热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

OpenStackNovaService启动过程分析

Novaproject下面具有多个service,api,compute,sceduler等等,他们的启动过程都几乎类似,这一篇博客就详细记录nova-sceduler的启动过程。文章中贴出的源码都是从OpenStackFolsom版截取过来的。下面就开始分析nova-sceduler的启动过程了,后面还有涉及到启

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是这 么一个对象。(记住,在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。


推荐阅读
  • 本文介绍了Python对Excel文件的读取方法,包括模块的安装和使用。通过安装xlrd、xlwt、xlutils、pyExcelerator等模块,可以实现对Excel文件的读取和处理。具体的读取方法包括打开excel文件、抓取所有sheet的名称、定位到指定的表单等。本文提供了两种定位表单的方式,并给出了相应的代码示例。 ... [详细]
  • 一面自我介绍对象相等的判断,equals方法实现。可以简单描述挫折,并说明自己如何克服,最终有哪些收获。职业规划表明自己决心,首先自己不准备继续求学了,必须招工作了。希望去哪 ... [详细]
  • mapreduce源码分析总结
    这篇文章总结的非常到位,故而转之一MapReduce概述MapReduce是一个用于大规模数据处理的分布式计算模型,它最初是由Google工程师设计并实现的ÿ ... [详细]
  • 项目需要将音视频文件上传服务器,考虑并发要求高,通过七牛来实现。直接上代码usingQiniu.IO;usingQiniu.IO.Resumable;usingQiniu.RPC; ... [详细]
  • java布尔字段用is前缀_POJO类中布尔类型的变量都不要加is前缀详解
    前言对应阿里巴巴开发手册第一章的命名风格的第八条。【强制】POJO类中布尔类型的变量都不要加is前缀,否则部分框架解析会引起序列化错误。反例:定义为基本 ... [详细]
  • Hadoop 源码学习笔记(4)Hdfs 数据读写流程分析
    Hdfs的数据模型在对读写流程进行分析之前,我们需要先对Hdfs的数据模型有一个简单的认知。数据模型如上图所示,在NameNode中有一个唯一的FSDirectory类负责维护文件 ... [详细]
  • NFS文件共享系统
    1、概述:NFS(NetworkFileSystem)意为网络文件系统,它最大的功能就是可以通过网络,让不同的机器不同的操作系统可以共享 ... [详细]
  • 定义#definePCAP_OPENFLAG_PROMISCUOUS1    定义适配器是否必须进入混杂模式。#definePCAP_OPENFLAG_DATATX_UDP2    ... [详细]
  • SOA架构理解理解SOA架构,了解ESB概念,明白SOA与微服务的区别和联系,了解SOA与热门技术的结合与应用。1、面向服务的架构SOASOA(ServiceOrien ... [详细]
  • 提示信息_局域网内互发提示信息
    本文由编程笔记#小编为大家整理,主要介绍了局域网内互发提示信息相关的知识,希望对你有一定的参考价值。【局域网内互发提示信息】准备工作:1.rege ... [详细]
  • windows平台使用NSP拦截具体进程的域名解析过程(xFsRedir的代理功能之域名代理)
    byfanxiushu2022-10-17转载或引用请注明原始作者。xFsRedir软件其中之一的功能就是实现了全方位的网络代理,从主机代理,到本地代理 ... [详细]
  • 微服务下的几个难点问题及常见的解决方案
    原文链接:https:cloud.tencent.comdevelopernews1362051背景介绍1.1幂等性定义数学定义在数学里,幂等有 ... [详细]
  • 自己手动写一个RPC框架
    一,简单一点的过程解说图(不太清晰,凑合看吧)Gitee仓库源码:https:gitee.comfanjiangfengwrite-rpc-framworkcommon模块创建商品 ... [详细]
  • Java开发面试问题,2021网易Java高级面试题及答案,实战案例
    前言大厂面试真题向来都是各大求职者的最佳练兵场,而今天小编带来的便是“HUAWEI”面经!这是一次真实的面试经历,虽然不是我自己亲身经历 ... [详细]
  • 本文为转载,原连接:https:www.zhihu.comquestion40822826简单说一下吧做要解释这些要从netconf说起。netconf ... [详细]
author-avatar
cometcui
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有