Openstack计算Nova组件
欢迎来到虚拟机的世界,如果我们将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组件的更多相关文章
- OpenStack 的Nova组件详解
Open Stack Compute Infrastructure (Nova) Nova是OpenStack云中的计算组织控制器.支持OpenStack云中实例(instances)生命周期的所有活 ...
- openstack中Nova组件简解
一.Nova组件概述 计算节点通过Nova Computer进行虚拟机创建,通过libvirt调用kvm创建虚拟机,nova之间通信通过rabbitMQ队列进行通信. Nova位于Openstack架 ...
- openstack中Nova组件images的全部python API 汇总
感谢朋友支持本博客.欢迎共同探讨交流,因为能力和时间有限,错误之处在所难免.欢迎指正! 假设转载,请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...
- openstack中nova组件Hypervisors、Floating_ips的全部python API 汇总
感谢朋友支持本博客,欢迎共同探讨交流,因为能力和时间有限.错误之处在所难免,欢迎指正! 假设转载.请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...
- openstack中Nova组件Networks的全部python API 汇总
感谢朋友支持本博客.欢迎共同探讨交流.因为能力和时间有限.错误之处在所难免,欢迎指正! 假设转载,请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...
- OpenStack—nova组件计算服务
nova介绍: Nova 是 OpenStack 最核心的服务,负责维护和管理云环境的计算资源.OpenStack 作为 IaaS 的云操作系统,虚拟机生命周期管理也就是通过 Nova 来实现的. 用 ...
- Nova 组件详解 - 每天5分钟玩转 OpenStack(26)
本节开始,我们将详细讲解 Nova 的各个子服务. 前面架构概览一节知道 Nova 有若干 nova-* 的子服务,下面我们将依次学习最重要的几个.今天先讨论 nova-api 和 nova-cond ...
- 五、OpenStack—nova组件介绍与安装
一.nova介绍 Nova 是 OpenStack 最核心的服务,负责维护和管理云环境的计算资源.OpenStack 作为 IaaS 的云操作系统,虚拟机生命周期管理也就是通过 Nova 来实现的. ...
- OpenStack 计算服务 Nova介绍和控制节点部署(七)
介绍 Nova是openstack最早的两块模块之一,另一个是对象存储swift.在openstack体系中一个叫做计算节点,一个叫做控制节点.这个主要和nova相关,我们把安装为计算节点nova-c ...
随机推荐
- 吴裕雄--天生自然 R语言开发学习:高级编程
运行的条件是一元逻辑向量(TRUE或FALSE)并且不能有缺失(NA).else部分是可选的.如果 仅有一个语句,花括号也是可以省略的. 下面的代码片段是一个例子: plot(x, y) } else ...
- log4j不输出日志错误分析
1.rootLogger不输出 代码如下: 配置文件代码: log4j.rootLogger=info, R,userLog log4j.appender.R=org.apache.log4j.Rol ...
- php数据库连接和mysql语句使用
从简单的登录页开始学习. 前提:已经有一个html+css+js的静态网站 登录: php连接数据库,读取数据. <?php $username = root; $userpass = shao ...
- HTTP的响应码?
响应头对浏览器来说很重要,它说明了响应的真正含义.例如200表示响应成功了,302表示重定向,这说明浏览器需要再发一个新的请求. l 200:请求成功,浏览器会把响应体内容(通常是html)显示在浏览 ...
- AI超越人类大脑,或许是场“别有用心者”的骗局
谷歌.微软.苹果.特斯拉.百度.腾讯.阿里等互联网巨头企业,以及纳德拉.马斯克.扎克伯格.马云等互联网大佬,近年来一直都对人工智能--AI非常上心.在众多场合对AI给予了或肯定,或恐惧的评价.但无 ...
- fastcgi_param详解
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;#脚本文件请求的路径 fastcgi_param QUERY_STRI ...
- app后端用户登录api
app将用户名和密码发送到服务器,服务器验证用户名和密码都正确后,会在redis或memcached服务器中以用户id为键生成token字 符串,然后服务器把token字符串和用户id都返回给客户端( ...
- ITT Corporation之“中国战略”
前言:众所周知,中国已经成为全世界第二大经济体,并且坐拥14亿人口的庞大市场,蕴藏着巨大的市场机遇,海外高科技企业想法获得长足的发展重视和开拓中国市场成为重中之重,诸如特斯拉,google,苹果等,近 ...
- ORB-SLAM2 运行 —— ROS + Android 手机摄像头
转载请注明出处,谢谢 原创作者:Mingrui 原创链接:https://www.cnblogs.com/MingruiYu/p/12404730.html 本文要点: ROS 配置安装 解决 sud ...
- Matplotlib数据可视化(4):折线图与散点图
In [1]: from matplotlib import pyplot as plt import numpy as np import matplotlib as mpl mpl.rcParam ...