07.计算Nova→3.场景学习→2.Launch→3.nova-compute

描述 详细
  1. 为 instance 准备资源
    1. nova-compute 首先会根据指定的 flavor 依次为 instance 分配内存、磁盘空间和 vCPU。
    2. 网络资源也会提早分配。
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
DEBUG nova.compute.manager 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] Starting instance... 
{{(pid=5666) _do_build_and_run_instance /opt/stack/nova/nova/compute/manager.py:1835
1
2
3
4
5
6
7
Jun 16 13:12:52 compute nova-compute[5666]: 
DEBUG oslo_concurrency.lockutils 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
Lock "compute_resources" acquired 
by "nova.compute.resource_tracker.instance_claim" :: waited 0.000s 
{{(pid=5666) inner 
/usr/local/lib/python2.7/dist-packages/oslo_concurrency/lockutils.py:273
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
DEBUG nova.compute.resource_tracker 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
Memory overhead for 512 MB instance; 0 MB 
{{(pid=5666) instance_claim /opt/stack/nova/nova/compute/resource_tracker.py:202
(ADJ) 在头顶上的;在上面的;高架的→You use overhead to indicate that something is above you or above the place that you are talking about.
n. 常常费用; 常常开支; 
这里指开销
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
DEBUG nova.compute.resource_tracker 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
Disk overhead for 1 GB instance; 0 GB 
{{(pid=5666) instance_claim /opt/stack/nova/nova/compute/resource_tracker.py:205
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
DEBUG nova.compute.resource_tracker 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
CPU overhead for 1 vCPUs instance; 0 vCPU(s) 
{{(pid=5666) instance_claim /opt/stack/nova/nova/compute/resource_tracker.py:208
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
Attempting claim on node compute: memory 512 MB, disk 1 GB, vcpus 1 CPU
建立虚拟机时选择的flavor是
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
Total memory: 7983 MB, used: 512.00 MB
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
memory limit not specified, defaulting to unlimited
1
2
3
4
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] Total disk: 47 GB, used: 0.00 GB
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
disk limit not specified, defaulting to unlimited
1
2
3
4
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] Total vcpu: 4 VCPU, used: 0.00 VCPU 
4VCPU是由于该日志是在公司开发环境搭建的2节点devstack上产生的,每台机器VCPU数量为4
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
vcpu limit not specified, defaulting to unlimited
1
2
3
4
5
Jun 16 13:12:52 compute nova-compute[5666]: 
DEBUG nova.virt.hardware 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
Require both a host and instance NUMA topology to fit instance on host. 
{{(pid=5666) numa_fit_instance_to_host /opt/stack/nova/nova/virt/hardware.py:1465
1
2
3
4
Jun 16 13:12:52 compute nova-compute[5666]: 
INFO nova.compute.claims 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] Claim successful on node compute
网络资源也会提早分配。
1
2
3
4
5
6
Jun 16 13:12:53 compute nova-compute[5666]: 
DEBUG nova.compute.manager 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin]
 [instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
Allocating IP information in the background. 
{{(pid=5666) _allocate_network_async /opt/stack/nova/nova/compute/manager.py:1423
  1. 建立 instance 的镜像文件
首先将该 image 下载到计算节点,而后将其做为 backing file 建立 instance 的镜像文件。
    1. 从 Glance 下载 image
      1. 资源准备好以后,nova-compute 会为 instance 建立镜像文件。OpenStack 启动一个 instance 时,会选择一个 image,这个 image 由 Glance 管理。
  1. nova-compute 首先会检查 image 是否已经下载(好比以前已经建立过基于相同 image 的 instance)。若是没有,就从 Glance 下载 image 到本地。由此可知,若是计算节点上要运行多个相同 image 的 instance,只会在启动第一个 instance 的时候从 Glance 下载 image,后面的 instance 启动速度就大大加快了。 
  1. 日志分析:
    1. image(ID为 f0bdf0e7-ebb5-459d-a7a5-a0f0ed13d6d7)是 qcow2 格式,nova-compute 将其下载。Nova 默认会经过 qemu-img 转换成 raw 格式,以提升 IO 性能。
    2. 下载的image 的存放目录是 /opt/stack/data/nova/instances/_base,这是由/etc/nova/nova.conf 的两个配置选项决定的
      1
      2
      3
      4
      5
      [DEFAULT]
      ...
      instances_path = /opt/stack/data/nova/instances
      base_dir_name = _base
      ...
    3. 下载的 image 文件被命名为 6eb03a619bcf59de5a27bf520cf83606bf8327a7,这是 image id 的 SHA1 哈希值Secure Hash Algorithm
1
2
3
4
5
Jun 16 13:12:55 compute nova-compute[5666]: 
DEBUG nova.virt.images 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
f0bdf0e7-ebb5-459d-a7a5-a0f0ed13d6d7 was qcow2, converting to raw 
{{(pid=5666) fetch_to_raw /opt/stack/nova/nova/virt/images.py:179
1
2
3
4
5
Jun 16 13:12:55 compute nova-compute[5666]: 
DEBUG nova.utils 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
Path '/opt/stack/data/nova/instances' supports direct I/O 
{{(pid=5666) supports_direct_io /opt/stack/nova/nova/utils.py:1394
1
2
3
4
5
6
7
Jun 16 13:12:55 compute nova-compute[5666]: 
DEBUG oslo_concurrency.processutils 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
Running cmd (subprocess): qemu-img convert -t none -O raw -f qcow2 
/opt/stack/data/nova/instances/_base/6eb03a619bcf59de5a27bf520cf83606bf8327a7.part 
/opt/stack/data/nova/instances/_base/6eb03a619bcf59de5a27bf520cf83606bf8327a7.converted 
{{(pid=5666) execute /usr/local/lib/python2.7/dist-packages/oslo_concurrency/processutils.py:372
-O:output format;-f:format;-t:cache



backing file的id不同是由于这条是我后来添加的笔记(又一个实例)
  1. 为 instance 建立镜像文件
    1. 有了 下载的image 以后,instance 的镜像文件直接经过 qemu-img 命令建立,backing file 就是下载的 image。
    2. 这里 instance 的镜像文件是 /opt/stack/data/nova/instances/86f71e87-4ae2-48fb-9bcd-c72e3c28e093/disk,格式为 qcow2,其中 86f71e87-4ae2-48fb-9bcd-c72e3c28e093就是 instance的 id。能够经过 qume-info 查看 disk 文件的属性
1
2
3
4
5
6
7
Jun 16 13:12:57 compute nova-compute[5666]: 
DEBUG oslo_concurrency.processutils 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
Running cmd (subprocess): qemu-img create -f qcow2 -o 
backing_file=/opt/stack/data/nova/instances/_base/6eb03a619bcf59de5a27bf520cf83606bf8327a7 
/opt/stack/data/nova/instances/86f71e87-4ae2-48fb-9bcd-c72e3c28e093/disk 
{{(pid=5666) execute /usr/local/lib/python2.7/dist-packages/oslo_concurrency/processutils.py:372
-o:options
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
root@compute:~# qemu-img info /opt/stack/data/nova/instances/86f71e87-4ae2-48fb-9bcd-c72e3c28e093/disk
image: /opt/stack/data/nova/instances/86f71e87-4ae2-48fb-9bcd-c72e3c28e093/disk
file format: qcow2
virtual size: 1.0G (1073741824 bytes)
disk size: 1.9M
cluster_size: 65536
backing file: /opt/stack/data/nova/instances/_base/6eb03a619bcf59de5a27bf520cf83606bf8327a7
Format specific information:
    compat: 1.1
    lazy refcounts: false
    refcount bits: 16
    corrupt: false
  1. 说明:
    1. image,指的是 Glance 上保存的镜像,做为 instance 运行的模板。 计算节点将下载的 image 存放在 /opt/stack/data/nova/instances/_base 目录下。
    2. 镜像文件,指的是 instance 启动盘所对应的文件
    3. 两者的关系是:image 是镜像文件 的 backing file。image 不会变,而镜像文件会发生变化。好比安装新的软件后,镜像文件会变大。
    4. 英文中二者都叫 “image”,为避免混淆,咱们用 “image” 和 “镜像文件” 做区分。
  1. 建立 instance 的 XML 定义文件
    1. cloudman:建立的 XML 文件会保存到该 instance 目录 /opt/stack/data/nova/instances/f1e22596-6844-4d7a-84a3-e41e6d7618ef,命名为 libvirt.xml
    2. 我:在/opt/stack/data/nova/instances/86f71e87-4ae2-48fb-9bcd-c72e3c28e093/没有找到.xml这个文件
      1. 可是在计算节点的/etc/libvirt/qemu/发现xml文件,该文件记录了虚机的各类参数


cloudman:

个人:
日志中关于xml的有:
1
2
3
DEBUG nova.virt.libvirt.driver
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
Start _get_guest_xml network_info=[...
1
2
3
DEBUG nova.virt.libvirt.driver
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
End _get_guest_xml ...
这个过程应该是获取xml文件吧,而后正式启动建立过程

1
2
3
4
5
6
7
root@compute:~# ll /opt/stack/data/nova/instances/86f71e87-4ae2-48fb-9bcd-c72e3c28e093/
total 2052
drwxr-xr-x 2 stack libvirt    4096 Jun 16 13:12 ./
drwxr-xr-x 5 stack root       4096 Jun 16 13:12 ../
-rw------- 1 root  root      48807 Jun 16 15:23 console.log
-rw-r--r-- 1 root  root    2097152 Jun 16 15:23 disk
-rw-r--r-- 1 stack libvirt      86 Jun 16 13:12 disk.info
  1. 建立虚拟网络并启动 instance
    1. 建立虚拟网络:用的是 linux-bridge 实现的虚拟网络
    • cloudman:为 instance 建立虚拟网络设备
    • 我:没有找到Ensuring bridge
cloudman:

vif是virtual interface(虚拟网卡)的缩写
我:
1
2
3
4
5
6
7
8
9
Jun 16 13:12:57 compute nova-compute[5666]: 
DEBUG nova.network.base_api 
[None req-d9a23179-e16d-4016-9586-e68c3dfdf6a9 admin admin] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
Updating instance_info_cache with network_info: 
[{"profile": {}, ... "network": {"bridge": "brq4f28b3ec-cc", 
"subnets": [{"ips": [{"meta": {}, "version": 4, ... "address": "172.12.12.7"}], 
"version": 4, "meta": {"dhcp_server": "172.12.12.2"}, ... "cidr": "172.12.12.0/24", ...
 {{(pid=5666) update_instance_cache_with_nw_info /opt/stack/nova/nova/network/base_api.py:48
虽然没有Ensuring bridge,可是有nova.virt.libvirt.vif参考见07.计算Nova→3.经过场景学习nova→4.Start Instance。总之,上述过程表示网络相关
  1. 接下来能够启动 instance了,最后Instance spawned successfully表示实例成功孵化。
    1. OpenStack 图形界面和 KVM CLI 均可以查看到 instance 的运行状态。
      1.virsh list用于显示当前节点建立的实例,而不是像nova list似的显示全部节点建立的实例 2.因为是第一次建立实例,故Name是...1
1
2
3
Jun 16 13:13:01 compute nova-compute[5666]: 
INFO nova.compute.manager [-] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] VM Started (Lifecycle Event)
1
2
3
4
Jun 16 13:13:01 compute nova-compute[5666]: 
INFO nova.compute.manager 
[None req-9b9e116b-fa49-46b3-8c41-9bade624c334 None None] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] VM Paused (Lifecycle Event)
1
2
3
4
5
Jun 16 13:13:01 compute nova-compute[5666]: 
INFO nova.compute.manager 
[None req-9b9e116b-fa49-46b3-8c41-9bade624c334 None None] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] 
During sync_power_state the instance has a pending task (spawning). Skip.
同步电源状态
1
2
3
4
Jun 16 13:13:01 compute nova-compute[5666]: 
INFO nova.compute.manager 
[None req-9b9e116b-fa49-46b3-8c41-9bade624c334 None None] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] VM Resumed (Lifecycle Event)
resume [rɪ'zjum](V-ERG) (使)从新开始;(使)继续进行
1
2
3
Jun 16 13:13:01 compute nova-compute[5666]: 
INFO nova.virt.libvirt.driver [-] 
[instance: 86f71e87-4ae2-48fb-9bcd-c72e3c28e093] Instance spawned successfully.
spawn [spɔn]:孵化
相关文章
相关标签/搜索