nova分析(6)—— nova service启动过程
Nova project下面具有多个service,api,compute,sceduler等等,他们的启动过程都几乎类似,这一篇博客就详细记录nova-sceduler的启动过程。文章中贴出的源码都是从OpenStack Folsom版截取过来的。
下面就开始分析nova-sceduler的启动过程了,后面还有涉及到启动之后,做的一些周期性工作,这部分可能与sceduler无关,是在compute中的,一次帖上来。

首先是解析启动脚本的参数,包括配置文件,设置日志,utils.monkey_patch现在不明白(为了能够使用高效的eventlet模块,需要打些补丁),然后创建服务,最后启动服务,等待请求。 Service.Service.create(binary=’nova-scheduler)过程如下:

过程为获取host name,topic即为用来与rabbit通信的标识,为scheduler,manager为scheduler_manager,在flags中搜索其对应的类名,其值在nova.conf中指定,默认值为nova.scheduler.manager.SchedulerManager ,report_interval为节点将状态报告给数据库的时间间隔,默认为10秒。Periodic_interval,执行周期性任务的周期。再开始初始化service。

其中关键的manager,其中self.manager_class_name 为nova.scheduler.manager.SchedulerManager,通过importutils.import_class动态的导入该对象,故manager_class是<class ‘nova.scheduler.manager.SchedulerManager’>这么一个对象。(记住,在python中,一切都是对象,有类型对象,实例对象,譬如int为一个类型对象,5则为一个实例对象,其类型是int,而int的类型则为type。)然后,调用SchedulerManager的__init__函数完成初始化,注意SchedulerManager的__init__函数的参数列表,有args和kwargs,所以host=self.host就成了kwargs的一项。
创建完service类之后,开始启动service。

其中workers为none,执行else语句,lanuch_server如下:

使用eventlet.spawn启动一个green thread,run_server如下:

开始启动server,其中start的关键代码如下:

首先获取一个到rabbitmq server的连接,然后再注册一个rpc_dispatcher,该对象与回调函数相关,接收到rabbitmq的消息后,再由它来处理,接着创建多个consumer来接收特定topic的消息队列的消息,并设置好消息监听。 这样一个服务就启动来了,在后面还有设置周期性的task。
在初始化service的过程中,会调用importutils动态导入具体的manager,对于nova-compute,导入的则是ComputeManager,该类的继承关系是,ComputeManager,Manager.SchedulerDependentManager,Manager,nova.db.Base.其中Manager包含ManagerMeta元类。可以参考RabbitMQ(三)中的manager类关系图。 对Manager与ManagerMeta的分析如下,这块代码涉及到一个资源刷新的问题。对于metaclass的分析可以参考后面的python高级中的metaclass最后一个例子分析。Manager具有一个类属性_periodic_tasks,是一个列表类型的属性,元素是各个需要周期执行的task。在manager类创建时,因为使用到了metaclass,会首先检查每个具有_periodic_task属性的函数,该属性由装饰器periodic_task装饰上的。

这部分的代码就是启动周期性的task。
LoopingCall初始化最关键的参数是f,即传递进一个函数。430行,就将service的report_state函数传递进去,然后调用start函数,下面是start函数的实现。

可以知道,start函数内部有一个闭包函数,然后启动一个greenthread的来执行这个内部函数,内部函数根据传递的参数,决定是否要推迟启动,然后开始周期性的执行传递进来的函数,即self.report_state和self.periodic_task.
查看report_state的代码,关键的如下:

主要的作用是周期性的更新数据库中的nova库service表的report_count字段,目前不知道该字段有什么作用!
再查看periodic_task函数,service.periodic_tasks函数最后会调用self.manager.periodic_tasks,该函数在nova.manager.py中,该函数会去调用被periodic_task装饰的函数,在nova-compute服务中,被periodic_task装饰的有_publish_service_capabilities函数,_report_driver_status函数等等,report_driver_status读取host的相关信息,然后更新capabilities,最后通过scheduler_rpcapi发送到scheduler服务去。
再开始看其中重要的一块RPC,Rpc参考前面的RabbtMQ三,关于rpc有详细的介绍。 最后一块pluginManager。
本文转自 http://www.choudan.net/2013/08/09/Nova-Service启动.html
nova分析(6)—— nova service启动过程的更多相关文章
- Envoy 源码分析--程序启动过程
目录 Envoy 源码分析--程序启动过程 初始化 main 入口 MainCommon 初始化 服务 InstanceImpl 初始化 启动 main 启动入口 服务启动流程 LDS 服务启动流程 ...
- 跟踪分析Linux内核的启动过程--实验报告 分析 及知识重点
跟踪分析Linux内核的启动过程 攥写人:杨光 学号:20135233 ( *原创作品转载请注明出处*) ( 学习课程:<Linux内核分析>MOOC课程http://mooc.stud ...
- 20135202闫佳歆--week3 跟踪分析Linux内核的启动过程--实验及总结
实验三:跟踪分析Linux内核的启动过程 一.调试步骤如下: 使用gdb跟踪调试内核 qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd r ...
- 跟踪分析Linux内核的启动过程小解
跟踪分析Linux内核的启动过程 “20135224陈实 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029 ...
- SpringBoot源码分析之SpringBoot的启动过程
SpringBoot源码分析之SpringBoot的启动过程 发表于 2017-04-30 | 分类于 springboot | 0 Comments | 阅读次数 SpringB ...
- 实验三:跟踪分析Linux内核的启动过程
实验三:跟踪分析Linux内核的启动过程 学号:20135114 姓名:王朝宪 注: 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.16 ...
- 20135239 益西拉姆 linux内核分析 跟踪分析Linux内核的启动过程
回顾 1.中断上下文的切换——保存现场&恢复现场 本节主要课程内容 Linux内核源代码简介 1.打开内核源代码页面 arch/目录:支持不同CPU的源代码:其中的X86是重点 init/目录 ...
- Linux内核分析第三周学习博客——跟踪分析Linux内核的启动过程
Linux内核分析第三周学习博客--跟踪分析Linux内核的启动过程 实验过程截图: 过程分析: 在Linux内核的启动过程中,一共经历了start_kernel,rest_init,kernel_t ...
- Spring源码分析专题 —— IOC容器启动过程(上篇)
声明 1.建议先阅读<Spring源码分析专题 -- 阅读指引> 2.强烈建议阅读过程中要参照调用过程图,每篇都有其对应的调用过程图 3.写文不易,转载请标明出处 前言 关于 IOC 容器 ...
随机推荐
- 《JavaScript模式》第2章 基本技巧
@by Ruth92(转载请注明出处) 第2章 基本技巧 一.编写可维护的代码 阅读性好 具有一致性 预见性好 看起来如同一个人编写 有文档 编写注释 编写 API 文档 @namespace:用于命 ...
- ui-bootstrap-tpls-0.11.0.min.js
- Lucene建索引代码
Lucene 是apache软件基金会一个开放源代码的全文检索引擎工具包,是一个全文检索引擎的架构,提供了完整的查询引擎和索引引擎,部分文本分析引擎. Lucene的目的是为软件开发人员提供一个简单易 ...
- Sprint第二个冲刺(第三天)
一.Sprint 计划会议: 今天我们召开了第二个Sprint的第三次会议,会议上我们把各自完成的情况进行了一次总结,现在主界面和美化按钮.增添图片的功能已经完成了,Doing里面的其他 ...
- tyvj 1056 能量项链 区间dp (很神)
P1056 能量项链 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 NOIP2006 提高组 第一道 描述 在Mars星球上,每个Mars人都随身佩 ...
- keil uvision看厌了么?试试Sublime Text吧!
之前用 Sublime Text(以下简称 ST )配置了 C/C++ 开发环境,感觉相当不错,作为编辑器的 ST,编辑代码的功能当然是相当棒的,美中不足的是目前只能编译单个文件,但是用来做些小练习也 ...
- JavaScript BOM 遗漏知识再整理;弹窗和记时事件;
1.JavaScript 弹窗 警告框 警告框经常用于确保用户可以得到某些信息. 当警告框出现后,用户需要点击确定按钮才能继续进行操作. window.alert() 方法可以不带上window对象, ...
- 软件或jar包等名字里的GA意思
首页 > 转贴的文章 > 软件的版本"GA"代表什么意思?如MyEclipse 5.0 GA 软件的版本"GA"代表什么意思?如MyEclips ...
- bzoj 1061 志愿者招募(最小费用最大流)
[Noi2008]志愿者招募 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 3792 Solved: 2314[Submit][Status][Di ...
- URAL 1208 Legendary Teams Contest(DFS)
Legendary Teams Contest Time limit: 1.0 secondMemory limit: 64 MB Nothing makes as old as years. A l ...