07.计算Nova→2.nova组件详解→3.nova-compute

nova-compute 在计算节点上运行,负责管理节点上的 instance。 OpenStack 对 instance 的操作,最后都是交给 nova-compute 来完成的。 nova-compute 与 Hypervisor 一起实现 OpenStack 对 instance 生命周期的管理。

  1. 通过 Driver 架构支持多种 Hypervisor
    1. nova-compute 多种 Hypervisor 定义了统一的接口,Hypervisor 只需要实现这些接口,就可以 Driver 的形式即插即用到 OpenStack 系统中。paste-183833190203395.jpg
    2. 可以在 /opt/stack/nova/nova/virt/ 目录下查看到 OpenStack 源代码中已经自带了上面这几个 Hypervisor 的 Driver
       1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      root@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
    3. 某个特定的计算节点上只会运行一种 Hypervisor,只需在该节点 nova-compute 的配置文件 /etc/nova/nova.conf 中配置所对应的 compute_driver 就可以了。在我们的环境中因为是 KVM,所以配置的是 Libvirt 的 driver。
      1
      2
      [DEFAULT]
      compute_driver = libvirt.LibvirtDriver

  2. 定期向 OpenStack 报告计算节点的状态
    1.  nova-scheduler 的很多 Filter 是根据算节点的资源使用情况进行过滤的。比如 RamFilter 要检查计算节点当前可以的内存量;CoreFilter 检查可用的 vCPU 数量;DiskFilter 则会检查可用的磁盘空间。OpenStack 是如何得知每个计算节点的这些信息呢? 
    2. 查看nova-compute的日志由于我配的devstack在两台节点上都有nova-comute服务,因此两台节点都有自己的日志:root@controller:~# journalctl -af --unit devstack@n-cpu.service
      1. Total usable vcpus: 1, total allocated vcpus: 0:报告当前计算节点资源使用情况,vcpus为1说明这个节点的cpu数量为1,allocated vcpus表示给在这个节点创建的虚拟机分配的cpu数量
      2. Compute_service record updated for controller:controller:更新nova-compute服务状态
      3. Running periodic task ComputeManager:运行周期性任务
      4. Didn't find any instances for network info cache update:因为此时还没有建虚拟机,所以出现这条日志
    3. nova-compute 是如何获得当前计算节点的资源使用信息的:nova-compute 可以通过 Hypervisor 的 driver 拿到这些信息,举例来说,在我们的实验环境下 Hypervisor 是 KVM,用的 Driver 是 LibvirtDriver。 LibvirtDriver 可以调用相关的 API 获得资源信息,这些 API 的作用相当于我们在 CLI 里执行 virsh nodeinfo、virsh dominfo 等命令。
paste-198337294761987.jpg
  1. 实现 instance 生命周期的管理
    1. OpenStack 对 instance 最主要的操作都是通过 nova-compute 实现的,包括 instance 的 launch、shutdown、reboot、suspend、resume、terminate、resize、migration、snapshot 等。
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值