本人虾悠悠 QQ:617600535 邮箱:leezhoucloud@gmail.com,欢迎交流。
注:本文针对G版源码进行一些结构性的分析。
首先想借用一段大神在blog的话,原文如下:“其实,对于OpenStack来说,它的强大并不是说它的代码写的多牛逼,而在于它的框架,它的设计思想。很多人虽然一说OpenStack,都知道可以通过OpenStack创建虚拟机,启动/停止虚拟机,创建卷,创建网络等等这些功能,却不在意它的工作流程,它的消息机制,它的异常处理,它的扩展机制,组件之间的交互等等,而这些才是OpenStack的核心。”
经过一段时间的总结,通过不断学习大牛的blog和官方文档,我从刚开始看nova源码的稀里糊涂,到现在的慢慢理解它的很多概念,设计和框架还谈不上,没理解完整,反正菜鸟之路异常艰辛啊,不管怎样,我的蛋炒饭开始了...
补充:应同学要求,补充一张简图,希望大家能结合代码,把东西看得更加明白。
工具不太会用,图画的不好,有点简陋,希望大神勿喷...
第一篇技术Blog,我想先从《Nova Service 启动源码分析》开始,因为这是理解Nova服务的一个关键。Nova的启动脚本放在/nova/cmd目录下,里面有诸如compute,scheduler等等的启动源码,如下图所示:
本文主要针对nova-Scheduler服务来做分析:
主要过程:
a)/nova/cmd/scheduler.py 脚本启动代码
b) /nova/service.py 服务启动代码 --------create()创建服务service -> 初始化service() -> start启动service,并且开启rpc和periodic_task -> wait()等待结束
(一)启动脚本/nova/cmd/scheduler.py
(二)启动过程分析
1、在/nova/service.py,由上图调用,生成一个server对象,<代码:server = service.Service.create(binary='nova-scheduler',topic=CONF.scheduler_topic)>
本例中的binary = nova-scheduler,manager = nova-manager...
2、在/nova/service.py,启动刚实例化的server对象,<代码:service.serve(server)>
3、在nova/openstack/common/service.py中,调用launch函数
(三)Service具体启动的一些东东
1、在/nova/service.py下,Service类下,start方法重要部分代码如下:
(1)第一部分主要关于Scheduler服务启动后,需要开启RPC监听功能
(2)主要执行周期性工作,具体在以后文章中专门讲periodic_task
至此,一个Scheduler的Service就正式启动,并且等待结束了,先吃午饭去第一次写博客,速度各种慢,累死我了