KVM自Linux 2.6.20版本后就直接整合到Linux内核,它依托CPU虚拟化指令集实现高性能的虚拟化支持。它与Linux内核高度整合,所以在性能、安全性、兼容性、稳定性上都有很好的表现。
在KVM环境中运行的每一个虚拟化操做系统都将表现为单个独立的系统进程。所以它能够很方便地与Linux系统中的安全模块进行整合(SELinux),能够灵活的实现硬件资源的管理和分配,KVM虚拟化的架构图以下:vim
话很少说,开始搭建KVM虚拟化平台:centos
一、安装:安全
[root@localhost media]# yum -y groupinstall "GNOME Desktop" #安装GNOME桌面环境 [root@localhost media]# yum -y install qemu-kvm #KVM模块 [root@localhost media]# yum -y install qemu-kvm-tools #KVM调试工具,可不安装 [root@localhost media]# yum -y install virt-install #构建虚拟机的命令行工具 [root@localhost media]# yum -y install qemu-img #qemu组件,建立磁盘、启动虚拟机等 [root@localhost media]# yum -y install bridge-utils #网络支持工具 [root@localhost media]# yum -y install libvirt #虚拟机管理工具 [root@localhost media]# yum -y install virt-manager #图形界面管理虚拟机 [root@localhost media]# yum -y install libguestfs-tools #用来管理虚拟机磁盘格式 [root@localhost ~]# ls -sf /lib/systemd/system/graphical.target /etc/systemd/system/default.target #将系统默认运行的target更改成graphical.target,若不执行该命令,重启时可能会报错。
二、安装完毕后,需重启系统,执行下面命令对系统进行检查:网络
[root@localhost ~]# cat /proc/cpuinfo | grep vmx #查看Intel的CPU是否支持虚拟化,如果AMD的CPU,需 “cat /proc/cpuinfo | grep smv” [root@localhost ~]# lsmod | grep kvm #检查KVM模块是否安装 kvm_intel 170181 0 kvm 554609 1 kvm_intel irqbypass 13503 1 kvm [root@localhost ~]# systemctl start libvirtd #启动libvirtd服务 [root@localhost ~]# systemctl enable libvirtd
三、设置KVM网络:架构
在libvirt中运行KVM网络有两种方法:NAT和Bridge,默认是NAT。
关于两种模式的说明以下:
(1)NAT模式:也是用户模式,数据包由NAT方式经过主机的接口进行传送,能够访问外网,可是没法从外部访问虚拟机网络,因此通常不会用到。
(2)Bridge:也就是桥接模式,这种模式容许虚拟机像一台独立的主机同样拥有网络,外部的机器能够直接访问到虚拟机内部,但须要网卡支持,通常有线网卡都支持。ide
我这里以Bridge(桥接模式)为例:工具
[root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33 TYPE=Ethernet BOOTPROTO=none #将这项改成none DEFROUTE=yes PEERDNS=yes PEERROUTES=yes IPV4_FAILURE_FATAL=no IPV6INIT=yes IPV6_AUTOCONF=yes IPV6_DEFROUTE=yes IPV6_PEERDNS=yes IPV6_PEERROUTES=yes IPV6_FAILURE_FATAL=no IPV6_ADDR_GEN_MODE=stable-privacy NAME=ens33 DEVICE=ens33 ONBOOT=yes BRIDGE=br0 #添加该行,如有UUID的配置项,建议删除。 #将网卡ens33的文件复制一份更名为br0 [root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-br0 TYPE=Bridge #将type改成Bridge BOOTPROTO=static #这里根据实际状况改成static或dhcp DEFROUTE=yes PEERDNS=yes PEERROUTES=yes IPV4_FAILURE_FATAL=no IPV6INIT=yes IPV6_AUTOCONF=yes IPV6_DEFROUTE=yes IPV6_PEERDNS=yes IPV6_PEERROUTES=yes IPV6_FAILURE_FATAL=no IPV6_ADDR_GEN_MODE=stable-privacy NAME=br0 #更名字 DEVICE=br0 #更名字 ONBOOT=yes IPADDR=192.168.1.1 #该ip将为宿主机的IP地址 GATEWAY=192.168.1.254 [root@localhost ~]# systemctl restart network #重启网络服务 [root@localhost ~]# ifconfig #确认IP地址信息 br0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 192.168.1.1 netmask 255.255.255.0 broadcast 192.168.1.255 inet6 fe80::db0f:ab79:54a1:241b prefixlen 64 scopeid 0x20<link> ether 00:0c:29:1a:e0:46 txqueuelen 1000 (Ethernet) RX packets 50 bytes 4155 (4.0 KiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 58 bytes 7046 (6.8 KiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 ether 00:0c:29:1a:e0:46 txqueuelen 1000 (Ethernet) RX packets 1062 bytes 95264 (93.0 KiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 688 bytes 81579 (79.6 KiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
四、管理KVM:性能
[root@localhost /]# virt-manager #打开图形管理软件,执行该命令后出现如下界面
建立存储池:ui
再以一样的操做建立一个iso镜像存储池,完成后以下:centos7
建立存储卷:
完成后,以下点击来建立虚拟机:[root@localhost ~]# cp /dev/cdrom /kvm/iso/centos7.iso #先复制光盘镜像到指定目录下
根据需求给硬件资源:
建立自定义存储:
定义虚拟机名称,并单击“完成”:
单击“完成”后,会自动弹出该虚拟机的窗口,安装系统吧,这里和平时安装系统同样,就省略了:
KVM虚拟化平台至此已部署完成,下面附加一些经常使用的管理命令:
[root@localhost ~]# virsh -h #查看命令帮助 [root@localhost ~]# ls /etc/libvirt/qemu #查看KVM的配置文件存放目录 (test01.xml是虚拟机系统实例的配置文件) networks test01.xml [root@localhost ~]# virsh list --all #查看虚拟机状态 Id 名称 状态 ---------------------------------------------------- 2 test01 running [root@localhost ~]# virsh shutdown test01 #关闭虚拟机 [root@localhost ~]# virsh start test01 #开启虚拟机 [root@localhost ~]# virsh destroy test01 #强制关机 [root@localhost ~]# virsh create /etc/libvirt/qemu/test01.xml #经过配置文件启动虚拟机 [root@localhost ~]# virsh suspend test01 #挂起虚拟机 [root@localhost ~]# virsh resume test01 #从挂起状态恢复运行虚拟机 [root@localhost ~]# virsh autostart test01 #设置虚拟机伴随宿主机自动启动 #虚拟机的删除与添加: [root@localhost ~]# virsh dumpxml test01 > /etc/libvirt/qemu/test02.xml #导出虚拟机配置 #删除虚拟机: [root@localhost ~]# virsh shutdown test01 [root@localhost ~]# virsh undefine test01 [root@localhost ~]# virsh list --all #查看虚拟机是否被删除 Id 名称 状态 ---------------------------------------------------- #经过备份的配置文件从新定义虚拟机: [root@localhost ~]# cd /etc/libvirt/qemu/ [root@localhost qemu]# mv test02.xml test01.xml [root@localhost qemu]# virsh define test01.xml #修改虚拟机配置(内存大小等)信息: [root@localhost qemu]# vim /etc/libvirt/qemu/test01.xml [root@localhost qemu]# virt-df -h test01 #在宿主机上查看虚拟机磁盘信息
克隆虚拟机:
[root@localhost qemu]# virt-clone -o test01 -n test02 -f /kvm/store/test02.qcow2 #将test01克隆为test02 [root@localhost qemu]# virsh list --all #查看现有虚拟机 Id 名称 状态 ---------------------------------------------------- - test01 关闭 - test02 关闭
虚拟机建立快照:
KVM虚拟机要使用快照功能,磁盘格式必须为qcow2
[root@localhost qemu]# virsh snapshot-create test01 #对虚拟机test01建立快照 [root@localhost qemu]# virsh snapshot-list test01 #查看快照信息 名称 生成时间 状态 ------------------------------------------------------------ 1560191837 2019-06-11 02:37:17 +0800 shutoff [root@localhost qemu]# virsh snapshot-revert test01 1560191837 #恢复虚拟机状态至1560191837 [root@localhost qemu]# virsh snapshot-delete test01 1560191837 #删除快照