[toc]
一、安装KVM
grep -E 'vmx|svm' /proc/cpuinfo #查看CPU是否支持KVM,只有支持才能做
lsmod | grep kvm #查看CPU是否支持KVM,只有支持才能做
yum install qemu-kvm qemu-kvm-tools virt-manager libvirt virt-install -y
安装完毕通过下面命令都可以看到多出一个新的网络设备virbr0
brctl show
ifconfig
设置libvirtd服务开机启动,libvirt对虚拟机不产生任何影响,只是用来管理的
systemctl enable libvirtd.service
systemctl start libvirtd.service
systemctl status libvirtd.service
qemu-img工具创建磁盘
qemu-img create -f raw /opt/Centos-7.2-x86_64.raw 10G
创建虚拟机
需要提前准备ISO镜像
virt-install --virt-type kvm --name Centos-7.2-x86_64 --ram 1024 --cdrom=/tmp/CentOS-7-x86_64-DVD-1511.iso --disk /opt/Centos-7.2-x86_64.raw --network network=default --graphics vnc,listen=0.0.0.0 --noautoconsole
紧接着用vncviewer工具,连接过去,然后安装虚拟机,注意关闭宿主机的防火墙和selinux
virsh vncdisplay Centos-7.2-x86_64
iptables -F
connect:宿主机:5900
选中Install CentOS7 ,按tab键,输入net.ifnames=0 biosdevname=0
分区那里不用设置swap分区。本身就是虚拟机了,再设置swap分区,效果很差.
最后一步要注意,点击reboot,它其实是关机。需要手动使用virsh命令启动
virsh常用命令
virsh --help
virsh list
virsh list --all
virsh shudown Centos-7.2-x86_64(主机名)
virsh destroy Centos-7.2-x86_64(主机名) 类似kill -9 进程号
virsh start Centos-7.2-x86_64
virsh undefine Centos-7.2-x86_64 #会删除/etc/libvirt/qemu的xml文件,可以通过dumpxml的xml恢复,前提是磁盘文件没有问题
virsh edit Centos-7.2-x86_64
virsh suspended Centos-7.2-x86_64
virsh resume Centos-7.2-x86_64
virsh dumpxml Centos-7.2-x86_64 > Centos-7.2-x86_64.backup
virsh define Centos-7.2-x86_64.backup
virsh autostart Centos-7.2-x86_64
ps -aux |grep kvm
KVM虚拟机配置文件说明
cat /etc/libvirt/qemu/Centos-7.2-x86_64.xml
vnc的端口是-1 表示监听再5900端口上
这里是最大内存和当前内存,以及cpu数量
4096000
1048576
4
下面是硬盘路径和格式
hvm表示硬件虚拟化
hvm
二、快照
快照配置文件在/var/lib/libvirt/qemu/snapshot/虚拟机名称/下
ls /var/lib/libvirt/qemu/snapshot/Centos-7.2-x86_64/
快照命令
virsh --help | grep snapshot
snapshot-create Create a snapshot from XML
snapshot-create-as Create a snapshot from a set of args
snapshot-current Get or set the current snapshot
snapshot-delete Delete a domain snapshot
snapshot-dumpxml Dump XML for a domain snapshot
snapshot-edit edit XML for a snapshot
snapshot-info snapshot information
snapshot-list List snapshots for a domain
snapshot-parent Get the name of the parent of a snapshot
snapshot-revert Revert a domain to a snapshot
转换磁盘的格式
raw磁盘格式的虚拟机不支持快照功能,要使用镜像功能,磁盘格式必须为qcow2
转换格式时虚拟机必须先关机
qemu-img convert -f raw -O qcow2 /opt/Centos-7.2-x86_64.raw /opt/Centos-7.2-x86_64.qcow2
qemu-img info /opt/Centos-7.2-x86_64.qcow2
修改配置文件的disk模块,把磁盘改成最新的qcow2的这个文件,同时格式也改成qcow2的
virsh edit Centos-7.2-x86_64
改好之后,检查启动是否正常
virsh start Centos-7.2-x86_64
virsh shutdown Centos-7.2-x86_64
快照备份,启动kvm和关闭的情况都可以快照
virsh snapshot-create Centos-7.2-x86_64 #每次创建一个快照之前,都可以在KVM虚拟机上touch一个文件,下面恢复快照的时候,可以检查该文件是否存在
virsh snapshot-list Centos-7.2-x86_64
virsh snapshot-create Centos-7.2-x86_64
virsh snapshot-list Centos-7.2-x86_64
virsh snapshot-current Centos-7.2-x86_64 # 查看当前快照
virsh snapshot-list Centos-7.2-x86_64
Name Creation Time State
------------------------------------------------------------
1533869463 2018-08-10 10:51:03 +0800 shutoff
1533869964 2018-08-10 10:59:24 +0800 running
1533869988 2018-08-10 10:59:48 +0800 running
1533870006 2018-08-10 11:00:06 +0800 running
virsh snapshot-revert Centos-7.2-x86_64 1533870006 #恢复到某个快照
virsh snapshot-revert Centos-7.2-x86_64 1533869964
virsh snapshot-delete Centos-7.2-x86_64 1533869502 #删除到某个快照
qemu-img info /opt/Centos-7.2-x86_64.qcow2 #qemu-img info也可以查看快照
image: /opt/Centos-7.2-x86_64.qcow2
file format: qcow2
virtual size: 10G (10737418240 bytes)
disk size: 2.2G
cluster_size: 65536
Snapshot list:
ID TAG VM SIZE DATE VM CLOCK
1 1533869463 0 2018-08-10 10:51:03 00:00:00.000
2 1533869964 380M 2018-08-10 10:59:24 00:05:47.239
3 1533869988 380M 2018-08-10 10:59:48 00:06:07.406
4 1533870006 380M 2018-08-10 11:00:06 00:06:21.841
Format specific information:
compat: 1.1
lazy refcounts: false
CPU和内存动态扩容
CPU和内存的动态扩容可以通过virt-install 命令实现
virt-install --help | grep cpu
--vcpus VCPUS Number of vcpus to configure for your guest. Ex:
--vcpus 5
--vcpus 5,maxcpus=10,cpuset=1-4,6,8
--vcpus sockets=2,cores=4,threads=2,
--cpu CPU CPU model and features. Ex:
--cpu coreduo,+x2apic
--cpu host-passthrough
--cpu host
virt-install --help | grep memory
usage: virt-install --name NAME --memory MB STORAGE INSTALL [options]
--memory MEMORY Configure guest memory allocation. Ex:
--memory 1024 (in MiB)
--memory 512,maxmemory=1024
--memory 512,maxmemory=1024,hotplugmemorymax=2048,hotplugmemoryslots=2
--memdev MEMDEV Configure a guest memory device. Ex:
--memtune MEMTUNE Tune memory policy for the domain process.
--memorybacking MEMORYBACKING
Set memory backing policy for the domain process. Ex:
--memorybacking hugepages=on
也通过修改配置文件实现,首先需要修改支持动态更改cpu和内存
动态修改cpu
virsh setvcpus Centos-7.2-x86_64 2 --live
KVM虚拟机查看 cat /proc/cpuinfo | grep processor | wc -l
另外动态修改CPU,只能动态的添加,不能动态的减少,如果要减少可以通过关闭kvm,修改配置文件操作
virsh dominfo Centos-7.2-x86_64 | grep CPU
动态修改内存
virsh qemu-monistor-command Centos-7.2-x86_64 --hmp --cmd info balloon
virsh qemu-monitor-command Centos-7.2-x86_64 --hmp --cmd balloon 2048
virsh dominfo Centos-7.2-x86_64| grep memory
另一种修改kvm内存的方式,另外修改内存不能超过最大内存
virsh setmem Centos-7.2-x86_64 748288
在规划是考虑到想要热添加,当时装虚拟机的时候,就要考虑这个问题,设置max内存和cpu
关于硬盘扩容部分,虽然可以resize增大,但是有丢失数据的风险,生产中不推荐使用
KVM的网络部分
启动kvm虚拟机,会多出一个vnet0网络设备,这是虚拟启动后生成的。
ifconfig
virbr0: flags=4163 mtu 1500
inet 192.168.122.1 netmask 255.255.255.0 broadcast 192.168.122.255
ether 52:54:00:2f:b1:73 txqueuelen 0 (Ethernet)
RX packets 13 bytes 1042 (1.0 KiB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 5 bytes 670 (670.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
vnet0: flags=4163 mtu 1500
kvm虚拟机启动后,vnet0默认桥接到了virbr0上,关闭后消失
此时的kvm虚拟机出去的流量是接到virbr0上,然后经过宿主机的iptables的nat,再经过eth0出去
这就有网络瓶颈了,而且依靠iptables,如果你把iptables关闭无法上网了。同时ip地址是地址池中分配的内网地址
iptables -t nat -vnL
Chain POSTROUTING (policy ACCEPT 5 packets, 585 bytes)
pkts bytes target prot opt in out source destination
2 269 RETURN all -- * * 192.168.122.0/24 224.0.0.0/24
0 0 RETURN all -- * * 192.168.122.0/24 255.255.255.255
0 0 MASQUERADE tcp -- * * 192.168.122.0/24 !192.168.122.0/24 masq ports: 1024-65535
0 0 MASQUERADE udp -- * * 192.168.122.0/24 !192.168.122.0/24 masq ports: 1024-65535
0 0 MASQUERADE all -- * * 192.168.122.0/24 !192.168.122.0/24
7 855 POSTROUTING_direct all -- * * 0.0.0.0/0 0.0.0.0/0
7 855 POSTROUTING_ZONES_SOURCE all -- * * 0.0.0.0/0 0.0.0.0/0
7 855 POSTROUTING_ZONES all -- * * 0.0.0.0/0 0.0.0.0/0
#brctl show
bridge name bridge id STP enabled interfaces
virbr0 8000.5254002fb173 yes vnet0
virsh net-list #查看default网络
less /etc/libvirt/qemu/networks/default.xml #查看defaut 网络配置
kvm获取的地址来源于下面
ps aux | grep dns #DNS服务
less /var/lib/libvirt/dnsmasq/default.conf #DNS配置文件
参考:https://www.cnblogs.com/nmap/p/6369180.html