DEA_NG 剖析

引言

dea主要负责的是应用的打包和部署,下面来简单剖析下dea的启动步骤。

bootstrap

setup

  1. validate_config:config配置加载
  2. setup_logging:设置日志
  3. setup_droplet_registry:初始化DropletRegistry对象,参数是droplet的打包存储路径
  4. setup_instance_registry:初始化InstanceRegistry对象,参数是config
  5. setup_staging_task_registry:初始化StagingTaskRegistry对象,这个对象维护了一个map
  6. setup_resource_manager:初始化ResourceManager对象,参数是InstanceRegistry,StagingTaskRegistry,config["resource"]
  7. setup_directory_server:初始化DirectoryServer对象
  8. setup_directory_server_v2:初始化DirectoryServerV2,源码文件系统,jdc file命令就是请求的这个服务
  9. setup_signal_handlers:信号处理初始化
  10. setup_directories:文件目录创建:db,droplets, instances, tmp, staging
  11. setup_pid_file:生成dea的pid
  12. setup_sweepers:启动heartbeat的定时任务,汇报instance的状态;InstanceRegistry启动定时任务start_reaper;启动定时任务进行droplet的清理
  13. setup_nats:初始化nats对象,参数是bootstrap,config;这个是由于所有消息订阅的处理全部在bootstrap中实现的
  14. setup_router_client:初始化RouterClient对象,负责向router发布消息

start

  1. start_component:vcap中注册dea这个组件
  2. start_nats:nats的启动,开始订阅消息
  3. start_directory_server:启动DirectoryServer
  4. greet_router:往gorouter发送greet消息,收到response后,初始化一个定时器,instance往gorouter的注册
  5. register_directory_server_v2:往router注册文件目录服务
  6. directory_server_v2这个文件目录服务的启动
  7. setup_varz:设置统计信息

经过setup和start后,dea就启动起来了,后续的操作都是通过消息订阅来进行处理的。

消息订阅

nats
  1. healthmanager.start:如果收到healthmanager的启动消息,会发布dea.heartbeat消息,告知当前所有instance的状态;
  2. router.start:收到router的启动消息,如果收到register的定时时间间隔,那么需要取消默认的定时器,重新初始化一个定时器,往gorouter注册dea中instance的信息;
  3. dea.status:回复当前的dea状态信息给订阅者
  4. dea.#{bootstrap.uuid}.start:收到app启动命令,会先初始化instance,然后启动instance;这里涉及了很多操作,具体细节可以查看源码;只是这里droplet包的下载和虚拟化空间是同步进行
  5. dea.stop:暂停app实例
  6. dea.update:dea状态更新(指的是uri更新)
  7. dea.find.droplet:返回droplet包对应的地址
dea_locator
  1. dea.locate:发布消息dea.advertise,汇报这个dea的id,app个数,可使用内存等信息
staging
  1. staging.#{@dea_id}.start:启动打包流程
  2. staging.stop:暂停打包
staging_locator
  1. staging.locate:发布消息staging.advertise,汇报可用内存和平台信息

Droplet打包流程图



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值