Openstack组件部署 — Overview和前期环境准备
Openstack组建部署 — Environment of Controller Node
Openstack组件部署 — Keystone功能介绍与认证明现流程
Openstack组件部署 — Keystone Install & Create service entity and API endpoints
Openstack组件部署 — keystone(domain, projects, users, and roles)
Openstack组件实现原理 — Keystone认证功能
Openstack组建部署 — Glance Install
Openstack组件实现原理 — Glance架构(V1/V2)
Openstack组件部署 — Nova overview
Openstack组件部署 — Nova_安装和配置Controller Node
Openstack组件部署 — Nova_Install and configure a compute node css
Nova主要有API、Compute、Conductor、Scheduler四个核心服务组成,这些服务之间经过AMQP消息队列来进行通讯。node
Client:Nova Client可以让Tenant管理员或用户终端提交指令,是Openstack官方为了简化用户对RESTful API的使用所提供的API封装,Client可以将用户的请求转换为标准的HTTP请求。数据库
API(nova-api service):nova-api service可以接收和响应Client的Compute API调用,因此API就是Client进入Nova的HTTP接口。api
Compute(nova-compute service):nova-compute service是一个经过hypervisor APIs(虚拟化层API)来实现建立和终止虚拟机实例的守护进程,Compute经过和VMM的交互来运行虚拟机并管理虚拟机的生命周期。安全
Scheduler(nova-scheduler service):nova-scheduler service会从queue中接收一个虚拟机实例的请求,并肯定该实例可以运行在哪一台Compute server中。Scheduler经过读取数据库的内容,从可用的池中选择最合适的Compute Node来建立新的虚拟机实例。markdown
Conductor(nova-conductor):nova-conductor module可以协调nova-compute service和database之间的交互,Conductor为数据库访问提供了一层安全保障。架构
Queue:queue是Nova 服务组件之间传递信息的中心枢纽。一般使用AMQP(高级消息队列协议Advanced Message Queuing Protocol)的RabbitMQ消息队列来实现。dom
注意:由于Scheduler只能读取数据库内容,和API经过Policy机制来限制数据库的访问,因此Scheduler和API这两个服务均可以直接访问数据库。可是支持引入了Conductor服务以后,更加规范的方法是经过Conductor服务来对数据库进行操做。ui
Step1:首先用户执行Nova Client提供的用于建立虚拟机的指令.net
Step2:nova-api service监听到来自于Nova Client的HTTP请求,并将这些请求转换为AMQP消息以后加入消息队列Queue
Step3:经过消息队列Queue调用nova-conductor service
Step4:nova-conductor service从Queue接收到虚拟机实例化请求消息后,进行一些准备工做(EG. 汇总HTTP请求中所须要实例化的虚拟机参数)
Step5:nova-conductor service经过Queue告诉nova-scheduler去选择一个合适的Compute Node来建立虚拟机,此时nova-scheduler会读取数据库的内容
Step6:nova-conductor从nova-scheduler获得了合适的Compute Node的信息后,在经过Queue来通知nova-compute service实现虚拟机的建立
送虚拟机实例化的过程能够看出,Nova中最重要的4个服务之间的通讯都是经过Queue来实现的。这符合松耦合的实现方式。