From af3b8cb8388a66d3854606135d20c7eb44bc50ba Mon Sep 17 00:00:00 2001 From: yaml <17622739710@163.com> Date: Thu, 19 Jun 2025 09:54:58 +0800 Subject: [PATCH] =?UTF-8?q?=E4=B8=8A=E4=BC=A0=E6=96=87=E4=BB=B6=E8=87=B3?= =?UTF-8?q?=20/?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- KVM.md | 1111 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 1111 insertions(+) create mode 100644 KVM.md diff --git a/KVM.md b/KVM.md new file mode 100644 index 0000000..980bc66 --- /dev/null +++ b/KVM.md @@ -0,0 +1,1111 @@ +## 1.kvm是什么 +kernel virtualization machine 内核虚拟机 + +qemu的二次开发 + +软件全拼 qemu-kvm + +kvm + +virtulbox ovm + +vmware vsphere套件(vmawre-esxi) + +microsoft hyper-V + +## 2.什么是虚拟化 +资源利用 + +资源隔离 + +虚拟化管理: + + 接口 + +命令 + +图形化 + +web管理工具 cockpit + +vps虚拟专用服务器 + + + +## 一、虚拟化技术概述 + 虚拟化[Virtualization]技术最早出现在 20 世纪 60 年代的 IBM 大型机系统,在70年代的 System 370 系列中逐渐流行起来,这些机器通过一种叫虚拟机监控器[Virtual Machine Monitor,VMM]的程序在物理硬件之上生成许多可以运行独立操作系统软件的虚拟机[Virtual Machine]实例。随着近年多核系统、集群、网格甚至云计算的广泛部署,虚拟化技术在商业应用上的优势日益体现,不仅降低了 IT 成本,而且还增强了系统安全性和可靠性,虚拟化的概念也逐渐深入到人们日常的工作与生活中。 + + 虚拟化是一个广义的术语,对于不同的人来说可能意味着不同的东西,这要取决他们所处的环境。在计算机科学领域中,虚拟化代表着对计算资源的抽象,而不仅仅局限于虚拟机的概念。例如对物理内存的抽象,产生了虚拟内存技术,使得应用程序认为其自身拥有连续可用的地址空间[Address Space],而实际上,应用程序的代码和数据可能是被分隔成多个碎片页或段),甚至被交换到磁盘、闪存等外部存储器上,即使物理内存不足,应用程序也能顺利执行。 + +常见的虚拟化软件 + +开源 + + kvm + + xen + + virtulbox + +闭源 + + vmware + + vmware-workstation + + vmware vsphere(vmware esxi)套件 + + 管理界面 + + hypervisor(vmm) + + + + virt-manager + + qemu-kvm + + ovm + + hyper-V + +## 二、主流虚拟化方案介绍 +### 1、虚拟化技术主要分类 ++ 平台虚拟化(Platform Virtualization) 针对计算机和操作系统的虚拟化。 ++ 资源虚拟化(Resource Virtualization) 针对特定的系统资源的虚拟化,比如内存、存储、网络资源等。 ++ 应用程序虚拟化(Application Virtualization) 包括仿真、模拟、解释技术等。 + +### 2、平台虚拟化技术分类 + 我们通常所说的虚拟化主要是指平台虚拟化技术,通过使用控制程序(Control Program,也被称为 Virtual Machine Monitor 或Hypervisor),隐藏特定计算平台的实际物理特性,为用户提供抽象的、统一的、模拟的计算环境(称为虚拟机)。虚拟机中运行的操作系统被称为客户机操作系统(Guest OS),运行虚拟机监控器的操作系统被称为主机操作系统(Host OS),当然某些虚拟机监控器可以脱离操作系统直接运行在硬件之上(如 VMWARE 的 ESX 产品)。运行虚拟机的真实系统我们称之为主机系统。 + +**操作系统级虚拟化(Operating System Level Virtualization)** + + 在传统操作系统中,所有用户的进程本质上是在同一个操作系统的实例中运行,因此内核或应用程序的缺陷可能影响到其它进程。操作系统级虚拟化是一种在服务器操作系统中使用的轻量级的虚拟化技术,内核通过创建多个虚拟的操作系统实例(内核和库)来隔离不同的进程,不同实例中的进程完全不了解对方的存在。 vps 比较著名的有 Solaris Container,FreeBSD Jail 和 OpenVZ 等。 比如OPENVZ:这个平台是最便宜的VPS平台,在各个vps商哪里都是价格最低的。OPENVZ本身运行在linux之上,它通过自己的虚拟化技术把一个服务器虚拟化成多个可以分别安装操作系统的实例,这样的每一个实体就是一个VPS,从客户的角度来看这就是一个虚拟的服务器,可以等同看做一台独立的服务器。 OPENVZ虚拟化出来的VPS只能安装linux操作系统,不能安装windows系统,比如Centos、Fedora、Gentoo、Debian等。不能安装windows操作系统是openvz的第一个缺点,需要使用windows平台的用户不能使用OPENVZVPS。 OPENVZ的第二个缺点是OPENVZ不是完全的虚拟化,每个VPS账户共用母机内核,不能单独修改内核。好在绝大多少用户根本不需要修改内核,所以这个缺点对多数人可以忽略不计。而这一点也正是openvz的优点,这一共用内核特性使得openvz的效率最高,超过KVM、Xen、VMware等平台。在不超售的情况下,openvz是最快速效率最高的VPS平台。 + +**部分虚拟化(Partial Virtualization)** + + VMM 只模拟部分底层硬件,因此客户机操作系统不做修改是无法在虚拟机中运行的,其它程序可能也需要进行修改。在历史上,部分虚拟化是通往全虚拟化道路上的重要里程碑,最早出现在第一代的分时系统 CTSS 和 IBM M44/44X 实验性的分页系统中。 + +**全虚拟化(Full Virtualization)** + + 全虚拟化是指虚拟机模拟了完整的底层硬件,包括处理器、物理内存、时钟、外设等,使得为原始硬件设计的操作系统或其它系统软件完全不做任何修改就可以在虚拟机中运行。 操作系统与真实硬件之间的交互可以看成是通过一个预先规定的硬件接口进行的。全虚拟化 VMM 以完整模拟硬件的方式提供全部接口(同时还必须模拟特权指令的执行过程)。举例而言,x86 体系结构中,对于操作系统切换进程页表的操作,真实硬件通过提供一个特权 CR3 寄存器来实现该接口,操作系统只需执行 "mov pgtable,%%cr3"汇编指令即可。 全虚拟化 VMM 必须完整地模拟该接口执行的全过程。如果硬件不提供虚拟化的特殊支持,那么这个模拟过程将会十分复杂:一般而言,VMM 必须运行在最高优先级来完全控制主机系统,而 Guest OS 需要降级运行,从而不能执行特权操作。当 Guest OS 执行前面的特权汇编指令时,主机系统产生异常(General Protection Exception),执行控制权重新从 Guest OS 转到 VMM 手中。VMM 事先分配一个变量作为影子 CR3 寄存器给 Guest OS,将 pgtable 代表的客户机物理地址(Guest Physical Address)填入影子 CR3 寄存器,然后 VMM 还需要 pgtable 翻译成主机物理地址(Host Physical Address)并填入物理 CR3 寄存器,最后返回到 Guest OS中。随后 VMM 还将处理复杂的 Guest OS 缺页异常(Page Fault)。 比较著名的全虚拟化 VMM 有 Microsoft Virtual PC、VMware Workstation、Sun Virtual Box、Parallels Desktop for Mac 和 QEMU。 + +**超虚拟化(Paravirtualization)** + +这是一种修改 Guest OS 部分访问特权状态的代码以便直接与 VMM 交互的技术。在超虚拟化虚拟机中,部分硬件接口以软件的形式提供给客户机操作系统,这可以通过 Hypercall(VMM 提供给 Guest OS 的直接调用,与系统调用类似)的方式来提供。例如,Guest OS 把切换页表的代码修改为调用 Hypercall 来直接完成修改影子 CR3 寄存器和翻译地址的工作。由于不需要产生额外的异常和模拟部分硬件执行流程,超虚拟化可以大幅度提高性能,比较著名的 VMM 有 Denali、Xen。 + +**硬件辅助虚拟化(Hardware-Assisted Virtualization)** + +硬件辅助虚拟化是指借助硬件(主要是主机处理器)的支持来实现高效的全虚拟化。例如有了 Intel-VT 技术的支持,Guest OS 和 VMM 的执行环境自动地完全隔离开来,Guest OS 有自己的""套寄存器",可以直接运行在最高级别。因此在上面的例子中,Guest OS 能够执行修改页表的汇编指令。Intel-VT 和 AMD-V 是目前 x86 体系结构上可用的两种硬件辅助虚拟化技术。 + +这种分类并不是绝对的,一个优秀的虚拟化软件往往融合了多项技术。例如 VMware Workstation 是一个著名的全虚拟化的 VMM,但是它使用了一种被称为动态二进制翻译的技术把对特权状态的访问转换成对影子状态的操作,从而避免了低效的 Trap-And-Emulate 的处理方式,这与超虚拟化相似,只不过超虚拟化是静态地修改程序代码。对于超虚拟化而言,如果能利用硬件特性,那么虚拟机的管理将会大大简化,同时还能保持较高的性能。 + +## 三、KVM架构解析 +从rhel6开始使用,红帽公司直接把KVM的模块做成了内核的一部分。 + +xen用在rhel6之前的企业版中默认内核不支持,需要重新安装带xen功能的内核 + +KVM 针对运行在 x86 硬件上的、驻留在内核中的虚拟化基础结构。KVM 是第一个成为原生 Linux 内核(2.6.20)的一部分的 hypervisor,它是由 Avi Kivity 开发和维护的,现在归 Red Hat 所有。 + +这个 hypervisor 提供 x86 虚拟化,同时拥有到 PowerPC® 和 IA64 的通道。另外,KVM 最近还添加了对对称多处理(SMP)主机(和来宾)的支持,并且支持企业级特性,比如活动迁移(允许来宾操作系统在物理服务器之间迁移)。 + +KVM 是作为内核模块实现的,因此 Linux 只要加载该模块就会成为一个hypervisor。KVM 为支持 hypervisor 指令的硬件平台提供完整的虚拟化(比如 Intel® Virtualization Technology [Intel VT] 或 AMD Virtualization [AMD-V] 产品)。KVM 还支持准虚拟化来宾操作系统,包括 Linux 和 Windows® + +这种技术由两个组件实现。第一个是可加载的 KVM 模块,当在 Linux 内核安装该模块之后,它就可以管理虚拟化硬件,并通过 /proc 文件系统公开其功能。第二个组件用于 PC 平台模拟,它是由修改版 QEMU 提供的。QEMU 作为用户空间进程执行,并且在来宾操作系统请求方面与内核协调。 + +当新的操作系统在 KVM 上启动时(通过一个称为 KVM 的实用程序),它就成为宿主操作系统的一个进程,因此就可以像其他进程一样调度它。但与传统的 Linux 进程不一样,来宾操作系统被 hypervisor 标识为处于 "来宾" 模式(独立于内核和用户模式)。 + +每个来宾操作系统都是通过 /dev/KVM 设备映射的,它们拥有自己的虚拟地址空间,该空间映射到主机内核的物理地址空间。如前所述,KVM 使用底层硬件的虚拟化支持来提供完整的(原生)虚拟化。I/O 请求通过主机内核映射到在主机上(hypervisor)执行的 QEMU 进程。 + +KVM 在 Linux 环境中以主机的方式运行,不过只要底层硬件虚拟化支持,它就能够支持大量的来宾操作系统. + +## 四、KVM软件安装 +### 1、 环境准备 +ip固定 + +1.虚拟化功能打开 + +2.硬盘不能太小 + +3.cpu不能太少 2+ + +4.往里面放一个测试镜像 放一个centos7的小镜像 + +### 2、 查看CPU是否支持VT技术 +[root@qfedu.com ~]# cat /proc/cpuinfo | grep -E 'vmx|svm' + +### 3、清理环境:卸载KVM +```powershell +[root@qfedu.com ~]# yum remove `rpm -qa | egrep 'qemu|virt|KVM'` -y +[root@qfedu.com ~]# rm -rf /var/lib/libvirt /etc/libvirt/ +``` + +### 4、安装软件 +**Centos6** + + [root@qfedu.com ~]# yum groupinstall "Virtualization" "Virtualization Client" "Virtualization Platform" "Virtualization Tools" -y + +**Centos7** + +[root@qfedu.com ~]# yum install *qemu* *virt* -y + +qemu-kvm: 主包 + +libvirt:API接口 + +virt-manager:图形管理程序 + +**Centos9** + +yum 组安装已经可以使用了问题:在进行组安装的时候可能会出现关于rpm版本的错误问题解决: + +#yum upgrade rpm -y + +# yum grouplist + +组安装成功之后还是要单独安装virt-manager工具 + +### 5、启动服务 +[root@qfedu.com ~]# systemctl start libvirtd + +### 6、查看KVM模块加载 +```powershell +[root@qfedu.com ~]# lsmod | grep -i kvm +kvm_intel 53484 3 +kvm 316506 1 kvm_intel +``` + +## 五、GuestOS安装 ++ **图形方式(非常重要 非常简单)** ++ **完全文本模式(现场配置虚拟机的规格)** 并不是自动化的 还是交互式的操作 ++ **命令行模式(重中之重 最常用 模板镜像+配置文件 方式配置规格)** ++ **通过飞机驾驶舱(cockpit)安装和管理虚拟机** + +```powershell +# yum install *cockpit* -y +# systemctl start cockpit +# yum install cockpit-machines -y +``` + +访问: 浏览器访问 服务器地址:9090 + +问题:centos-stream9中cockpit安装guestos时不能使用键盘(未知bug) + +### 1、图形模式安装Guest OS +[root@qfedu.com ~]# virt-manager + +**centos-stream8 bug** + +如果进行了批量的软件升级操作,kvm在安装guestos的时候会报如下错误 + +error: internal error: unknown feature amd-sev-es + +解决方案如下(wing已测) + +```powershell +# mkdir -p /etc/qemu/firmware +# touch /etc/qemu/firmware/50-edk2-ovmf-cc.json +# systemctl restart libvirtd +``` + +### 2、完全文本方式安装 +注意:**不需要讲,了解即可** + +**极端情况-服务器没有图形 客户端也没有图形** + +```powershell +# virt-install --connect qemu:///system -n vm6 -r 512 --disk path=/virhost/vmware/vm6.img,size=7 --os-type=linux --os-variant=rhel6 --vcpus=1 --network bridge=br0 --location=http://127.0.0.1/rhel6u4 -x console=ttyS0 --nographics + +#virt-install --connect qemu:///system -n vm9 -r 2048 --disk path=/var/lib/libvirt/images/vm9.img,size=7 --os-type=linux --os-variant=centos7.0 --vcpus=1 --location=ftp://192.168.100.230/centos7u3 -x console=ttyS0 --nographics +``` + +**注意:** + +1. 用这种方式安装的操作系统,大小写会胡乱变化,不影响远程操作 +2. 内存必须2G以上 + +**查看KVM支持的OS版本:** + +```powershell +[root@qfedu.com ~]# man virt-install +[root@qfedu.com ~]# osinfo-query os | grep centos +``` + +**排错:** + +安装过程中: + +手动配置IP地址 + +到url位置找不到路径,要返回去手动选择url,重新配置url为ftp://192.168.100.230/rhel6u4,这里的ip不要写127.0.0.1而是br0的ip + +给虚拟机指定的内存必须大于2048M,不然报错如下: dracut-initqueue[552]: /sbin/dmsquash-live-root: line 273: printf: write error: No space left on device + +**逃脱符:** + +Escape character is ^] + +### 3、命令行模式安装 +**虚拟机的组成部分** + +1. **虚拟机配置文件** + +```powershell +[root@qfedu.com ~]# ls /etc/libvirt/qemu +networks vm1.xml +``` + +1. **储存虚拟机的介质** + +```powershell +[root@qfedu.com ~]# ls /var/lib/libvirt/images/ +vm1.img +``` + +**根据配置文件创建虚拟机** + +```powershell +1.需要有磁盘镜像文件: +[root@qfedu.com ~]# cp vm1.img vm2.img + +2.需要有配置文件 +[root@qfedu.com ~]# cp vm1.xml vm2.xml + +3.配置文件需要修改必要的内容 + +4.创建虚拟机: +[root@qfedu.com ~]# virsh define /etc/libvirt/qemu/vm2.xml +``` + +****: allocate 英[ˈæləkeɪt] 美[ˈæləkeɪt] + +拨…(给); 划…(归); 分配…(给); + +[例句]Tickets are limited and will be allocated to those who apply first + +票数有限,先申请者先得。 + +### 4、实例 +**模板镜像+配置文件 方式创建虚拟机** + +```powershell +1.拷贝模板镜像和配置文件 +[root@qfedu.com ~]# cp /var/lib/libvirt/images/vm2.img /var/lib/libvirt/images/vm3.img +[root@qfedu.com ~]# cp /etc/libvirt/qemu/vm2.xml /etc/libvirt/qemu/vm3.xml + +2.修改配置文件 +[root@qfedu.com ~]# vim /etc/libvirt/qemu/vm3.xml + +vm3 #虚拟机的名称 + a2f62549-c6b7-4b8f-a8e2-c14edda35a78 # 虚拟机的uuid + 2099200 # 虚拟机能使用的最大内存 + 2099200 # 虚拟机使用的当前内存 和上面的内存配置保持一致 + 2 # cpu核心数 + + hvm + + + + + + + + Haswell-noTSX + + + + + + + destroy + restart + destroy + + + + + + /usr/libexec/qemu-KVM + + + #磁盘镜像文件类型 + #磁盘镜像文件的路径 + # vda是系统内磁盘逻辑名称 +
+ #slot需要修改成0x00 + + #如果需要添加磁盘,只需添加如下配置即可 + + + +
+ + + +
+ + + +
+ + + +
+ + + +
+ + + + +
+ + + + # mac地址,只能修改后3段 + # default为所使用的网络的名字 + +
+ # slot需要修改成0x00 + + + + + + + + + + + + + + +
+ + + + +
+ + + +``` + +# KVM管理 +## 一、GuestOS安装问题解析 +**问题1**:用图形安装guest os的时候卡住不动 + +```powershell +解决:升级系统 +[root@qfedu.com ~]# yum upgrade -y +``` + +**问题2**:升级系统后安装guest os的时候还是卡住不动 + +解决:需要在安装宿主机的时候安装兼容性程序(有的同学就没有安装也可以使用,这可能是bug) + +**问题3**:如果安装了各种兼容程序之后还是不行 + +如果所有问题都排查过后还是安装不上guestos,最后的原因就是在安装宿主机系统的时候各种兼容性软件没有安装而且Yum也没有自动处理导致的 + +## 二、GuestOS升级配置 +1. **修改配置文件(比如添加磁盘,那就添加如下配置)** + +```powershell + + + + +
+ +``` + +特别注意:centos7直接把slot修改成0x00就可以,centos8/9里面硬盘和网卡的添加已经不能修改slot了,要求修改的是bus地址,把bus修改成bus='0x00',kvm会自动修改到合适的值 + +1. **创建新的空磁盘卷** + +[root@qfedu.com ~]# qemu-img create -f qcow2 vm3-1.qcow2 10G + +1. **重新定义** + +[root@qfedu.com ~]# virsh define /etc/libvirtd/qemu/vm3.xml + +## 三、KVM存储 +**概念** + +KVM必须要配置一个目录当作他存储磁盘镜像(存储卷)的目录,我们称这个目录为存储池 + +**默认存储池** + +/var/lib/libvirt/images/ + +SAN NAS DAS + +scsi 光纤交换机 光纤 光纤模块 专业存储 + +ide sata sas scsi + +ipsan iscsi + +分布式文件系统 + + 可扩展性强 + + 安全 trunk 128M 64M hdfs + + glusterfs 简单 + + ceph 私有云 公有云 底层存储 + + hdfs 大数据平台hadoop里面默认的分布式文件系统 + +### 1、存储池管理 +```powershell +1.创建基于文件夹的存储池(目录) +[root@qfedu.com ~]# mkdir -p /data/vmfs + +2.定义存储池与其目录 +[root@qfedu.com ~]# virsh pool-define-as vmdisk --type dir --target /data/vmfs + +3.创建已定义的存储池 +(1) 创建已定义的存储池 +[root@qfedu.com ~]# virsh pool-build vmdisk + +(2) 查看已定义的存储池,存储池不激活无法使用。 +#virsh pool-list --all + +4.激活并自动启动已定义的存储池 + [root@qfedu.com ~]# virsh pool-start vmdisk + [root@qfedu.com ~]# virsh pool-autostart vmdisk + + 这里vmdisk存储池就已经创建好了,可以直接在这个存储池中创建虚拟磁盘文件了。 + +5.在存储池中创建虚拟机存储卷 2种方法 + # virsh vol-create-as vmdisk oeltest03.qcow2 20G --format qcow2 + # qemu-img create -f qcow2 vm4.qcow2 20G + + 注1:KVM存储池主要是体现一种管理方式,可以通过挂载存储目录,lvm逻辑卷的方式创建存储池,虚拟机存储卷创建完成后,剩下的操作与无存储卷的方式无任何区别了。 + + 注2:KVM存储池也要用于虚拟机迁移任务。 + +6.存储池相关管理命令 + (1)在存储池中删除虚拟机存储卷 + [root@qfedu.com ~]# virsh vol-delete --pool vmdisk oeltest03.qcow2 + + (2)取消激活存储池 + [root@qfedu.com ~]# virsh pool-destroy vmdisk + + (3)删除存储池定义的目录/data/vmfs + [root@qfedu.com ~]# virsh pool-delete vmdisk + + (4)取消定义存储池 + [root@qfedu.com ~]# virsh pool-undefine vmdisk +``` + +到此KVM存储池配置与管理操作完毕。 + +### 2、生产环境存储池使用 +添加lvm和远程存储即可 + +### 3、磁盘格式 +1. **磁盘镜像文件格式** + +raw + +原始格式,性能最好 + +qcow + +先去网上了解一下cow(写时拷贝copy on write) ,性能远不能和raw相比,所以很快夭折了,所以出现了qcow2 + +qcow2 + +性能上还是不如raw,但是raw不支持快照,qcow2支持快照。 + +qed + +现在默认安装好的用的是raw格式,所有做快照要把他转换成qcow2格式 + +什么叫写时拷贝? + +raw立刻分配空间,不管你有没有用到那么多空间 + +qcow2只是承诺给你分配空间,但是只有当你需要用空间的时候,才会给你空间。最多只给你承诺空间的大小,避免空间浪费 + +工作当中用哪个?看你用不用快照。 + +工作当中虚拟机会有多个备份,一个坏了,再起一个就行了,所有没必要用快照。当然也不一定。数据绝对不会存储到本地。 + +1. **创建磁盘文件** + +```powershell +建立qcow2格式磁盘文件: +#qemu-img create -f qcow2 test.qcow2 20G + +建立raw格式磁盘文件: +#qemu-img create -f raw test.raw 20G + +查看已经创建的虚拟磁盘文件: +#qemu-img info test.qcow2 +``` + +### 4、挂载磁盘 +作为虚拟化环境管理员,你肯定遇到过虚拟机无法启动的情况。实施排错时,你需要对虚拟机的内部进行检查。而Libguestfs Linux工具集可以在这种情况下为你提供帮助。 + +利用Libguestfs找出损坏的虚拟机文件 + +Libguestfs允许在虚拟机上挂载任何类型的文件系统,以便修复启动故障。 + +使用Libguestfs,首先需要使用Libvirt。Libvirt是一个管理接口,可以和KVM、Xen和其他一些基于Liunx的虚拟机相互连接。Libguestfs的功能更加强大,可以打开Windows虚拟机上的文件。但是首先你需要将虚拟机迁移到libguestfs可用的环境当中,也就是Linux环境。 + +假如你是vmware的ESXI虚拟机,为了将虚拟机迁移到Linux当中,你可以使用SSH连接到ESXi主机,这意味着你首先需要启用ESXi主机上的SSH访问方式。完成之后,在Linux平台上运行下面的scp命令: + +```powershell +查看磁盘镜像分区信息: +[root@qfedu.com ~]# virt-df -h -d vm1 + Filesystem Size Used Available Use% + vm1:/dev/sda1 484M 32M 428M 7% + vm1:/dev/sdb1 3.5G 3.5G 0 100% + vm1:/dev/VolGroup/lv_root 6.1G 1.1G 4.7G 18% + +[root@qfedu.com ~]# virt-filesystems -d vm1 + /dev/sda1 + /dev/sdb1 + /dev/VolGroup/lv_root + +挂载磁盘镜像分区: +[root@qfedu.com ~]# guestmount -d vm1 -m /dev/vda1 --rw /mnt +``` + +注: + +mtab文件在centos7的启动过程中非常有用,删掉会导致不能启动 + +## 四、KVM管理 +### 1、KVM基本管理 +**查看 启动 关闭 重启 重置 ** + +```powershell +查看虚拟机: +[root@qfedu.com ~]# virsh list +Id Name State ---------------------------------------------------- 2 vm1 running + +[root@qfedu.com ~]# virsh list --all +Id Name State ---------------------------------------------------- 2 vm1 running +查看KVM虚拟机配置文件(X): +[root@qfedu.com ~]# virsh dumpxml name + +将node4虚拟机的配置文件保存至node6.xml(X): +[root@qfedu.com ~]# virsh dumpxml node4 > /etc/libvirt/qemu/node6.xml + +修改node6的配置文件(X): +[root@qfedu.com ~]# virsh edit node6 +如果直接用vim编辑器修改配置文件的话,需要重启libvirtd服务启动: + +[root@qfedu.com ~]# virsh start vm1 +Domain vm1 started +暂停虚拟机: +[root@qfedu.com ~]# virsh suspend vm_name +恢复虚拟机: +[root@qfedu.com ~]# virsh resume vm_name +关闭: +方法1: +[root@qfedu.com ~]# virsh shutdown vm1 +Domain vm1 is being shutdown + +方法2(X): +[root@qfedu.com ~]# virsh destroy vm1 +Domain vm1 destroyed + +重启: +[root@qfedu.com ~]# virsh reboot vm1 +Domain vm1 is being reboote + +重置: +[root@qfedu.com ~]# virsh reset vm1 +Domain vm1 was reset + +删除虚拟机: +[root@qfedu.com ~]# virsh undefine vm2 +Domain vm2 has been undefined +注意:虚拟机在开启的情况下undefine是无法删除的,但是如果再destroy会直接被删除掉虚拟机开机自动启动: [root@qfedu.com ~]# virsh autostart vm1 域 vm1标记为自动开始 +[root@qfedu.com ~]# ls /etc/libvirt/qemu/autostart/ //此目录默认不存在,在有开机启动的虚拟机时自动创建 vm1.xml +[root@qfedu.com ~]# virsh autostart --disable vm1 +域 vm1取消标记为自动开始 + +查看所有开机自启的guest os: +[root@qfedu.com ~]# ls /etc/libvirt/qemu/autostart/ +[root@qfedu.com ~]# virsh list --all --autostart + +# virsh domifaddr vm2 //这个命令有的时候在7里面有bug,看不到任何信息 + Name MAC address Protocol Address +------------------------------------------------------------------------------- + vnet0 52:54:00:0a:d8:42 ipv4 192.168.122.135/24 +``` + +### 2、虚拟机克隆 +**1.图形界面** + + Applications (左上角)-----> System Tools ------>Virtual Machine Manager + +关闭要克隆的虚拟机,右键点击虚拟机选择Clone + +**2.字符终端,命令克隆** + +```powershell +[root@qfedu.com ~]# virt-clone -o vm1 --auto-clone + WARNING 设置图形设备端口为自动端口,以避免相互冲突。 正在分配 'vm1-clone.qcow2' | 6.0 GB 00:00:05 成功克隆 'vm1-clone'。 -o origin + + [root@qfedu.com ~]# virt-clone -o vm1 -n vm2 --auto-clone + WARNING 设置图形设备端口为自动端口,以避免相互冲突。 正在分配 'vm2.qcow2' | 6.0 GB 00:00:06 成功克隆 'vm2'。 + + [root@qfedu.com ~]# virt-clone -o vm1 -n vm2 -f /var/lib/libvirt/images/vm2.img + 正在克隆 vm1.img | 8.0 GB 01:03 Clone 'vm2' created successfully. +``` + +### 3、增量镜像 +注意:扩展内容,了解即可 + +**1、概述** + +通过一个基础镜像(node.img),里面把各个虚拟机都需要的环境都搭建好,然后基于这个镜像建立起一个个增量镜像,每个增量镜像对应一个虚拟机,虚拟机对镜像中所有的改变都记录在增量镜像里面,基础镜像始终保持不变。 + +功能: + +节省磁盘空间,快速复制虚拟机。 + +环境: + +基本镜像文件:node.img 虚拟机ID:node + +增量镜像文件:node4.img 虚拟机ID:node4 + +要求: + +以基本镜像文件node.img为基础,创建一个镜像文件node4.img,以此创建一个虚拟机node4,虚拟机node4的改变将存储于node4.img中。 + +**2、创建增量镜像文件** + +```powershell +[root@qfedu.com ~]# qemu-img create -b node.img -f qcow2 node4.img +[root@qfedu.com ~]# qemu-img info node4.img image: node4.imgfile format: qcow2virtual size: 20G (21495808000 bytes)disk size: 33Mcluster_size: 65536backing file: node.img (actual path: node.img) +``` + +注:该实验只是针对qcow2格式的镜像文件,未测试raw格式的镜像文件是否可行。 + +**3、创建虚拟机node4的XML配置文件** + +```powershell +[root@qfedu.com ~]# cp /etc/libvirt/qemu/node.xml /etc/libvirt/qemu/node4.xml +[root@qfedu.com ~]# vim /etc/libvirt/qemu/node4.xml + node4 #node4的虚拟机名,须修改,否则与基本虚拟机冲突 4b7e91eb-6521-c2c6-cc64-c1ba72707fe4 #node4的UUID,必须修改,否则与基本虚拟机冲突 524288 524288 2 hvm destroy restart restart /usr/libexec/qemu-KVM #将原指向/virhost/KVM_node/node.img改为node4.img
#修改网卡MAC,防止冲突
#修改网卡MAC,防止冲突