部署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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享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