KVM虚拟化、创建、克隆、qemu-guest-agent安装等实践过程

大兔子大兔子 提交于 2020-07-28 11:13:27

由于公司需求,所以最近学习了KVM,下面是本人安装实践过程。

安装虚拟化软件

  • 查看CPU是否支持KVM
    egrep 'vmx|svm' /proc/cpuinfo --color=auto
    可以看到grep出来的内容,就说明支持kvm。

  • 通过apt进行安装
apt-get install -y qemu-kvm libvirt-daemon libvirt-daemon-system 
  • 启动并设置开机启动
    systemctl start libvirtd && systemctl enable libvirtd

配置网桥网卡,如下配置

  • ubuntu路径: vim /etc/netplan/01-network-manager-all.yaml
network:
  version: 2
  renderer: NetworkManager
  ethernets:
      enp2s0:
          dhcp4: yes
          dhcp6: yes
          #bridge: br0
  bridges:
      br0:
          dhcp4: no
          dhcp6: no
          addresses: [192.168.10.163/23]
          gateway4: 192.168.10.1
          nameservers:
              addresses: [223.5.5.5,223.6.6.6]

重启网卡

netplan apply

安装vncserver

apt-get install xrdp
apt-get install virt-manager
apt-get install tightvncserver

使用qemu-img命令创建磁盘镜像文件

qemu-img create -f qcow2 /root/test.qcow2 20G

使用virt-install命令创建虚拟机

纯命令行安装虚拟机

  • 先上传需要创建虚拟机的镜像文件cn_windows_10_business_editions_version_1909_x64_dvd_0ca83907.iso,和软驱virtio-win-0.1.171_amd64.vfd
virt-install --name win-win10 --ram 2048 --cdrom=/kvm/iso/cn_windows_10_business_editions_version_1909_x64_dvd_0ca83907.iso --disk path=/qcow2/win-win10.qcow2 --disk path=/kvm/iso/virtio-win-0.1.171_amd64.vfd,device=floppy  --network source=enp2s0,source.mode=bridge,type=direct --graphics vnc,password=root,port=5913,listen=0.0.0.0 --noautoconsole --check all=off
  • 更多virt-install 参数使用
virt-install --help
  • 参考
[root@localhost ~]# qemu-img create -f qcow2 /kvm/vfs/vm3.qcow2 20G
[root@localhost ~]# virt-install -n vm3 \     定义虚拟机名
> -r 1024 \         内存大小
> --vcpus 1 \       CPU数量
> -l /kvm/iso/Centos7.iso \      ISO位置
> --disk path=/kvm/vfs/vm3.qcow2,format=qcow2 \      磁盘文件位置及格式
> --graphics vnc,listen=0.0.0.0,port=5924, \         vnc安装,使用5924端口
> --noautoconsole  \      不要自动尝试连接到客户端控制台
> --accelerate \          提速安装
> --autostart             引导主机时自动启动域
[root@localhost ~]# firewall-cmd --add-port=5924/tcp    允许vnc连接

然后可以使用客户端vnc viewer连接新创建的虚拟机,ip:port,ip为宿主机ip,端口为创建虚拟机指定的端口,创建虚拟机没有指定密码则无需密码。亦可使用如下命令查看虚拟机vnc端口

virsh vncdisplay win-win10

安装Qemu-guest-agent

  1. 先在xml里配置channel段,然后启动虚拟机,会在宿主机上生成一个unix socket,同时在vm里生成一个字符设备,生成的unix socket和字符设备可以理解为一个channel隧道的两端

  2. 虚拟机里要启动qemu-guest-agent守护进程,该守护进程会监听字符设备

  3. 然后可以在宿主机上将虚拟机里的qemu-guest-agent所支持的RPC指令经过channel发送到虚拟机里,虚拟机里的qemu-guest-agent从字符设备收到数据后,执行指令,比如读写文件、修改密码等等

  • 在虚拟机的配置文件.xml中添加宿主机和虚拟机通信的通道
virsh edit 虚拟机名字
在<devices>标签中添加如下信息:

 <channel type='unix'>
      <source mode='bind' path='/tmp/channel.sock'/>
      <target type='virtio' name='org.qemu.guest_agent.0'/>
      <address type='virtio-serial' controller='0' bus='0' port='1'/>
</channel>

然后关闭虚拟机并启动虚拟机

virsh shutdown VM
virsh start VM
  • 如果虚拟机是Linux,只需安装qemu-guest-agent
apt-get install qemu-guest-agent
或
yum install qemu-guest-agent
  • Windows
    首先,您必须下载virtio-win驱动程序iso
    下载好wirtio-win手工挂载到虚拟机上
    在这里插入图片描述
    进入虚拟机,转到Windows设备管理器
    查找“ PCI简单通信控制器”
    右键单击->更新驱动程序,然后选择目录为上面挂载的光驱盘:





进入我的电脑->选择手工挂载的光驱盘,找到qemu-guest目录,
双击执行安装程序(qemu-ga-x64.msi(64位)或qemu-ga-x86.msi(32位)
之后,进入服务管理器查看qemu-guest-agent应该已启动并正在运行。

  • 在宿主机通过指令
virsh qemu-agent-command VM  --cmd '{"execute":"guest-info"}'
可以查看其所有支持的命令

复制虚拟机:

  • 普通复制
virt-clone -o vm -n newvm -f /root/centos7_clone1.qcow2 (新磁盘镜像)
或者
virt-clone --connect qemu:///system --original vm1 --name vm1-clone --file /vm-images/vm1-clone.qcow2
  • 通过模板复制虚拟机
    安装完成后,关闭虚拟机
virsh shutdown vm1

将原虚拟机的磁盘镜像文件copy一份,作为镜像模板

cp /kvm/vm/vm1_0.qcow2 /data/kvm/template/tpl.qcow2

使用virsh dumpxml命令获取虚拟机的配置文件

virsh dumpxml --domain vm1 > /data/kvm/template/tpl.xml

修改tpl.xml中镜像文件的指定位置为/data/kvm/template/tpl.qcow2,即我们复制的磁盘镜像文件的路径。

<disk type='file' device='disk'>
    <driver name='qemu' type='qcow2'/>
    <source file='/data/kvm/template/tpl.qcow2'/>
    <target dev='vda' bus='virtio'/>
    <address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/>
</disk>

删除tpl.xml中如下四行内容,其中<source …/>是必删的,其它三行只是为了避免歧义。

<name>vm1</name>
<uuid>47cdbba1-3551-407d-a03c-90d2a60bfa71</uuid>
<mac address='52:54:00:83:79:76'/>
<source mode='bind' path='/var/lib/libvirt/qemu/channel/target/domain-vm1/org.qemu.guest_agent.0'/>

通过 virt-sysprep 命令处理tpl.qcow2,为了clone操作可以用于这个镜像。

virt-sysprep -a /data/kvm/template/tpl.qcow2

这样,我们的模板文件和模板镜像就制作好了。其root密码同vm1的root密码一致。

[root@localhost /data/kvm/template]# tree .

├── tpl.qcow2
└── tpl.xml

如果直接使用virt-sysprep 来重置镜像,不加任何其他参数,会把镜像重置成几乎是完全新安装的状态。其执行的步骤,可以通过list命令查看。

virt-sysprep --list-operations
一些定制的配置,可以通过参数来设置,比如hostname和root密码。

virt-sysprep -a /data/kvm/template/tpl.qcow2  --hostname localhost --root-password password:testpwd

通过模板创建虚拟机

virt-clone --connect qemu:///system \
  --original-xml /data/kvm/template/tpl.xml \
  --name 虚拟机名字 \
  --file /data/kvm/vm/vm5_0.qcow2 (新的磁盘镜像)
virt-clone --connect qemu:///system \
  --original-xml /data/kvm/template/tpl.xml \
  --name vm3 \
  --file /data/kvm/vm/vm3_0.qcow2
clone操作会为新的虚拟机分配新的uuid和mac地址。

定义存储池

  • 存储池介绍
    KVM平台以存储池的形式对存储进行统一管理,所谓存储池可以理解为本地目录,通过远端磁盘阵列(ISCSI,NFS)分配过来磁盘或目录,当然也支持各类分布式文件系统。
    存储池是放置虚拟机存储的位置,可以是本地,也可以是网络存储,具体的虚拟机实例放置在卷上。
    KVM创建的存储池可以理解为一种映射关系,即将某一块挂载至宿主机器上的存储空间形成可被KVM使用的逻辑存储池,以方便虚拟主机的管理


  • 定义存储池
    采用本地目录方式创建KVM存储池
  mkdir -p /data/vmfs
  virsh pool-define-as vmfspool --type dir --target /data/vmfs  (定义池 vmfspool)
  virsh pool-build vmfspool  (构建池 vmfspool)

 virsh pool-list --all
 名称               状态     自动开始
-------------------------------------------
 vmfspool             不活跃  否       

virsh pool-info vmfspool
名称:       vmfspool
UUID:           c6d5bd62-3229-4a16-b267-081d943be80a
状态:       不活跃
持久:       是
自动启动: 否
  • 设置存储池自动启动
virsh pool-autostart vmfspool
  • 启动存储池
virsh pool-start vmfspool
  • 查看存储池信息
名称:       vmfspool
UUID:           c6d5bd62-3229-4a16-b267-081d943be80a
状态:       running
持久:       是
自动启动: 是
容量:       49.98 GiB     #显示挂载分区总容量
分配:       6.59 GiB      #分区已经使用容量
可用:       43.38 GiB     #可用容量

3、在存储池创建映像文件,安装vm
#在存储池创建一个 testqcow2.img (磁盘映像文件)

virsh vol-create-as vmfspool  test.qcow2 10G --format qcow2
 ll /data/vmfs/
总用量 196
-rw------- 1 root root 197120 10月 26 13:39 oel3_qcow2.img
[root@node71 ~]# 
[root@node71 ~]# virsh vol-info --pool vmfspool /data/vmfs/oel3_qcow2.img
名称:       oel3_qcow2.img
类型:       文件
容量:       10.00 GiB
分配:       196.00 KiB
  • 存储池的删除
virsh pool-destroy vmfspool
virsh pool-undefine vmfspool
virsh pool-delete vmfspool

创建快照

  • 磁盘内部快照( 只支持qcow2格式的镜像文件)
virsh snapshot-create-as --domain vm --name vm1

查看虚拟机快照列表

virsh snapshot-list --domain vm1

快照回滚

virsh snapshot-revert --domain vm --snapshotname vm1

快照删除

virsh snapshot-delete --domain vm --snapshotname vm1
  • 磁盘外部快照
    外置磁盘快照创建时,会保存正在使用磁盘作为backing file(此磁盘不再接受新数据,只保存快照前的数据),并创建一个新的磁盘作为overlays以等待写入新数据
    创建

virsh snapshot-create-as --domain vm1 vm1_sn1 --disk-only --diskspec vda,snapshot=external,file=/disk3/vm1_sn.qcow2 --atomic --no-metadata

已生成域快照 vm1_sn1
其中/disk3/vm1_sn.qcow2是新生成的磁盘快照
查看快照列表

virsh snapshot-list vm1
  • 参考文章
    https://www.cnblogs.com/fzxiaomange/p/kvm-inject.html
    https://www.toutiao.com/i6646012291059810823/
    https://www.jianshu.com/p/1f93b724c540


易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!