Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1522762
  • 博文数量: 230
  • 博客积分: 474
  • 博客等级: 下士
  • 技术积分: 1955
  • 用 户 组: 普通用户
  • 注册时间: 2010-03-19 18:40
文章分类

全部博文(230)

文章存档

2020年(3)

2019年(3)

2018年(12)

2017年(13)

2016年(11)

2015年(55)

2014年(74)

2013年(39)

2012年(2)

2011年(18)

我的朋友

分类: 云计算

2015-11-03 14:32:15

本人虾悠悠  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就正式启动,并且等待结束了,先吃午饭去哭第一次写博客,速度各种慢,累死我了骂人
阅读(2502) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~