nova-compute 在计算节点上运行,负责管理节点上的 instance。 OpenStack 对 instance 的操作,最后都是交给 nova-compute 来完成的。 nova-compute 与 Hypervisor 一起实现 OpenStack 对 instance 生命周期的管理。
- 通过 Driver 架构支持多种 Hypervisor
- nova-compute 多种 Hypervisor 定义了统一的接口,Hypervisor 只需要实现这些接口,就可以 Driver 的形式即插即用到 OpenStack 系统中。
- 可以在 /opt/stack/nova/nova/virt/ 目录下查看到 OpenStack 源代码中已经自带了上面这几个 Hypervisor 的 Driver
1
2
3
4
5
6
7
8
9
10
11root@controller:~# ll /opt/stack/nova/nova/virt/ |grep '^d'
drwxr-xr-x 10 stack stack 4096 Jun 8 00:51 ./
drwxr-xr-x 30 stack stack 4096 Jun 8 00:51 ../
drwxr-xr-x 4 stack stack 4096 Jun 8 00:51 disk/
drwxr-xr-x 2 stack stack 4096 Jun 7 23:36
drwxr-xr-x 2 stack stack 4096 Jun 8 00:51 image/
drwxr-xr-x 2 stack stack 4096 Jun 8 00:28 ironic/
drwxr-xr-x 4 stack stack 4096 Jun 8 00:51
drwxr-xr-x 4 stack stack 4096 Jun 7 23:36 powervm/
drwxr-xr-x 2 stack stack 4096 Jun 7 23:36
drwxr-xr-x 3 stack stack 4096 Jun 7 23:36 - 某个特定的计算节点上只会运行一种 Hypervisor,只需在该节点 nova-compute 的配置文件 /etc/nova/nova.conf 中配置所对应的 compute_driver 就可以了。在我们的环境中因为是 KVM,所以配置的是 Libvirt 的 driver。
1
2[DEFAULT]
compute_driver = libvirt.LibvirtDriver
- 定期向 OpenStack 报告计算节点的状态
- nova-scheduler 的很多 Filter 是根据算节点的资源使用情况进行过滤的。比如 RamFilter 要检查计算节点当前可以的内存量;CoreFilter 检查可用的 vCPU 数量;DiskFilter 则会检查可用的磁盘空间。OpenStack 是如何得知每个计算节点的这些信息呢?
- 查看nova-compute的日志由于我配的devstack在两台节点上都有nova-comute服务,因此两台节点都有自己的日志:root@controller:~# journalctl -af --unit devstack@n-cpu.service
- Total usable vcpus: 1, total allocated vcpus: 0:报告当前计算节点资源使用情况,vcpus为1说明这个节点的cpu数量为1,allocated vcpus表示给在这个节点创建的虚拟机分配的cpu数量
- Compute_service record updated for controller:controller:更新nova-compute服务状态
- Running periodic task ComputeManager:运行周期性任务
- Didn't find any instances for network info cache update:因为此时还没有建虚拟机,所以出现这条日志
- nova-compute 是如何获得当前计算节点的资源使用信息的:nova-compute 可以通过 Hypervisor 的 driver 拿到这些信息,举例来说,在我们的实验环境下 Hypervisor 是 KVM,用的 Driver 是 LibvirtDriver。 LibvirtDriver 可以调用相关的 API 获得资源信息,这些 API 的作用相当于我们在 CLI 里执行 virsh nodeinfo、virsh dominfo 等命令。
- 实现 instance 生命周期的管理
- OpenStack 对 instance 最主要的操作都是通过 nova-compute 实现的,包括 instance 的 launch、shutdown、reboot、suspend、resume、terminate、resize、migration、snapshot 等。