欢迎来到虚拟机的世界,如果我们将Openstack环境里运行在各个无力节点上的各种服务看座生命体,而不是死的指令集合,那么就是一个虚拟机的世界。

Openstack的计算组件,也就是Nova项目实现了虚拟机世界的抽象,控制者一个个虚拟机的状态变迁与生老病死,管理者它们的资源分配。

Nova的体系结构

Nova主要由API、Compute、Conductor、Scheduler四个核心服务组成,它们之前通过AMQP消息队列进行通信

API上进去Nova的HTTP借口,Compute和VMM(虚拟机管理器)交互来进行虚拟机并管理虚拟机的生命周期,Scheduler从可用池中选择最合适的计算节点来创建新的虚拟机实例,Conductor为数据库的访问提供一层安全保障,Scheduler只是读取数据库的内容,API则由Policy保护,因此它们都可以直接操作数据库,但是社区还是希望涉及数据库的操作都通过Conductor

以创建虚拟机为例,首先用户执行novaclient提供的用于创建虚拟机的命令,API服务间听到novaclient发送的HTTP请求并且将它转换成AMQP消息,通过消息队列调用Conductor服务,Conductor服务通过消息队列接受到任务之后,做一些准备工作(例如汇总虚拟机参数等),再通过消息队列告诉Scheduler去选择一个满足虚拟机创建要求的主机,Conductor拿到Scheduler提供的目标主机之后,会要求Compute服务创建虚拟机

并不是所有的业务流程都像虚拟机那样需要所有的服务,比如删除虚拟机时,不需要Scheduler服务,API通过消息队列告诉Compute删除指定虚拟机,Computed通过Conductor更新数据库即完成业务的流程

1.Nova源码目录结构

看到这里的想法是Openstack从入门到劝退

在一个城市里面寻找一个地方 最快的方法是打开地图,所以对新人来说,这里面最重要的文件是setup.cfg,作为Openstack的源码地图,setup.cfg文件就是浏览代码时候最为依仗的文件,它引导我们去认识一个新的项目,并了解它的代码结构

 [entry_points]
console_scripts =
nova-api = nova.cmd.api:main
nova-api-metadata = nova.cmd.api_metadata:main
nova-api-os-compute = nova.cmd.api_os_compute:main
nova-compute = nova.cmd.compute:main
nova-conductor = nova.cmd.conductor:main
nova-manage = nova.cmd.manage:main
nova-novncproxy = nova.cmd.novncproxy:main
nova-policy = nova.cmd.policy:main
nova-rootwrap = oslo_rootwrap.cmd:main
nova-rootwrap-daemon = oslo_rootwrap.cmd:daemon
nova-scheduler = nova.cmd.scheduler:main
nova-serialproxy = nova.cmd.serialproxy:main
nova-spicehtml5proxy = nova.cmd.spicehtml5proxy:main
nova-status = nova.cmd.status:main

每个setup.cfg文件的"entry_points"中都有会个比较特殊的组,或者说namespace。

console.scripts中的文件在部署的时候会生产执行文件,它也是入口文件

 # nova/compute/rpcapi.py
@profiler.trace_cls("rpc")
class ComputeAPI(object):
def live_migration(self, ctxt, instance, dest, block_migration, host,
migration, migrate_data=None):
version = '5.0'
client = self.router.client(ctxt)
# 获取目标机的RPC Client
cctxt = client.prepare(server=host, version=version)
# RPC cast主要用于异步任务,比如创建虚拟机,在创建过程可能需要很长时间
# 如果使用RPC call会等待 显然对性能有很大影响,csta()第二个参数是
# RPC调用对函数名,后面的参数将作为参数被传入该函数
cctxt.cast(ctxt, 'live_migration', instance=instance,
dest=dest, block_migration=block_migration,
migrate_data=migrate_data, migration=migration)

类ComputedAPI中的函数即为Compute服务提供给RPC调用的接口,其他服务调用前需要使用这个模块,比如

 # nova/conductor/tasks/live_migrate.py
class LiveMigrationTask(base.TaskBase):
def __init__(self, context, instance, destination,
block_migration, disk_over_commit, migration, compute_rpcapi,
servicegroup_api, query_client, report_client,
request_spec=None):
super(LiveMigrationTask, self).__init__(context, instance)
...
self.compute_rpcapi = compute_rpcapi
def _execute(self):
....
return self.compute_rpcapi.live_migration(self.context,
host=self.source,
instance=self.instance,
dest=self.destination,
block_migration=self.block_migration,
migration=self.migration,
migrate_data=self.migrate_data)

类ComputeAPI只是暴露给其他服务的RPC调用接口,Compute服务的RPC Server接受RPC请求后,真正完成任务的是nova.compute.manager

# nova/compute/manager.py
class ComputeManager(manager.Manager):
"""Manages the running instances from creation to destruction.""" target = messaging.Target(version='5.10')
def _do_live_migration(self, context, dest, instance, block_migration,
migration, migrate_data):
...

从ComputeAPI到ComputeManager的过程即是RPC调用过程

Openstack计算Nova组件的更多相关文章

  1. OpenStack 的Nova组件详解

    Open Stack Compute Infrastructure (Nova) Nova是OpenStack云中的计算组织控制器.支持OpenStack云中实例(instances)生命周期的所有活 ...

  2. openstack中Nova组件简解

    一.Nova组件概述 计算节点通过Nova Computer进行虚拟机创建,通过libvirt调用kvm创建虚拟机,nova之间通信通过rabbitMQ队列进行通信. Nova位于Openstack架 ...

  3. openstack中Nova组件images的全部python API 汇总

    感谢朋友支持本博客.欢迎共同探讨交流,因为能力和时间有限,错误之处在所难免.欢迎指正! 假设转载,请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...

  4. openstack中nova组件Hypervisors、Floating_ips的全部python API 汇总

    感谢朋友支持本博客,欢迎共同探讨交流,因为能力和时间有限.错误之处在所难免,欢迎指正! 假设转载.请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...

  5. openstack中Nova组件Networks的全部python API 汇总

    感谢朋友支持本博客.欢迎共同探讨交流.因为能力和时间有限.错误之处在所难免,欢迎指正! 假设转载,请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...

  6. OpenStack—nova组件计算服务

    nova介绍: Nova 是 OpenStack 最核心的服务,负责维护和管理云环境的计算资源.OpenStack 作为 IaaS 的云操作系统,虚拟机生命周期管理也就是通过 Nova 来实现的. 用 ...

  7. Nova 组件详解 - 每天5分钟玩转 OpenStack(26)

    本节开始,我们将详细讲解 Nova 的各个子服务. 前面架构概览一节知道 Nova 有若干 nova-* 的子服务,下面我们将依次学习最重要的几个.今天先讨论 nova-api 和 nova-cond ...

  8. 五、OpenStack—nova组件介绍与安装

    一.nova介绍 Nova 是 OpenStack 最核心的服务,负责维护和管理云环境的计算资源.OpenStack 作为 IaaS 的云操作系统,虚拟机生命周期管理也就是通过 Nova 来实现的. ...

  9. OpenStack 计算服务 Nova介绍和控制节点部署(七)

    介绍 Nova是openstack最早的两块模块之一,另一个是对象存储swift.在openstack体系中一个叫做计算节点,一个叫做控制节点.这个主要和nova相关,我们把安装为计算节点nova-c ...

随机推荐

  1. Scarpy框架安装教程

    在一切之前,建议升级pip,如果版本太低,安装会失败 升级pip命令: python -m pip install --upgrade pip 如果上面的命令不能用,用下面这个 easy_instal ...

  2. eclipse、myeclipse使用常用的小技巧

    1.修改类名称上的@author  *** Preference----Java----Code Style----Code Templates----->Comments----->Ty ...

  3. JAVA中String类的比较

    首先给大家看一段代码 package javaapptest; public class JavaAppTest { public static void main(String[] args) { ...

  4. 腾讯玩O2O手机维修 巨头入局引市场大变

     巨头入局引市场大变" title="腾讯玩O2O手机维修 巨头入局引市场大变">     对于"游击队"或初创企业来说,最怕的就是巨头的杀入. ...

  5. 醉酒驾驶VS睡眠不足,哪个更危险

    在全球范围内,睡眠不足驾驶每年导致成千上万起交通事故,醉酒驾驶就更不用说了.毫无疑问,两种情况下都不应该驾车,都有危险.睡眠不足和醉酒驾驶相对来说哪个更危险呢? 如果要问哪一个"好" ...

  6. Android空包签名

    空包签名 搜狗.优亿等Android市场,上传应用需要提供一个与要上传的应用相同签名的空包.这个空包是相应官方市场提供的,下载好之后需要使用命令行进行签名.具命令如下: 1 jarsigner -ve ...

  7. 美团新零售招聘-高级测试开发(20k-50k/月)

    内推邮箱:liuxinguang@meituan.com 地点:北京 职位级别:p2-2以上级别 15.5薪

  8. 对话|人工智能先驱Yoshua Bengio

    ​​ ​ Bengio"> 今年1月份,微软收购深度学习初创公司Maluuba时,Maluuba公司德高望重的顾问.深度学习先驱Yoshua Bengio也接手了微软的人工智能研究顾问 ...

  9. 原创:Python爬虫实战之爬取美女照片

    这个素材是出自小甲鱼的python教程,但源码全部是我原创的,所以,猥琐的不是我 注:没有用header(总会报错),暂时不会正则表达式(马上要学了),以下代码可能些许混乱,不过效果还是可以的. 爬虫 ...

  10. CSS过渡、动画及变形的基本属性与运用

    [逆战班] 动画可以让一个元素具有动态的效果,这个过程是使元素从一种样式变成另一个样式的过程.我们可以通过设置关键帧的方法来控制动画在某个时间节点的运动方式.通常设置多个节点来实现复杂的动画效果.0% ...