部署KVM虚拟化平台

转载自:https://blog.csdn.net/qq_61116007/article/details/125580280

部署KVM

在Centos的系统光盘镜像中,已经提供了安装KVM所需软件。通过部署基于光盘镜像的本地yum源,直接使用yum安装所需软件即可。

  • 验证

重启虚拟机,查看CPU是否支持虚拟化,对于intel的服务器可以通过以下命令查看,只要有输出就说明CPU支持虚拟化;

[root@localhost ~]# cat /proc/cpuinfo | grep vmx
 flags       : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts mmx fxsr sse sse2 ss ht syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts nopl xtopology tsc_reliable nonstop_tsc aperfmperf eagerfpu pni pclmulqdq vmx ssse3 fma cx16 pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand hypervisor lahf_lm abm 3dnowprefetch ida arat epb pln pts dtherm hwp hwp_noitfy hwp_act_window hwp_epp tpr_shadow vnmi ept vpid fsgsbase tsc_adjust bmi1 avx2 smep bmi2 invpcid rdseed adx smap xsaveopt

AMD服务器可以用cat /proc/cpuinfo | grep smv命令查看。

  • 配置yum仓库
[root@localhost ~]# rm -rf /etc/yum.repos.d/*
[root@localhost ~]# vim /etc/yum.repos.d/yum.repo
[yum]
name=a
baseurl=file:///media
gpgcheck=0
[root@localhost ~]# mount /dev/cdrom /media
mount: /dev/sr0 写保护,将以只读方式挂载
  • 安装KVM所需文件
[root@localhost ~]# yum -y install qemu-kvm qemu-kvm-tools virt-install qemu-img bridge-utils libvirt virt-manager

软件包含义如下:

qemu-kvm: KVM模块
qemu-kvm-tools: KVM调试工具,可以不安装
virt-install: 构建虚拟机的命令行工具
qemu-img : qemu组件,创建磁盘、启动虚拟机等
bridge-utils: 网络支持工具
libvirt : 虚拟机管理工具
virt-manager: 图形界面管理虚拟机

  • 检查KVM模块是否安装
[root@localhost ~]# lsmod | grep kvm
kvm_intel             170181  0 
kvm                   554609  1 kvm_intel
irqbypass              13503  1 kvm
  • 开启服务
[root@localhost ~]# systemctl start libvirtd
[root@localhost ~]# systemctl enable libvirtd

设置KVM网络

KVM的两种网络模式:
1.用户模式(NAT):这是默认模式,kvm中的虚拟机能访问外部主机,但是外部主机不能访问kvm中的虚拟机。
2.桥接模式(Bridge):kvm中的虚拟机和外部主机能相互访问。

这里以Bridge为例。

  • 配置网络
[root@localhost]# cd /etc/sysconfig/network-scripts/
[root@localhost network-scripts]# vim 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                              # no改为yes
BRIDGE=br0                              # 加入此行配置


[root@localhost network-scripts]# cp ifcfg-ens33 ifcfg-br0      # 复制网卡信息

[root@localhost network-scripts]# vim ifcfg-br0                 # 修改ifcfg-br0网卡信息
TYPE=Bridge                                                     # 类型改为Bridge
BOOTPROTO=static                                                # 模式改为静态
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                                        # 网卡ens33改为br0
DEVICE=br0                                      # 网卡ens33改为br0
ONBOOT=yes
IPADDR=192.168.10.1                             # 添加网络信息                    
NETMASK=255.255.255.0                           # 添加网络信息
GATEWAY=192.168.10.254                          # 添加网络信息
BRIDGE=br0                                      # 删掉此行配置
  • 重启网络服务
[root@localhost ~]# systemctl restart network
  • 确认IP地址信息
[root@localhost ~]# ifconfig
br0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
       inet 192.168.10.1  netmask 255.255.255.0  broadcast 192.168.10.255
       inet6 fe80::8e68:5d16:b97c:b837  prefixlen 64  scopeid 0x20<link>
       ether 00:0c:29:bc:c7:b8  txqueuelen 1000  (Ethernet)
       RX packets 1  bytes 328 (328.0 B)
       RX errors 0  dropped 0  overruns 0  frame 0
       TX packets 26  bytes 3922 (3.8 KiB)
       TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
...... //省略部分信息

KVM管理

virt-manager是基于libvirt的图形化虚拟机管理软件。不同的发行版本上virt-manager的版本不同,图形界面和操作方法也可能不同。

[root@localhost ~]# virt-manager

虚拟化管理

创建存储池先准备存储池和镜像位置

[root@localhost ~]# mkdir -p /data_kvm/store
[root@localhost ~]# mkdir -p /data_kvm/iso
  • 创建存储池,双击“QEMU/KVM”,选择“存储”选项卡,单击左下角“+”按钮新建存储池。单击“前进”按钮,根据提示输入或浏览用以设置存储目录,如/data_kvm/store,最后点击完成按钮。

  • 同样操作创建一个镜像存储池,名称为aaa_iso,目录为/data_kvm/iso即可。安装操作系统的时,还需要把镜像上传到服务器目录/data_kvm/iso。
[root@localhost ~]# mount /dev/cdrom /media
mount: /dev/sr0 写保护,将以只读方式挂载
[root@localhost ~]# cp /dev/cdrom /data_kvm/iso/centos7.iso

  • 创建存储卷,单击刚创建好的“aaa“,单击窗口中”卷“右边的”+“按钮建立一个存储卷,并设置最大容量

  • 单击“完成”按钮,回到“虚拟机系统管理器”。右击“QEMU/KVM”,选择“新建"选项,再弹出对话框后,选择“本地安装介质”,单击”前进“按钮。

选择iso镜像文件(没有的话刷新一下)

识别出操作系统后下一步即可。选择创建好的存储卷后点击”前进“。

安装前自定义配置,应用自动启动引导后开始安装。

后面的配置就和正常的安装系统相同了,推荐最小化安装,图形界面安装时间较久。

使用KVM命令集管理虚拟机

  • 查看帮助信息
[root@localhost ~]# virsh -h
  • 查看KVM的配置文件存放目录
[root@localhost ~]# ls /etc/libvirt/qemu
autostart  centos7.0.xml  networks          //centos7.0.xml是虚拟机系统的配置文件
  • 查看虚拟机状态
[root@localhost ~]# virsh list --all
Id    名称                         状态
----------------------------------------------------
2     centos7.0                      running           //centos7.0为虚拟机名称
  • 虚拟机关机与开机

首先需要确定acpid服务安装并运行。

[root@localhost ~]# virsh shutdown centos7.0        //关机
域 centos7.0 被关闭
​
[root@localhost ~]# virsh start centos7.0           //开机
域 centos7.0 已开始
  • 强制系统关闭电源
[root@localhost ~]# virsh destroy centos7.0
域 centos7.0 被删除             //已经被强制关闭电源
  • 通过配置文件启动虚拟机
[root@localhost ~]# virsh create /etc/libvirt/qemu/centos7.0.xml                //上面已经强制关机,通过配置文件启动虚拟机
域 centos7.0 被创建(从 /etc/libvirt/qemu/centos7.0.xml)
​
[root@localhost ~]# virsh list --all                //查看状态
Id    名称                         状态
----------------------------------------------------
4     centos7.0                      running
  • 挂起虚拟机
[root@localhost ~]# virsh suspend centos7.0
域 centos7.0 被挂起
​
[root@localhost ~]# virsh list --all
Id    名称                         状态
----------------------------------------------------
4     centos7.0                      暂停
  • 恢复虚拟机
[root@localhost ~]# virsh resume centos7.0
域 centos7.0 被重新恢复
​
[root@localhost ~]# virsh list --all
Id    名称                         状态
----------------------------------------------------
4     centos7.0                      running
  • 配置虚拟机伴随宿主机自动启动
[root@localhost ~]# virsh autostart centos7.0
域 centos7.0标记为自动开始
  • 取消虚拟机伴随宿主机自动启动
virsh autostart --disable  vmname

上述命令将创建/etc/libvirt/qemu/autostart/目录,目录内容为开机自动启动的系统。

  • 导出虚拟机配置

复制centos7.0配置命名为test01.xml

[root@localhost ~]# virsh dumpxml centos7.0 > /etc/libvirt/qemu/test01.xml 
  • 虚拟机的删除与添加

作了上面导出配置在作这项,否则虚拟机删除了将需要从新安装,比较耗时间。

删除虚拟机:

[root@localhost ~]# virsh shutdown centos7.0            //关机
域 centos7.0 被关闭
​
[root@localhost ~]# virsh undefine centos7.0            //删除虚拟机
域 centos7.0 已经被取消定义
​
[root@localhost ~]# ls /etc/libvirt/qemu                //查看文件,配置文件被删除,但是磁盘文件不会被删除。
autostart  networks  test01.xml
[root@localhost ~]# virsh list --all                    //查看虚拟机
Id    名称                         状态
----------------------------------------------------

通过备份的配置文件恢复虚拟机:

[root@localhost ~]# cd /etc/libvirt/qemu
[root@localhost qemu]# mv test01.xml centos7.0.xml
[root@localhost qemu]# virsh define centos7.0.xml               //重新定义虚拟机
定义域 centos7.0(从 centos7.0.xml)
​
[root@localhost qemu]# virsh list --all
Id    名称                         状态
----------------------------------------------------
-     centos7.0                      关闭
  • 修改虚拟机而配置信息

用来修改系统内存大小、磁盘文件等信息。

通过vim命令修改
[root@localhost ~]# vim /etc/libvirt/qemu/centos7.0.xml 
或
通过virsh命令修改
[root@localhost ~]# virsh edit centos7.0

KVM文件管理

通过文件管理可以直接查看、修改、复制虚拟机的内部文件。例如,当系统因为配置问题无法启动时,可以直接修改虚拟机的文件。虚拟机磁盘文件有raw、qcow2与qed格式,KVM虚拟机默认使用qcow2格式。这里介绍本地YUM安装libguestfs-tools后产生的命令行工具,这个工具可以直接读取qcow2格式的磁盘文件。

提前配置YUM安装libguestfs-tools工具

[root@localhost ~]# rm -rf /etc/yum.repos.d/*
[root@localhost ~]# vim /etc/yum.repos.d/a.repo
[yum]
name=a
baseurl=file:///media
gpgcheck=0
[root@localhost ~]# eject
[root@localhost ~]# mount /dev/cdrom /media             //挂载系统盘(YUM)
mount: /dev/sr0 写保护,将以只读方式挂载
[root@localhost ~]# yum -y install libguestfs-tools
  • 查看当前磁盘格式
[root@localhost ~]# qemu-img info /data_kvm/store/aaa_kvm.qcow2 
image: /data_kvm/store/aaa_kvm.qcow2
file format: qcow2
virtual size: 20G (21474836480 bytes)
disk size: 1.3G
cluster_size: 65536
Format specific information:
 compat: 1.1
 lazy refcounts: true

如果不是qcow2格式,可以通过"qemu-img"命令转换磁盘文件格式,执行以下操作可以将centos7.0虚拟机raw格式磁盘转换为qcow2格式。

[root@localhost ~]# virsh shutdown centos7.0
[root@localhost ~]# qemu-img convert -f raw -o qcow2 /data_kvm/store/centos7.0.img /data_kvm/store/centos7.0.qcow2

执行转换磁盘格式的命令后还需要修改centos7.0的xml配置文件中磁盘的类型与磁盘文件名。

[root@localhost ~]# virsh edit centos7.0
......//省略部分
<driver name='qemu' type='qcow2'/>                  //raw改为qcow2
<source file='/data_kvm/store/aaa_kvm.qcow2'/>      //raw改为qcow2
......//省略部分
  • virt-cat命令,类似cat命令
[root@localhost ~]# virt-cat -a /data_kvm/store/aaa_kvm.qcow2 /etc/sysconfig/grub 
GRUB_TIMEOUT=5
GRUB_DISTRIBUTOR="$(sed 's, release .*$,,g' /etc/system-release)"
GRUB_DEFAULT=saved
GRUB_DISABLE_SUBMENU=true
GRUB_TERMINAL_OUTPUT="console"
GRUB_CMDLINE_LINUX="crashkernel=auto rd.lvm.lv=cl/root rd.lvm.lv=cl/swap rhgb quiet"
GRUB_DISABLE_RECOVERY="true"
  • virt-edit命令,用于编辑文件,用法和vim基本一致
[root@localhost ~]# virt-edit -a /data_kvm/store/aaa_kvm.qcow2 /etc/resolv.conf 
666666
  • virt-df命令用于查看虚拟机磁盘信息
[root@localhost ~]# virt-df -h centos7.0
文件系统                            大小 已用空间 可用空间 使用百分比%
centos7.0:/dev/sda1                      1014M       106M       908M   11%
centos7.0:/dev/cl/root                     17G       918M        16G    6%

克隆虚拟机

  • 查看虚拟机状态
[root@localhost ~]# virsh list --all
Id    名称                         状态
----------------------------------------------------
-     centos7.0                      关闭
  • 从centos7.0克隆为test01
[root@localhost ~]# virt-clone -o centos7.0 -n test01 -f /data_kvm/store/test01.qcow2
正在分配 'test01.qcow2'                                                                               |  20 GB  00:00:04     
​
成功克隆 'test01'

注:centos7.0为原虚拟机,test01为新虚拟机,test01.qcow2为新虚拟机文件名称。

  • 查看虚拟机状态并启动
[root@localhost ~]# virsh list --all
Id    名称                         状态
----------------------------------------------------
-     centos7.0                      关闭
-     test01                         关闭
​
[root@localhost ~]# virsh start test01
域 test01 已开始

虚拟机快照

KVM虚拟机要使用镜像功能,磁盘格式必须为qcow2

  • 对test01创建快照
[root@localhost ~]# virsh snapshot-create test01
已生成域快照 1656648933
  • 查看虚拟机快照版本信息
[root@localhost ~]# virsh snapshot-current test01
<domainsnapshot>
 <name>1656648933</name>           //快照版本号
 <state>running</state>
......//省略部分信息
  • 查看快照信息
[root@localhost ~]# virsh snapshot-list test01
名称               生成时间              状态
------------------------------------------------------------
1656648933           2022-07-01 12:15:33 +0800 running
  • 创建新快照
[root@localhost ~]# virsh snapshot-create test01
已生成域快照 1656649136
  • 查看快照信息
[root@localhost ~]# virsh snapshot-list test01
名称               生成时间              状态
------------------------------------------------------------
1656648933           2022-07-01 12:15:33 +0800 running
1656649136           2022-07-01 12:18:56 +0800 running
  • 恢复虚拟机状态至1656648933
[root@localhost ~]# virsh snapshot-revert test01 1656648933
  • 删除快照
[root@localhost ~]# virsh snapshot-delete test01 1656648933
已删除域快照 1656648933
posted @   哈喽哈喽111111  阅读(86)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
历史上的今天:
2021-07-14 使用 openssl 生成 https 证书, 并在 nginx 中配置 https
2021-07-14 在k8s中将nginx.conf文件内容创建为ConfigMap挂载到pod容器中
2021-07-14 Docker目录/var/lib/docker/containers文件太大
2021-07-14 Systemd 进程管理教程
2020-07-14 记录阿里云安全组设置遇到的奇葩问题--出口ip
点击右上角即可分享
微信分享提示