kvm安装

1、在宿主机上准备好yum(只需要本地镜像yum就可以)

2、查看CPU是否支持inter或AMD的虚拟技术

# cat /proc/cpuinfo |grep -E "vmx|svm"

3、安装kvm

# yum install qemu-kvm libvirt virt-install libvirt-python virt-manager virt-install libvirt-client virt-viewer

4、确认是否有装在kvm模块,没有装载可以使用modprobe kvm来装载

# lsmod |grep kvm
kvm_intel 170181 0
kvm 554609 1 kvm_intel
irqbypass 13503 1 kvm

5、启动并设置为开机自启动

# systemctl start libvirtd
# systemctl status libvirtd
# systemctl enable libvirtd

启动报错排查

Linux-KVM虚拟化_LinuxLinux-KVM虚拟化_Linux_02

[root@server ~]# systemctl start libvirtd
Job for libvirtd.service failed because the control process exited with error code. See "systemctl status libvirtd.service" and "journalctl -xe" for details.

[root@server ~]# journalctl -xe
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit libvirtd.service has failed.
--
-- The result is failed.
1月 04 16:34:19 server systemd[1]: Unit libvirtd.service entered failed state.
1月 04 16:34:19 server systemd[1]: libvirtd.service failed.
1月 04 16:34:19 server systemd[1]: libvirtd.service holdoff time over, scheduling restart.
1月 04 16:34:19 server systemd[1]: start request repeated too quickly for libvirtd.service
1月 04 16:34:19 server systemd[1]: Failed to start Virtualization daemon.
-- Subject: Unit libvirtd.service has failed
-- Defined-By: systemd
-- Support: http://lists.freedesktop.org/mailman/listinfo/systemd-devel
--
-- Unit libvirtd.service has failed.
--
-- The result is failed.
1月 04 16:34:19 server systemd[1]: Unit libvirtd.service entered failed state.
1月 04 16:34:19 server systemd[1]: libvirtd.service failed.



查看/var/log/messages日志发现:
Jan 4 16:41:44 server libvirtd: 2019-01-04 08:41:44.437+0000: 23439: error : virModuleLoadFile:53 : 内部错误:Failed to load module '/usr/lib64/libvirt/storage-backend/libvirt_storage_backend_rbd.so': /usr/lib64/libvirt/storage-backend/libvirt_storage_backend_rbd.so: undefined symbol: rbd_diff_iterate2

解决办法:
# cd /usr/lib64/libvirt/storage-backend
# mv libvirt_storage_backend_rbd.so libvirt_storage_backend_rbd.so.back

再次启动就ok

/var/log/messages日志报错信息:virModuleLoadFile:53

kvm安装虚拟机

图形安装

--和xen一样的命令,打开虚拟机管理器
# virt-manager

第一步、

安装方式:         --我这里选择第一个,使用iso直接安装


第二步、

安装路径:/data/CentOS-7-x86_64-DVD-1611.iso                  --写上iso的路径


第三步、

内存大小: 800M          -- 内存如果较小,安装时无法使用图形安装方式,只能使用文本安装方式

cpu个数:2                 --不能大于宿主机器的cpu核数


第四步、

硬盘大小:20G          --我这里定义20G大小;它的默认路径会在/var/lib/libvirt/images/kvm1.qcow2


第五步、

name:kvm1              --自定义一个虚拟机名称

网络现在只能选择default --这是一个nat网络(私有网络),桥接网络不能选,需要后面单独配置后才能选择

命令行安装

# virt-install --hvm --name "kvm1" --memory 800 --vcpus 2  --disk=/var/lib/libvirt/images/kvm1.qcow2,size=20 -l /share/CentOS-7-x86_64-DVD-1611.iso --network bridge=virbr0

--hvm 指使用全虚拟化

kvm主要的管理命令

virsh help  
virsh help domain
virsh help network
virsh help monitor --因为参数很多,可以用象domain,network,monitor这种关键字,只查看与关键字有关的参数帮助
......
# virsh  list
Id Name State
----------------------------------------------------
1 kvm1 running

# virsh list --all
Id Name State
----------------------------------------------------
1 kvm1 running
- kvm2 shut off

启动、关闭、重启相关

# virsh  start kvm1       --启动一个虚拟机

# virsh shutdown kvm1 --正常关闭一个虚拟机(把服务都停掉,再关电源)

# virsh reboot kvm1 --正常重启一个虚拟机,先shutdown再start
# virsh  destroy kvm1     --强制关闭一个虚拟机,类似断电,可以瞬间关闭虚拟机     

# virsh reset kvm1 --相当于是先destroy,再start

保存、暂停相关

# virsh save kvm1 /etc/libvirt/qemu/kvm1.save      --把kvm1关闭,并把当前状态保存为一个文件    

# virsh restore /etc/libvirt/qemu/kvm1.save --通过保存的文件,恢复当时save时的状态

# virsh suspend kvm1 --暂停kvm1的状态

# virsh resume kvm1 --由暂停切换为继续的状态

连接虚拟机相关

方法一:

# virt-manager 打开管理器,双击你要连接的虚拟机

方法二:

# virt-viewer  kvm1   --连接一个已经启动的虚拟机,并使用图形查看

方法三:

# ssh x.x.x.x   --非图形方式就可以连,但需要虚拟机配置好ip

方法四:

非图形方式也可以使用console连(此方法不需要虚拟机配置ip都可以连),但需要配置授权

# virsh console kvm1   --字符连接一个虚拟机,但是现在连接不了;因为需要一个串口的授权才可以;

授权做法:

1,在kvm1虚拟机里操作(注意不是在宿主机上操作)
# grubby --update-kernel=ALL --args="console=ttyS0"

# reboot
2,在宿主机virsh console kvm1连接使用
3,退出的方式
exit只是退出登录的用户而已
要完全退出这个console连接,需要使用的是ctrl+ ] (也就是右中框号的这个键)

虚拟机相关的文件

以kvm1为例:

配置文件在:

/etc/libvirt/qemu/kvm1.xml

磁盘文件默认在:

/var/lib/libvirt/images/kvm1.qcow2

打开虚拟机配置文件的做法:

方法一:

# vim /etc/libvirt/qemu/kvm1.xml

方法二:

# virsh edit kvm1      --此方法默认是调用vi,所以没有颜色,你可以做个软链接,让访问vi实际链接到vim就可以了

命令删除一个虚拟机的做法(假设kvm3)

# virsh destroy kvm3

# virsh undefine kvm3

# rm -rf /var/lib/libvirt/images/kvm3.img

kvm的克隆

--注意:克隆都需要源虚拟机器是关闭或者暂停状态

图形克隆

  • 先关闭kvm1或 virsh suspend kvm1暂停kvm1(使用virsh resume kvm1恢复)
  • virt-manager--》右键点kvm1--》选择clone-->修改克隆后的名字或其它参数--》点clone

文本克隆

 1、拷贝配置文件和磁盘文件

# cp /etc/libvirt/qemu/kvm1.xml /etc/libvirt/qemu/kvm3.xml

# cp /var/lib/libvirt/images/kvm1.qcow2 /var/lib/libvirt/images/kvm3.qcow2

 2、修改拷贝的配置文件

# vim /etc/libvirt/qemu/kvm3.xml

<domain type='kvm'>
<name>kvm3</name> --名字改成kvm3
<uuid>811d69e8-b1d8-cfbf-684a-69f2e0af6b88</uuid> --uuid随便改几个数字
<memory unit='KiB'>1048576</memory>
<currentMemory unit='KiB'>1048576</currentMemory>
<vcpu placement='static'>2</vcpu>
<os>
<type arch='x86_64' machine='pc-i440fx-rhel7.0.0'>hvm</type>
<boot dev='hd'/>
</os>
<features>
<acpi/>
<apic/>
<pae/>
</features>
<clock offset='utc'/>
<on_poweroff>destroy</on_poweroff>
<on_reboot>restart</on_reboot>
<on_crash>restart</on_crash>
<devices>
<emulator>/usr/libexec/qemu-kvm</emulator>
<disk type='file' device='disk'>
<driver name='qemu' type='raw' cache='none'/>
<source file='/var/lib/libvirt/images/kvm3.qcow2'/> --磁盘路径改成kvm3.qcow2的路径
<target dev='vda' bus='virtio'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x0'/>
</disk>
<disk type='block' device='cdrom'>
<driver name='qemu' type='raw'/>
<target dev='hdc' bus='ide'/>
<readonly/>
<address type='drive' controller='0' bus='1' target='0' unit='0'/>
</disk>
<controller type='usb' index='0'>
<address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x2'/>
</controller>
<controller type='ide' index='0'>
<address type='pci' domain='0x0000' bus='0x00' slot='0x01' function='0x1'/>
</controller>
<interface type='bridge'>
<mac address='52:54:00:5c:3a:2d'/> --网卡地址随便改下,只改后三位
<source bridge='br0'/>
<model type='virtio'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
</interface>
<serial type='pty'>
<target port='0'/>
</serial>
<console type='pty'>
<target type='serial' port='0'/>
</console>
<input type='tablet' bus='usb'/>
<input type='mouse' bus='ps2'/>
<graphics type='vnc' port='-1' autoport='yes'/>
<sound model='ich6'>
<address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x0'/>
</sound>
<video>
<model type='cirrus' vram='9216' heads='1'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x02' function='0x0'/>
</video>
<memballoon model='virtio'>
<address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/>
</memballoon>
</devices>
</domain>

3、保存后,使用virsh list --all查看不到的,需要define一下

# virsh define /etc/libvirt/qemu/kvm3.xml
# virsh list --all        --再查就可以查看到kvm3
Id Name State
----------------------------------------------------
- kvm1 shut off
- kvm1-clone shut off
- kvm2 shut off
- kvm3 shut off

4、再启动

# virsh start kvm3   --可以启动克隆的机器了

命令克隆

# virt-clone -o kvm1 -n kvm4 -f /var/lib/libvirt/images/kvm4.img 
Allocating kvm4.img 7% [- ] 34 MB/s | 957 MB 05:29 ETA

--把kvm1克隆成kvm4,指定磁盘路径为/var/lib/libvirt/images/kvm4.img;如果kvm1有多个硬盘,那么克隆时也要对应的克隆成多个路径

kvm网络管理

只查看与网络有关的帮助参数

# virsh  help network
# virsh net-list --all
Name State Autostart
-----------------------------------------
default active yes --这是一个NAT网络,私有网络
# virsh net-info default
Name default
UUID 704eb1b7-3feb-4a38-8642-9c3fe2f023bb
Active: yes
Persistent: yes
Autostart: yes
Bridge: virbr0

default网段的配置文件的路径为:

/etc/libvirt/qemu/networks/default.xml
# virsh net-destroy default        --停掉default网络,由virsh net-list --all去查看,状态变为inactive
# virsh net-start default --启动default网络,状态变为active

图形增加私有网络

virt-manager打开图形--》edit --》connections details --》 virtual networks--》点左下角的+号增加一个私有网络(选择名字,网络分配地址范围,dhcp的分配范围)

注意:这里最后一步有三种网络:

1、isolated 相当vmware的hostonly,没有NAT,也没有网关(完全和vmware的hostonly类型一样)

2、NAT 有网关,有NAT,可以通过宿主上外网(和vmware的NAT类型一样)

3、routed 也是相当于hostonly,在isolated的基础上就是加了一个网关(仍然是和vmware的hostonly一致,但多了一个网关)

把上面的步骤做完后,直接在宿主机用ifconfig或virsh net-list --all,就可以看到新加的网络了

手动增加私有网络

1、拷贝一个网络配置文件并编辑

# cp /etc/libvirt/qemu/networks/default1.xml /etc/libvirt/qemu/networks/default2.xml
# vim /etc/libvirt/qemu/networks/default2.xml

<network>
<name>default2</name> --修改名字为default2
<uuid>243166ddb-e2fd-9983-1997-5e8efdc06c42</uuid> --uuid随便修改一下
<bridge name='virbr2' stp='on' delay='0' /> --virbr1改成virbr2
<mac address='52:54:00:AF:27:25'/> --MAC地址改一下,只改后面三位
<ip address='192.168.101.1' netmask='255.255.255.0'> --IP改为101
<dhcp>
<range start='192.168.101.128' end='192.168.101.254' /> --dhcp地址范围也改成101的
</dhcp>
</ip>
</network>

2、定义一下,然后就可以使用virsh  net-list --all去查看,状态为inactive,autostart的状态为no

# virsh net-define /etc/libvirt/qemu/networks/default2.xml

3、启动

# virsh net-start default2

4、查看

# ifconfig virbr2 |head -2    --查看就有了    
virbr2 Link encap:Ethernet HWaddr 52:54:00:AF:27:25
inet addr:192.168.101.1 Bcast:192.168.101.255 Mask:255.255.255.0
# ls /etc/libvirt/qemu/networks/autostart/
default1.xml default.xml

5、设置为开机自动启动

# virsh net-autostart default2

# ls /etc/libvirt/qemu/networks/autostart/ --这里就会多了default2.xml了,其实都是网络配置文件的软链接
default1.xml default2.xml default.xml

刚加的网络配置文件都在下面的目录

# ls /etc/libvirt/qemu/networks
autostart default1.xml default2.xml default.xml

修改一个网络

1、编辑配置文件

# vim /etc/libvirt/qemu/networks/default2.xml    


<network>
<name>default2</name>
<uuid>243166ddb-e2fd-9982-1996-5e8efdc06c42</uuid>
<forward dev='eth0' mode='route'>
<interface dev='eth0'/>
</forward>
<bridge name='virbr2' stp='on' delay='0' />
<mac address='52:54:00:AF:166:45'/>
<ip address='192.168.102.1' netmask='255.255.255.0'> --我这里把以前的192.168.101.0的IP范围都改成了192.168.102.0
<dhcp>
<range start='192.168.102.128' end='192.168.102.254' />
</dhcp>
</ip>
</network>

保存后,使用ifconfig virbr1 查看,还是192.168.102.1, 没有改变

需要做下面三步:

2、定义一个网络,使你的修改被他知道

# virsh net-define /etc/libvirt/qemu/networks/default2.xml  --定义一个网络,使你的修改被他知道
Network default2 defined from /etc/libvirt/qemu/networks/default3.xml

3、停一下这个网络

# virsh net-destroy default2    --停一下这个网络
Network default2 destroyed

4、再启动这个网络

# virsh net-start default2    --再启这个网络
Network default2 started

ifconfig virbr2查看,成功修改成192.168.102.1

上面的第一步和第二步可以统一成一步来做:

# virsh  net-edit default2   --使用这个命令打开,修改,然后就直接net-destroy和net-start,不需要去net-define

删除一个网络

图形删除一个网络

virt-manager打开图形--》edit --》connections details --》 virtual networks--》选择你要删除的网络,然后左下角,先停,再删除就可以了

命令删除一个网络

# virsh net-destroy default2    --停掉要删除的网络,用virsh net-list --all命令去查就变成了inactive状态

# virsh net-undefine default2  --这下就删除了这个网络定义了,并且物理上的配置文件也没了

增加一个桥接网络

把物理网卡enp2s0桥接到br0(这个名字是自己定义的)

1、在宿主机上创建一个桥接网络

# systemctl stop NetworkManager
# systemctl status NetworkManager
# systemctl disable NetworkManager
# vim /etc/sysconfig/network-scripts/ifcfg-br0  --此文件不存在,br0这个名字是自定义的
DEVICE=br0 --名字对应好
TYPE=Bridge --这里的Birdge,B要大写,后面的irdge要小写
BOOTPROTO=static
IPADDR=172.16.13.X
NETMASK=255.255.255.0
GATEWAY=172.16.13.254
DNS1=114.114.114.114
ONBOOT=yes

2、把一个物理网卡加到一个桥接网络里,这里是把enp2s0加到br0

# vim /etc/sysconfig/network-scripts/ifcfg-enp2s0     --原物理网卡enp2s0里的配置只留下这三句就可以了
DEVICE="enp2s0"
ONBOOT="yes"
BRIDGE=br0

3、重启网络

/etc/init.d/network restart 或者 systemctl restart network

在宿主机上ifconfig 查看就会有br0这个网卡,有IP;而原enp2s0网卡没有IP;这是正常的

修改虚拟机的网卡连接

图形修改

virt-manager打开图形,双击你要修改的虚拟机--》点击左上的一个!号(centos7里看到的是一个像灯泡一样的符号)按钮show virtual hardware detail-->>找个网卡,修改成你想要改的网络

命令修改

# virsh edit kvm3

<interface type='network'>
<mac address='52:54:00:07:8d:e5'/>
<source network='default'/>
<model type='virtio'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
</interface>

改成下面的样子

<interface type='bridge'> --network改成了bridge
<mac address='52:54:00:07:8d:e5'/>
<source bridge='br0'/> --network改成了bridge;default改成了br0
<model type='virtio'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/>
</interface>
# virsh shutdown kvm1

# virsh start kvm1 --重启后,虚拟机就是桥接网络

kvm磁盘管理

图形添加硬盘设备

virt-manager--》 双击打开kvm4--》点左上角的灯泡符号show virtual hardware details --》点左下角add devices 直接添加,并写上相关参数就可以(注意参数,device type都选择virtio,不需要重启虚拟机,可以直接生效,并且磁盘名叫vda,vdb,vdc...;如果你第一次加硬盘选择IDE disk,需要重启,并且磁盘名叫sda,sdb,sdc...)

注意:用图形方式在线删除磁盘后,还要去物理上把它的磁盘xxx.qcow2文件给rm掉

命令添加硬盘设备

1、使用dd命令创建一个磁盘文件

# dd if=/dev/zero of=/var/lib/libvirt/images/kvm4-2.img bs=1M count=1 seek=4000000
--seek是指跳过多少个BS块,这里就是产生一个4T大小的文件(实际大小只1M)
# qemu-img info /var/lib/libvirt/images/kvm4-2.img
image: /var/lib/libvirt/images/kvm4-2.img
file format: raw --格式为raw(这是老版本的默认格式,新版本是qcow2格式)
virtual size: 3.8T (4194305048576 bytes)
disk size: 1.0M
# cd /var/lib/libvirt/images/
# qemu-img convert -f raw -O qcow2 kvm4-2.img kvm4-2.qcow2 --把kvm4-2.img文件转换成一个新文件kvm4-2.qcow2(格式也转换成qcow2)
# rm kvm4-2.img -rf --原来的这个文件不用了就可以删除掉了
# qemu-img info /var/lib/libvirt/images/kvm4-2.qcow2 
image: /var/lib/libvirt/images/kvm4-2.qcow2
file format: qcow2 --转化后的新文件格式就为qcow2格式了
virtual size: 3.8T (4194305048576 bytes)
disk size: 256K
cluster_size: 65536
Format specific information:
compat: 1.1
lazy refcounts: false

2、编辑虚拟机的配置文件

# virsh edit kvm4
<devices>与</devices>之间加上下面的一段,也可以把其它磁盘的配置定义拷贝一段进行修改


<disk type='file' device='disk'>
<driver name='qemu' type='qcow2' /> --格式为qcow2
<source file='/var/lib/libvirt/images/kvm4-2.qcow2'/> --路径名称改成kvm4-2.qcow2
<target dev='vdb' bus='virtio'/> --新加的硬盘,就叫vdb
<address type='pci' domain='0x0000' bus='0x00' slot='0x08' function='0x0'/> --slot也改一下,我这里是把0x07改成0x09(只要这个编号没有被重复占用就可以)
</disk>

3、重启虚拟机后(有可能reboot还不行,需要force off再启动),登录使用fdisk就能查看到这个4T大小的硬盘了

迁移磁盘目录

比如宿主机的/var目录空间不够,想把磁盘文件改到气他目录(如/data/kvm/目录)

# virsh destroy kvm1  --先停掉kvm1

# mv /var/lib/libvirt/images/kvm1.qcow2 /data/kvm/


# virsh edit kvm1
......
<disk type='file' device='disk'>
<driver name='qemu' type='qcow2' />
<source file='/data/kvm/kvm1.qcow2'/> --把这个路径改成mv后的新路径
<target dev='vda' bus='virtio'/>
<address type='pci' domain='0x0000' bus='0x00' slot='0x05' function='0x0'/>
</disk>
......


# virsh start kvm1


人生是条无名的河,是浅是深都要过; 人生是杯无色的茶,是苦是甜都要喝; 人生是首无畏的歌,是高是低都要唱。