KVM特点


KVM必须在具备Intel VT或AMD-V功能的x86平台上运行。KVM包含一个为处理器提供底层虚拟化,可加载的核心模块kvm.ko(kvm-intel.ko或kvm-AMD.ko)。使用一个经过修改的QEMU(qemu-kvm),作为虚拟机上层控制和界面。


由于KVM仅是一个简单的虚拟化模块,所以它的内存管理没有自我实现,需借助于Linux内核实现内存管理。KVM能够使用Linux所支持的任何存储,在驱动程序的实现上,直接借助于Linux内核来驱动任何硬件。在性能上KVM继承了Linux很好的性能和伸缩性,在虚拟化性能方面,已经达到非虚拟化原生环境95%左右的性能(官方数据)。KVM拓展性也非常好,客户机和宿主机都可以支持非常多的CPU数量和非常大的内存,可以过载使用CPU和内存,还可借助KSM技术实现对内存的过量使用,且保证性能依旧非常不错。


KVM架构


检测是否支持虚拟化

[root@lab01 ~]# egrep --color "(vmx|svm)" /proc/cpuinfo
#如果含有vmx或者svm字样,则表示硬件支持虚拟化,vmx代表Intel,svm代表AMD

安装网桥工具,创建桥接网卡

[root@lab01 ~]# yum -y install bridge-utils
[root@lab01 ~]# brctl addbr br0
[root@lab01 ~]# cd /etc/sysconfig/network-scripts
[root@lab01 network-scripts]# cp ifcfg-eth0 ifcfg-br0
[root@lab01 network-scripts]# vim ifcfg-br0

DEVICE=br0
TYPE=Bridge
ONBOOT=yes
BOOTPROTO=none
IPADDR=192.168.1.11
NETMASK=255.255.255.0
DNS2=202.106.196.115
GATEWAY=192.168.1.1
DNS1=202.106.0.20
IPV6INIT=no
USERCTL=no

[root@lab01 network-scripts]# vim ifcfg-eth0 

DEVICE=eth0
TYPE=Ethernet
ONBOOT=yes
BOOTPROTO=none
BRIDGE=br0
IPV6INIT=no
USERCTL=no

[root@lab01 network-scripts]# service network restart
Shutting down interface eth0:  device eth0 is not a slave of br0
                                                           [  OK  ]
Shutting down loopback interface:                          [  OK  ]
Bringing up loopback interface:                            [  OK  ]
Bringing up interface eth0:                                [  OK  ]
Bringing up interface br0:  Determining if ip address 192.168.1.11 is already in use for device br0...
                                                           [  OK  ]

加载KVM模块

[root@lab01 ~]# modprobe kvm
[root@lab01 ~]# modprobe kvm-intel
[root@lab01 ~]# lsmod | grep kvm
kvm_intel              55624  0 
kvm                   341551  1 kvm_intel

安装QEMU-KVM管理软件

[root@lab01 ~]# yum -y install qemu-kvm qemu-kvm-tools
[root@lab01 ~]# ln -sv /usr/libexec/qemu-kvm /usr/bin
`/usr/bin/qemu-kvm' -> `/usr/libexec/qemu-kvm'

qemu-kvm标准选项

-name name:设定虚拟机名称;
-M machine:指定要模拟的主机类型,如Standard PC、ISA-only PC或Intel-Mac等
-m megs:设定虚拟机的RAM大小;
-cpu model:设定CPU模型,如coreduo、qemu64等
-smp n[,cores=cores][,threads=threads][,sockets=sockets][,maxcpus=maxcpus]:设定模拟的SMP架构中CPU
的个数等、每个CPU的核心数及CPU的socket数目等;PC机上最多可以模拟255颗CPU;maxcpus用于指定热插入的CP
U个数上限;
-numa opts:指定模拟多节点的numa设备;
-fda file:
-fdb file:使用指定文件(file)作为软盘镜像,file为/dev/fd0表示使用物理软驱;
-hda file
-hdb file
-hdc file
-hdd file:使用指定file作为硬盘镜像;
-cdrom file:使用指定file作为CD-ROM镜像,需要注意的是-cdrom和-hdc不能同时使用;将file指定为/dev/cdr
om可以直接使用物理光驱;
-drive option[,option[,option[,...]]]:定义一个硬盘设备;可用子选项有很多。
    file=/path/to/somefile:硬件映像文件路径;
    if=interface:指定硬盘设备所连接的接口类型,即控制器类型,如ide、scsi、sd、mtd、floppy、pflash
    及virtio等;
    index=index:设定同一种控制器类型中不同设备的索引号,即标识号;
    media=media:定义介质类型为硬盘(disk)还是光盘(cdrom);
    snapshot=snapshot:指定当前硬盘设备是否支持快照功能:on或off;
    cache=cache:定义如何使用物理机缓存来访问块数据,其可用值有none、writeback、unsafe和writethrough四个;
    format=format:指定映像文件的格式,具体格式可参见qemu-img命令;
-boot [order=drives][,once=drives][,menu=on|off]:定义启动设备的引导次序,每种设备使用一个字符表示
;不同的架构所支持的设备及其表示字符不尽相同,在x86 PC架构上,a、b表示软驱、c表示第一块硬盘,d表示
第一个光驱设备,n-p表示网络适配器;默认为硬盘设备;
-boot order=dc,once=d

qemu-kvm显示选项

-nographic:默认情况下,qemu使用SDL来显示VGA输出;而此选项用于禁止图形接口,此时,qemu类似一个简单的
命令行程序,其仿真串口设备将被重定向到控制台;
-curses:禁止图形接口,并使用curses/ncurses作为交互接口;
-alt-grab:使用Ctrl+Alt+Shift组合键释放鼠标;
-ctrl-grab:使用右Ctrl键释放鼠标;
-sdl:启用SDL;
-spice option[,option[,...]]:启用spice远程桌面协议;其有许多子选项,具体请参照qemu-kvm的手册;
-vga type:指定要仿真的VGA接口类型,常见类型有:
cirrus:Cirrus Logic GD5446显示卡;
std:带有Bochs VBI扩展的标准VGA显示卡;
vmware:VMWare SVGA-II兼容的显示适配器;
qxl:QXL半虚拟化显示卡;与VGA兼容;在Guest中安装qxl驱动后能以很好的方式工作,在使用spice协议时推荐
使用此类型;
none:禁用VGA卡;
-vnc display[,option[,option[,...]]]:默认情况下,qemu使用SDL显示VGA输出;使用-vnc选项,可以让qemu
监听在VNC上,并将VGA输出重定向至VNC会话;使用此选项时,必须使用-k选项指定键盘布局类型;其有许多子选
项,具体请参照qemu-kvm的手册;

	display:
		(1)host:N
			172.16.100.7:1, 监听于172.16.100.7主的5900+N的端口上
		(2) unix:/path/to/socket_file
		(3) none

	options:
		password: 连接时需要验正密码;设定密码通过monitor接口使用change
		reverse: “反向”连接至某处于监听状态的vncview上;

	-monitor stdio:表示在标准输入输出上显示monitor界面
	-nographic
		Ctrl-a, c: 在console和monitor之间切换
		Ctrl-a, h: 显示帮助信息

qemu-kvm网络属性相关选项

-net nic[,vlan=n][,macaddr=mac][,model=type][,name=name][,addr=addr][,vectors=v]:创建一个新的网卡
设备并连接至vlan n中;macaddr用于为其指定MAC地址,name用于指定一个在监控时显示的网上设备名称;emu可
以模拟多个类型的网卡设备
-net tap[,vlan=n][,name=name][,fd=h][,ifname=name][,script=file][,downscript=dfile]:通过物理机的TA
P网络接口连接至vlan n中,使用script=file指定的脚本(默认为/etc/qemu-ifup)来配置当前网络接口,并使用d
ownscript=file指定的脚本(默认为/etc/qemu-ifdown)来撤消接口配置;使用script=no和downscript=no可分别
用来禁止执行脚本;
-net user[,option][,option][,...]:在用户模式配置网络栈,其不依赖于管理权限;有效选项有:
  vlan=n:连接至vlan n,默认n=0;
  name=name:指定接口的显示名称,常用于监控模式中;
  net=addr[/mask]:设定GuestOS可见的IP网络,掩码可选,默认为10.0.2.0/8;
  host=addr:指定GuestOS中看到的物理机的IP地址,默认为指定网络中的第二个,即x.x.x.2;
  dhcpstart=addr:指定DHCP服务地址池中16个地址的起始IP,默认为第16个至第31个,即x.x.x.16-x.x.x.31;
  dns=addr:指定GuestOS可见的dns服务器地址;默认为GuestOS网络中的第三个地址,即x.x.x.3;
  tftp=dir:激活内置的tftp服务器,并使用指定的dir作为tftp服务器的默认根目录;
  bootfile=file:BOOTP文件名称,用于实现网络引导GuestOS;如:qemu -hda linux.img -boot n -net user
tftp=/tftpserver/pub,bootfile=/pxelinux.0



tap: 二层虚拟通道 
tun:三层虚拟通道

qemu-kvm的其它的用到的参数:

动态迁移时用到的选项:-incoming tcp:0:PORT
让qemu-kvm进程运行于后台:-daemonize
开启USB总线:-usb 
	GuestOS为Windows时,-usb -usbdevice tablet  用于实现鼠标定位
打开KVM的支持:qemu-kvm默认就启用了此选项
	-enable-kvm
打声音设备:-soundhw

设定iscsi存储设备:
	-iscsi [user=USERNAME][,password=PASSWORD][,initiator-name=iqn]
	通过URL指定使用的iscsi设备
	iscsi://[:port]//

	# qemu-kvm  -iscsi initiator-name=    -drive file=iscsi://tgt.magedu.com/iqn.2014-05.com.magedu.tgt1/1

指定使用的bios文件:
	-bios /path/to/some_bios_program

使用外部内核及ramdisk文件:
	-kernel
	-initrd
	-append: 向内核传递的参数列表

使用qemu-img管理磁盘映像

qemu-img是qemu用来实现磁盘映像管理的工具组件,其有许多子命令,分别用于实现不同的管理功能,而每一个子

命令也都有一系列不同的选项。其使用语法格式为“qemu-img  subcommand  [options]”,支持的子命令如下。

create:创建一个新的磁盘映像文件;
check:检查磁盘映像文件中的错误;
convert:转换磁盘映像的格式;
info:显示指定磁盘映像的信息;
snapshot:管理磁盘映像的快照;
commit:提交磁盘映像的所有改变;
rbase:基于某磁盘映像创建新的映像文件;
resize:增大或缩减磁盘映像文件的大小;

使用create子命令创建磁盘映像的命令格式为“create [-f fmt] [-o options] filename [size]”,例如下面
的命令创建了一个格式为qcow2的50G的磁盘映像文件。
[root@lab01 ~]# qemu-img create -f qcow2 /kvm/p_w_picpaths/centos/hz***.img -o size=50G,preallocation="me
tadata"
Formatting '/kvm/p_w_picpaths/centos/hz***.img', fmt=qcow2 size=53687091200 encryption=off cluster_size=6
5536 preallocation='metadata' 
[root@lab01 ~]# ll -h /kvm/p_w_picpaths/centos/hz***.img 
-rw-r--r--. 1 root root 51G Dec 19 16:33 /kvm/p_w_picpaths/centos/hz***.img
#-f:指定虚拟磁盘文件格式 -o:指定选项


如果我们加入网卡设备,则需要使用系统启动后自动桥接网络到br0上,可以通过脚本实现和停止系统时桥接网络和删除桥接的自动执行操作

[root@lab01 ~]# mkdir /kvm/script
[root@lab01 ~]# vim /kvm/script/qemu-ifup
 
#!/bin/bash
 
switch=br0
   
if [ -n "$1" ]; then
    ip link set $1 up
    sleep 1
    brctl addif $switch $1
    exit 0
else
    echo "Error: No Interface."
    exit 1
fi
 
 
[root@lab01 ~]# vim /kvm/script/qemu-ifdown
 
 #!/bin/bash
 
switch=br0
   
if [ -n "$1" ];then
    brctl delif $switch $1
    ip link set $1 down
    exit 0
else
    echo "Error: No Interface."
    exit 1
fi
 
[root@lab01 ~]# chmod -R +x /kvm/script/

安装虚拟机

[root@lab01 ~]# yum -y install tigervnc tigervnc-server
[root@lab01 ~]# qemu-kvm -name "hz***" -m 1024 -smp 2 -drive file=/kvm/p_w_picpaths/centos/hz***.img,medi
a=disk,format=qcow2,if=virtio,index=0 -net nic,model=virtio -net tap,ifname=vnet0,script=/kvm/scrip
t/qemu-ifup -usb -usbdevice tablet -drive file=/kvm/CentOS-6.7-x86_64-bin-DVD1.iso,media=cdrom -boo
t order=dc,once=d -vnc :1
sleep: missing operand
Try `sleep --help' for more information.
####其中 -usb -usbdevice tablet:用于鼠标定位,-vnc :1表示监控0.0.0.0:5901端口上

现在可以安装系统了,看看脚本有没有生效

[root@lab01 kvm]# ifconfig vnet0
vnet0     Link encap:Ethernet  HWaddr 2A:7A:60:E7:54:C1  
          inet6 addr: fe80::287a:60ff:fee7:54c1/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:500 
          RX bytes:0 (0.0 b)  TX bytes:0 (0.0 b)

脚本已经生效,剩下安装过程,可以自己测试。

安装完毕效果


基于Libvirt实现虚拟机管理


因为对进程管理非常麻烦,Redhat发布了一个开源项目libvirt,libvirt有API,也有一套命令行工具,可以完成对虚拟机的管理,大多数的管理平台都是通过libvirt来完成对KVM虚拟机管理的,下面我们来介绍一下基于libvirt实现虚拟机的管理


安装所需组件

[root@lab01 ~]# yum -y install libvirt virt-manager virt-viewer python-virtinst
##如果不确定有哪些包需要使用,可以直接安装包组,先找出来
[root@lab01 ~]# yum grouplist | grep Virtualization
   Virtualization
   Virtualization Client
   Virtualization Platform
   Virtualization Tools
[root@lab01 ~]# yum -y groupinstall "Virtualization,Virtualization Client,Virtualization Platform,V
irtualization Tools"

启动服务

[root@lab01 ~]# service libvirtd start
Starting libvirtd daemon:                                  [  OK  ]

#使用libvirt创建网桥无需再手动修改配置文件,一条命令即可解决
# virsh iface-bridge eth0 br0

使用virt-install创建虚拟机并安装GuestOS

virt-install是一个命令行工具,它能够为KVM,Xen或其它支持Libvirt API的hypervisor创建虚拟机并完成GuestOS安装,此外,它能够基于串行控制台、VNC或SDL支持文本或图形安装界面。安装过程可以使用本地的安装介质如CDROM,也可以通过网络方式如NFS.HTTP或FTP服务实现,对于通过网络安装的方式,virt-install可以自动加载必要的文件以启动安装过程而无需额外提供引导工具。当然,virt-install也支持PXE方式的安装过程,也能够直接使用现有的磁盘映像直接启动安装过程。


virt-install命令有很多选项,这些选项大体可以分为下面几大类,同时对每类中的常用选项也做出简单说明。

#一般选项:指定虚拟机的名称、内存大小、VCPU个数及特性等
-n NAME, --name=NAME:虚拟机名称,需全局惟一;
-r MEMORY, --ram=MEMORY:虚拟机内在大小,单位为MB;
--vcpus=VCPUS[,maxvcpus=MAX][,sockets=#][,cores=#][,threads=#]:VCPU个数及相关配置;
--cpu=CPU:CPU模式及特性,如coreduo等;可以使用qemu-kvm -cpu ?来获取支持的CPU模式;
安装方法:指定安装方法、GuestOS类型等;
-c CDROM, --cdrom=CDROM:光盘安装介质;
-l LOCATION, --location=LOCATION:安装源URL,支持FTP、HTTP及NFS等,如ftp://172.16.0.1/pub;
--pxe:基于PXE完成安装;
--livecd: 把光盘当作LiveCD;
--os-type=DISTRO_TYPE:操作系统类型,如linux、unix或windows等;
--os-variant=DISTRO_VARIANT:某类型操作系统的变体,如rhel5、fedora8等;
-x EXTRA, --extra-args=EXTRA:根据--location指定的方式安装GuestOS时,用于传递给内核的额外
选项,例如指定kickstart文件的位置,--extra-args "ks=http://172.16.0.1/class.cfg"
--boot=BOOTOPTS:指定安装过程完成后的配置选项,如指定引导设备次序、使用指定的而非安装的ke
rnel/initrd来引导系统启动等 ;例如:
--boot  cdrom,hd,network:指定引导次序;
--boot kernel=KERNEL,initrd=INITRD,kernel_args=”console=/dev/ttyS0”:指定启动系统的内核及initrd文件;
#存储配置:指定存储类型、位置及属性等;
--disk=DISKOPTS:指定存储设备及其属性;格式为--disk /some/storage/path,opt1=val1,opt2=val2等;
常用的选项有:
    device:设备类型,如cdrom、disk或floppy等,默认为disk;
    bus:磁盘总结类型,其值可以为ide、scsi、usb、virtio或xen;
    perms:访问权限,如rw、ro或sh(共享的可读写),默认为rw;
    size:新建磁盘映像的大小,单位为GB;
    cache:缓存模型,其值有none、writethrouth(缓存读)及writeback(缓存读写);
    format:磁盘映像格式,如raw、qcow2、vmdk等;
    sparse:磁盘映像使用稀疏格式,即不立即分配指定大小的空间;
    --nodisks:不使用本地磁盘,在LiveCD模式中常用;
#网络配置:指定网络接口的网络类型及接口属性如MAC地址、驱动模式等;
-w NETWORK, --network=NETWORK,opt1=val1,opt2=val2:将虚拟机连入宿主机的网络中,其中NETWORK可以为:
    bridge=BRIDGE:连接至名为“BRIDEG”的桥设备;
    network=NAME:连接至名为“NAME”的网络;
其它常用的选项还有:
    model:GuestOS中看到的网络设备型号,如e1000、rtl8139或virtio等;
    mac:固定的MAC地址;省略此选项时将使用随机地址
--nonetworks:虚拟机不使用网络功能;
#图形配置:定义虚拟机显示功能相关的配置,如VNC相关配置;
--graphics TYPE,opt1=val1,opt2=val2;指定图形显示相关的配置,此选项不会配置任何显示硬件(如显卡),
而是仅指定虚拟机启动后对其进行访问的接口;
TYPE:指定显示类型,可以为vnc、sd1、spice或none等,默认为vnc;
port:TYPE为vnc或spice时其监听的端口;
listen:TYPE为vnc或spice时所监听的IP地址,默认为127.0.0.1,可以通过修改/etc/libvirt/qemu.conf定义新的默认值;
password:TYPE为vnc或spice时,为远程访问监听的服务进指定认证密码;
--noautoconsole:禁止自动连接至虚拟机的控制台;
设备选项:指定文本控制台、声音设备、串行接口、并行接口、显示接口等;
--serial=CHAROPTS:附加一个串行设备至当前虚拟机,根据设备类型的不同,可以使用不同的选项,
格式为“--serial type,opt1=val1,opt2=val2,...”
--serial pty:创建伪终端;
--serial dev,path=HOSTPATH:附加主机设备至此虚拟机;
--video=VIDEO:指定显卡设备模型,可用取值为cirrus、vga、qxl或vmvga;
#虚拟化平台:虚拟化模型(hvm或paravirt)、模拟的CPU平台类型、模拟的主机类型、hypervisor类型(如kvm
、xen或qemu等)以及当前虚拟机的UUID等;
-v, --hvm:当物理机同时支持完全虚拟化和半虚拟化时,指定使用完全虚拟化;
-p, --paravirt:指定使用半虚拟化;
--virt-type:使用的hypervisor,如kvm、qemu、xen等;所有可用值可以使用’virsh capabilities’命令获取;
#其它:
--autostart:指定虚拟机是否在物理启动后自动启动;
--print-xml:如果虚拟机不需要安装过程(--import、--boot),则显示生成的XML而不是创建此虚拟
机;默认情况下,此选项仍会创建磁盘映像;
--force:禁止命令进入交互式模式,如果有需要回答yes或no选项,则自动回答为yes;
--dry-run:执行创建虚拟机的整个过程,但不真正创建虚拟机、改变主机上的设备配置信息及将其创
建的需求通知给libvirt;
-d, --debug:显示debug信息;

尽管virt-install命令有着类似上述的众多选项,但实际使用中,其必须提供的选项仅包括--name、--ram、--disk(也可是--nodisks)及安装过程相关的选项。此外,有时还需要使用括--connect=CONNCT选项来指定连接至一个非默认的hypervisor。


下面这个示例创建一个名为rhel5的虚拟机,其hypervisor为KVM,内存大小为512MB,磁盘为8G的映像文件/var/lib/libvirt/p_w_picpaths/rhel5.8.img,通过boot.iso光盘镜像来引导启动安装过程。

# virt-install \
   --connect qemu:///system \
   --virt-type kvm \
   --name rhel5 \
   --ram 512 \
   --disk path=/var/lib/libvirt/p_w_picpaths/rhel5.img,size=8 \
   --graphics vnc \
   --cdrom /tmp/boot.iso \
   --os-variant rhel5

下面的示例将创建一个名为rhel6的虚拟机,其有两个虚拟CPU,安装方法为FTP,并指定了ks文件的位置,磁盘映像

文件为稀疏格式,连接至物理主机上的名为brnet0的桥接网络:

# virt-install \
    --connect qemu:///system \
    --virt-type kvm \
    --name rhel6 \
    --ram 1024 \
    --vcpus 2 \
    --network bridge=brnet0 \
    --disk path=/VMs/p_w_picpaths/rhel6.img,size=120,sparse \
    --location ftp://172.16.0.1/rhel6/dvd \
    --extra_args “ks=http://172.16.0.1/rhel6.cfg” \
    --os-variant rhel6 \
    --force

下面的示例将创建一个名为rhel5.8的虚拟机,磁盘映像文件为稀疏模式的格式为qcow2且总线类型为virtio,安装

过程不启动图形界面(--nographics),但会启动一个串行终端将安装过程以字符形式显示在当前文本模式下,虚拟机显卡类型为cirrus:

# virt-install \
--connect qemu:///system \
--virt-type kvm \ 
--name rhel5.8 \ 
--vcpus 2,maxvcpus=4 \
--ram 512 \ 
--disk path=/VMs/p_w_picpaths/rhel5.8.img,size=120,format=qcow2,bus=virtio,sparse \ 
--network bridge=brnet0,model=virtio
--nographics \
--location ftp://172.16.0.1/pub \ 
--extra-args "ks=http://172.16.0.1/class.cfg  console=ttyS0  serial" \
--os-variant rhel5 \
--force  \
--video=cirrus

下面的示例则利用已经存在的磁盘映像文件(已经有安装好的系统)创建一个名为rhel5.8的虚拟机:

# virt-install \
    --name rhel5.8
    --ram 512
    --disk /VMs/rhel5.8.img
    --import

每个虚拟机创建后,其配置信息保存在/etc/libvirt/qemu目录中,文件名与虚拟机相同,格式为XML。



下面我在创建一个自定义的:

[root@lab01 ~]# virt-install --cpu=host -n hzcf*** --vcpus=2 -r 1024 \
   -c /kvm/CentOS-6.7-x86_64-bin-DVD1.iso \
   --disk path=/kvm/p_w_picpaths/centos/hz***.qcow2,bus=virtio,size=50,format=qcow2,sparse \
   --network bridge=br0,model=virtio --force 
   --graphics vnc,listen=0.0.0.0,port=5902



下面总结一下virsh的几个常用命令:

virt-install:创建虚拟机,并安装OS;也可创建虚拟机并导入Image文件:
根据xml文件创建:
    create:创建并启动
    define:创建但不启动
关闭domain:
    destroy
    shutdown
    reboot
删除domain:
    undefine
连接至console:
    console
列出:
    list
附加或拆除disk:
    attach-disk
    detach-disk
保存状态至磁盘文件或从磁盘文件恢复:
    save
    restore
暂停于内存或继续运行:
    suspend
    resume

具体用法示例:

#开关机
virsh start centos6.7 #开机
virsh create /etc/libvirt/qemu/centos6.7.xml #直接通过主机配置文档启动主机
virsh shutdown centos6.7 #关机
virsh destroy centos6.7 #强制关闭电源
virsh list --all #查看虚拟机状态
#添加删除虚拟机
virsh define /etc/libvirt/qemu/centos6.7.xml #根据主机配置文档添加虚拟机
virsh undefine centos6.7 #移除虚拟机centos6.7
virsh list --all #查看添加的虚拟机
#使用已存在的虚拟机配置文档安裝新的虚拟机
qemu-img create -f qcow2 -o size=50G /kvm/p_w_picpaths/lab01.img #为新建虚拟机生产磁盘镜像文件
virsh list --all
virsh dumpxml hz***.xml >/etc/libvirt/qemu/centos6.7.xml#导出虚拟机centos6.7的硬件配置信息为/etc/libvirt/qemu/centos6.7.xml
[root@lab01 ~]# vim /etc/libvirt/qemu/centos6.7.xml
id='20'> #修改node6的id号
centos6.7 #虚拟机centos6.7的name
4b7e91eb-6521-c2c6-cc64-c1ba72707fc7 #uuid必须修改,否则会和hz***的冲突
#指定新虚拟机的硬盘文件

virsh define /etc/libvirt/qemu/centos6.7.xml #使用虚拟描述文档建立虚拟机,
#可用virsh edit centos6.7修改centos6.7的配置文件
virsh start centos6.7#启动虚拟机

#为虚拟机开启vnc
virsh edit hz*** #编辑hz***的配置文件;不建议直接通过vim hz***.xml修改。

#port='-1' :port自动分配,监听回环网络(virt-manager管理需要listen='127.0.0.1'),无密码
改为

#固定vnc管理端口5904,不自动分配,vnc密码redhat,监听所有网络

存储池和存储卷的管理

1.创建 KVM主机存储池
1).创建基于文件夹(目录)的存储池
virsh pool-define-as vmware_pool --type dir --target /virhost/vmware#定义存储池vmware_pool或
virsh pool-create-as --name vmware_pool --type dir --target /virhost/vmware
#创建存储池vmware_pool,类型为文件目录,/virhost/vmware,与pool-define-as结果一样

2).创建基于文件系统的存储池
virsh pool-define-as --name vmware_pool --type fs --source-dev /dev/vg_target/LogVol02 
--source-format ext4 --target /virhost/vmware     或
virsh pool-create-as --name vmware_pool --type fs --source-dev /dev/vg_target/LogVol02 
--source-format ext4 --target /virhost/vmware

3).查看存储池信息
virsh pool-info vmware_pool #查看存储域(池)

4).启动存储池
virsh pool-start vmware_pool #启动存储池
virsh pool-list

5)销毁存储域,取消存储池
virsh pool-destroy vmware_pool #销毁存储池
virsh pool-list --all
virsh pool-undefine vmware_pool #取消存储池的定义
virsh pool-list --all

2.创建了存储池后,就可以创建一个卷,这个卷是用来做虚拟机的硬盘
virsh vol-create-as --pool vmware_pool --name node6.img --capacity 10G --allocation 1G --format qcow2
#创建卷 node6.img,所在存储池为vmware_pool,容量10G,初始分配1G,文件格式类型qcow2
virsh vol-info /virhost/vmware/node6.img #查看卷信息名称: node6.img类型: 文件容量: 10.00 GB分配: 136.00 KB

3.在存储卷上安装虚拟主机
#virt-install --connect qemu:///system \
    -n node7 \
    -r 512 \
    -f /virhost/vmware/node7.img \
    --vnc \
    --os-type=linux \
    --os-variant=rhel6 \
    --vcpus=1 \
    --network bridge=br0 \
    -c /mnt/rhel-server-6.0-x86_64-dvd.iso

复制虚拟机,不用修改其中配置文件,也不用创建磁盘文件

#virt-clone -o vm001 -n vm002 -f /var/lib/libvirt/vm002.img
#说明:以vm001做为源,克隆vm001虚拟机,并创建名称为vm002虚拟机,使用磁盘文件/var/lib/libvirt/vm002.img

直接根据磁盘文件创建一个新的虚拟机

virt-install -n "nginx01" --vcpus=4 -r 8096 --boot hd --disk path=/kvm/p_w_picpaths/nginx01.img,bus=virti
o,size=200,format=qcow2,sparse --network bridge=br0,model=virtio --force --graphics vnc,listen=0.0.
0.0,port=5901