一、概述
1、虚拟化
虚拟化演变过程:软件模拟、虚拟化层翻译,容器虚拟化
- 软件模拟:理论上可模拟任何硬件,性能低,典型产品QEMU、Bochs;
- 虚拟化层翻译:又分为
- 软件捕获翻译,即软件全虚拟化,(VMWare的软件全虚拟化方案)
- 改造虚拟机系统内核加虚拟化层翻译,即半虚拟化,(Xen改造虚拟机操作系统)
- 硬件支持的虚拟化层翻译,即硬件支持全虚拟化,基于硬件效率特别高,(Intel硬件方案,对CPU指令进行改造,及VR-x)
- 容器虚拟化:基于CGroups和Namespace技术将进程隔离,Docker。
2、KVM
KVM (Kernel-based Virtual Machine),Openstack的主流虚拟化引擎。
架构:KVM为内核的一个模块,用户空间通过QEMU模拟硬件提供给虚拟机使用,一台虚拟机对应一个Linux进程,通过对该进程管理实现对虚拟机的管理.
考虑到对进程管理非常麻烦,RedHat发布Libvirt完成对虚拟机的管理,具备API和命令行工具。诸如Openstack、CloudStack、OpenNebula大多数管理平台通过Libvirt实现对KVM虚拟机的管理。
3、QEMU与KVM
Qemu开源项目,实现软件模拟硬件,可以模拟X86、AMD64、MIPS R4000、ARM v6/v7、APARC sun3和PowerPC架构的硬件,可以在其他平台上运行Linux程序,可以存储和还原虚拟机的状态,可以虚拟网卡、多CPU、IDE设备、软驱、显卡、声卡和多种并/串口设备、US设备、PC喇叭、PS/2键鼠、USB键鼠、蓝牙设备。
Qemu还内建DHCP、DNS、SMB、TFTP服务器。
纯软件模拟,优点是可以在支持平台上模拟设备,缺点是效率低,运行慢,1.0时期有与KVM结合分支,后来版本合并到主版本,目前QEMU默认支持KVM,KVM虚拟机可以借助QEMU管理工具来管理,QEMU可以借助KVM来加速。
4、Libvirt与KVM
Libvirt为开源的虚拟化管理工具,组成包括:
- API的lib库:支持C/Python/Ruby等主流语言
- Libvirtd服务
- 命令行工具virsh
Libvirt设计目标是通过相同的方式管理不同的虚拟化引擎,比如KVM、Xen、HyperV、VMware ESX等,但目前实际场景KVM使用Libvirt最多,其他平台各有管理工具。
Libvirt可以实现对虚拟机的创建、启动、关闭、暂停、恢复、迁移、销毁及硬件设备的热添加等管理。
Libvirt还支持远程的宿主机的管理,在宿主机上启动libvirtd服务并做好配置,可以通过SSH、TCP或基于TCP的TLS进行虚拟机的配置。
5、KVM优势
- 开源:与底层Linux、中间层Libvirt、到云管理平台Openstack紧密结合
- 性能:同样硬件条件下,提供更好的虚拟机性能
- 免费:开源
- 技术支持:开源社区活跃
二、实践
利用virt-install命令创建一个虚拟机:
1 2 |
# qemu-img create -f qcow2 centos7.1.qcow2 15G # virt-install --virt-type kvm --name CentOS-7.1 --ram 2048 --disk centos7.1.qcow2,format=qcow2 --network network=default --graphics vnc,listen=0.0.0.0 --noautoconsole --os-type=linux --os-variant=rhel7 --cdrom=CentOS-7-x86_64-DVD-1511.iso |
导出虚拟机XML模版文件:
1 |
# virsh dumpxml CentOS-7.3 > centos7.1.xml |
该文件如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 |
<domain type='kvm' id='21'> <name>CentOS-7.3</name> <uuid>f25f6724-98b5-409a-89b1-de5dfc7ff76e</uuid> <memory unit='KiB'>2097152</memory> <currentMemory unit='KiB'>2097152</currentMemory> <vcpu placement='static'>1</vcpu> <resource> <partition>/machine</partition> </resource> <os> <type arch='x86_64' machine='pc-i440fx-rhel7.0.0'>hvm</type> <boot dev='cdrom'/> <boot dev='hd'/> </os> <features> <acpi/> <apic/> </features> <cpu mode='custom' match='exact'> <model fallback='allow'>Haswell-noTSX</model> </cpu> <clock offset='utc'> <timer name='rtc' tickpolicy='catchup'/> <timer name='pit' tickpolicy='delay'/> <timer name='hpet' present='no'/> </clock> <on_poweroff>destroy</on_poweroff> <on_reboot>destroy</on_reboot> <on_crash>destroy</on_crash> <pm> <suspend-to-mem enabled='no'/> <suspend-to-disk enabled='no'/> </pm> <devices> <emulator>/usr/libexec/qemu-kvm</emulator> <disk type='file' device='disk'> <driver name='qemu' type='qcow2'/> <source file='/root/image/centos7.1.qcow2'/> <backingStore/> <target dev='vda' bus='virtio'/> <alias name='virtio-disk0'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/> </disk> <disk type='file' device='cdrom'> <driver name='qemu' type='raw'/> <source file='/root/image/CentOS-7-x86_64-DVD-1511.iso'/> <backingStore/> <target dev='hda' bus='ide'/> <readonly/> <alias name='ide0-0-0'/> <address type='drive' controller='0' bus='0' target='0' unit='0'/> </disk> <controller type='usb' index='0' model='ich9-ehci1'> <alias name='usb'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x7'/> </controller> <controller type='usb' index='0' model='ich9-uhci1'> <alias name='usb'/> <master startport='0'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x0' multifunction='on'/> </controller> <controller type='usb' index='0' model='ich9-uhci2'> <alias name='usb'/> <master startport='2'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x1'/> </controller> <controller type='usb' index='0' model='ich9-uhci3'> <alias name='usb'/> <master startport='4'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x2'/> </controller> <controller type='pci' index='0' model='pci-root'> <alias name='pci.0'/> </controller> <controller type='ide' index='0'> <alias name='ide'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x1'/> </controller> <controller type='virtio-serial' index='0'> <alias name='virtio-serial0'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x0'/> </controller> <interface type='network'> <mac address='52:54:00:fa:dc:83'/> <source network='default' bridge='virbr0'/> <target dev='vnet0'/> <model type='virtio'/> <alias name='net0'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/> </interface> <serial type='pty'> <source path='/dev/pts/3'/> <target port='0'/> <alias name='serial0'/> </serial> <console type='pty' tty='/dev/pts/3'> <source path='/dev/pts/3'/> <target type='serial' port='0'/> <alias name='serial0'/> </console> <channel type='unix'> <source mode='bind' path='/var/lib/libvirt/qemu/channel/target/domain-CentOS-7.3/org.qemu.guest_agent.0'/> <target type='virtio' name='org.qemu.guest_agent.0' state='disconnected'/> <alias name='channel0'/> <address type='virtio-serial' controller='0' bus='0' port='1'/> </channel> <input type='tablet' bus='usb'> <alias name='input0'/> </input> <input type='mouse' bus='ps2'/> <input type='keyboard' bus='ps2'/> <graphics type='vnc' port='5900' autoport='yes' listen='0.0.0.0'> <listen type='address' address='0.0.0.0'/> </graphics> <video> <model type='cirrus' vram='16384' heads='1'/> <alias name='video0'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x02' function='0x0'/> </video> <memballoon model='virtio'> <alias name='balloon0'/> <address type='pci' domain='0x0000' bus='0x00' slot='0x07' function='0x0'/> </memballoon> </devices> </domain> |
可以查看该虚拟机的内存、磁盘、网卡、CDROM设备的配置信息。
三、参考文档
《深度实践KVM:核心技术、管理运维、性能优化与项目实施》 肖力等著
code
more code
~~~~