openstack-nova-metadata-api.service
openstack-nova-network.service
nova-api负责接受和响应终端用户有关虚拟机和云硬盘的请求,提供了openstackAPI,亚马逊EC2AP以及管理员控制API,一句话:nova-api是整个nova的入口。它接受用户请求,将指令发送至消息队列,由相应的服务执行相关的指令信息。
nova-compute是主要的执行守护进程,职责是基于各种虚拟化技术Hypervisior实现创建和终止虚拟机。nova-compute有两个工作,接受消息队列中的执行指令,并执行相关指令,如部署虚拟机。维护数据库相关模型的状态数据。
nova-compute整合了计算资源CPU,存储,网络三类资源部署管理虚拟机,实现计算能力的交付。包括如下内容:运行虚拟机,终止虚拟机,重启虚机,挂载虚拟机,挂载云硬盘,卸载云硬盘,控制台输出。
nova-volume/Cinder的职责是创建,挂载,和卸载持久化的磁盘虚拟机,运行机制类似nova-compute。同样是接受消息队列中的执行指令,并执行相关指令,volume的职责包括如下:创建云硬盘,删除云硬盘,弹性计算硬盘。一句话:就是为虚拟机增加块设备存储。
nova-network的职责是实现网络资源池的管理,包括IP池,网桥接口,VLAN,防火墙的管理。接受消息队列指令消息并执行。network的职责包括如下:分配私有云,VLAN,配置计算节点网络。nova-network解决云计算网络资源池的网络问题。
nova-schedule的职责是调度虚拟机在哪个物理宿主机上部署,接受消息队列指令并执行。
Queue也就是消息队列,他就像是网络上的一个hub,nova各个组件之间的通信几乎都是靠它进行的,当前的Queue是用RabbitMQ实现的,它和database一起为各个守护进程之间传递消息。
组件:
API
Nova-api请求和回复一个用户计算的API,支持openstack 计算API,Amazon EC2 api和Admin Api对特权用户执行管理操作,另外启动最新的任务,如运行一个实例,安装一个虚拟机
Nova-api-metadata 接受来自实例的元数据请求
Comput core
Nova-comput 进程,一个守护进程,通过虚拟机管理程序的API创建和终止虚拟机实例,如xenapi for xenserver/xcp libvirt适用于kvm 或qemu vmwareapi 适用于vmware
Nova-scheduler 进程,调度,从消息队列中取一个虚拟机实例的请求,并执行在其虚拟主机上。
Nova-conductor 模式,介于nova-computer和database之间,设计目的在于消除直接nova-computer直接访问云数据库。
Networking for VMs
Nova-network 工作守护进程,类nova-computer它接受消息队列中的任务闭幕式执行,如设立桥接接口或者更改iptables规则,
Nova-dhcpbridge 脚本,跟踪IP地址租约,并通过使用dnsmasq的DHCP脚本记录在数据库中。
Console interface
Noca-consoleauth 守护进程,由用户的console控制台代理提供授权tokens,两种模式nova-novncproxy和nova-xvcproxy
nova-novncproxy 守护进程,提供了VNC连接访问正在运行的实例的代表,基于novnc客户浏览器
Nova-console 已经弃用,被 nova-xvncproxy取代
nova-xvncproxy 守护进程,通过vnc连接访问正在运行的实例代理,支持专门设计的Openstack的java客户端
Nova-cert 守护进程,管理x509证书
Image management
nova-objectstore 提供了一个用于注册S3接口的镜像服务,主要必须支持euca2ools安装,nova-objectstore转换S3请求镜像服务的请求
Euca2ools 客户端,一组命令解释器来管理云资源,可以配置nova-api来支持EC2接口。
Command-line clients and other interfaces
Nova 客户端 使用户、租客管理员提交命令
Nova-manage 客户端,使云管理员提交命令
Other components
The queue 消息队列 rabbitmq,apache qpid zeromq
Sql database 数据库mysql,sqlite,PostgreSQL