一、虚拟化技术概述
虚拟化[Virtualization]技术最早出现在20世纪60年代的IBM大型机系统,在70年代的System370系列中逐渐流行起来,这些机器通过一种叫虚拟机监控器[VirtualMachineMonitor,VMM]的程序在物理硬件之上生成许多可以运行独立操作系统软件的虚拟机[VirtualMachine]实例。随着近年多核系统、集群、网格甚至云计算的广泛部署,虚拟化技术在商业应用,上的优势日益体现,不仅降低了IT成本,而且还增强了系统安全性和可靠性,虚拟化的概念也逐渐深入到人们日常的工作与生活中。
虚拟化是一个广义的术语,对于不同的人来说可能意味着不同的东西,这要取决他们所处的环境。在计算机科学领域中,虚拟化代表着对计算资源的抽象,而不仅仅局限于虚拟机的概念。例如对物理内存的抽象,产生了虚拟内存技术,使得应用程序认为其自身拥有连续可用的地址空间[AddressSpace],而实际上,应用程序的代码和数据可能是被分隔成多个碎片页或段),甚至被交换到磁盘、闪存等外部存储器上,即使物理内存不足,应用程序也能顺利执行。
二、主流虚拟化方案介绍
1、虚拟化技术主要分类
- 平台虚拟化(PlatformVirtualization)
针对计算机和操作系统的虚拟化。
- 资源虚拟化(ResourceVirtualization)
针对特定的系统资源的虚拟化,比如内存、存储、网络资源等。
- 应用程序虚拟化(ApplicationVirtualization)
2、平台虚拟化技术分类
我们通常所说的虚拟化主要是指平台虚拟化技术,通过使用控制程序(ControlProgram,也被称为VirtualMachineMonitor或Hypervisor),隐藏特定计算平台的实际物理特性,为用户提供抽象的、统一的、模拟的计算环境(称为虚拟机)。虚拟机中运行的操作系统被称为客户机操作系统(GuestOS),运行虚拟机监控器的操作系统被称为主机操作系统(HostOS),当然某些虚拟机监控器可以脱离操作系统直接运行在硬件之上(如VMWARE的ESX产品)。运行虚拟机的真实系统我们称之为主机系统。
操作系统级虚拟化(OperatingSystemLevelVirtualization)
在传统操作系统中,所有用户的进程本质上是在同一个操作系统的实例中运行,因此内核或应用程序的缺陷可能影响到其它进程。操作系统级虚拟化是一种在服务器操作系统中使用的轻量级的虚拟化技术,内核通过创建多个虚拟的操作系统实例(内核和库)来隔离不同的进程,不同实例中的进程完全不了解对方的存在。
比较著名的有SolarisContainer,FreeBSDJail和OpenVZ等。
比如OPENVZ:这个平台是最便宜的VPS平台,在各个vps商那里都是价格最低的。OPENVZ本身运行在linux之上,它通过自己的虚拟化技术把一个服务器虚拟化成多个可以分别安装操作系统的实例,这样的每一个实体就是一个YPS,从客户的角度来看这就是一个虚拟的服务器,可以等同看做一台独立的服务器。OPENVZ虚拟化出来的VPS只能安装linux操作系统,不能安装windows系统,比如Centos、Fedora、Gentoo、Debian等。不能安装windows操作系统是openvz的第一个缺点,需要使用windows平台的用户不能使用OPENVZVPS。
OPENVZ的第二个缺点是OPENVZ不是完全的虚拟化,每个YPS账户共用母机内核,不能单独修改内核。好在绝大多少用户根本不需要修改内核,所以这个缺点对多数人可以忽略不计。而这一点也正是qpenvz的优点,这一共用内核特性使得qpenvz的效率最高,超过KVM、Xen、VMware等平台。在不超售的情况下,openvz是最快速效率最高的VPS平台。
部分虚拟化(PartialVirtualization)
VMM只模拟部分底层硬件,因此客户机操作系统不做修改是无法在虚拟机中运行的,其它程序可能也需要进行修改。在历史上,部分虚拟化是通往全虚拟化道路上的重要里程碑,最早出现在第一代的分时系统CTSS和IBMM44/44X实验性的分页系统中。
全虚拟化(FullVirtualization)
全虚拟化是指虚拟机模拟了完整的底层硬件,包括处理器、物理内存、时钟、外设等,使得为原始硬件设计的操作,系统或其它系统软件完全不做任何修改就可以在虚拟机中运行。
操作系统与真实硬件之间的交互可以看成是通过一个预先规定的硬件接口进行的。全虚拟化VMM以完整模拟硬件的方式提供全部接口(同时还必须模拟特权指令的执行过程)。举例而言,x86体系结构中,对于操作系统切换进程页表的操作,真实硬件通过提供一个特权CR3寄存器来实现该接口,操作系统只需执行”movpgtable,%%cr3”汇编指令即可。
全虚拟化VMM必须完整地模拟该接口执行的全过程。如果硬件不提供虚拟化的特殊支持,那么这个模拟过程将会十分复杂:一般而言,VMM必须运行在最高优先级来完全控制主机系统,而GuestOS需要降级运行,从而不能执行特权操作。当GuestOS执行前面的特权汇编指令时,主机系统产生异常(GeneralProtectionException),执行控制权重新从GuestOS转到VMM手中。VMM事先分配一个变量作为影子CR3寄存器给GuestOS,将pgtable代表的客户机物理地址(GuestPhysicalAddress)填入影子CR3寄存器,然后VMM还需要pgtable翻译成主机物理地址(HostPhysicalAddress)并填入物理CR3寄存器,最后返回到GuestOS中。随后VMM还将处理复杂的GuestOS缺页异常(PageFault)。
比较著名的全虚拟化VMM有MicrosoftVirtualPC、VMwareWorkstation.SunVirtualBox、Parallels 、DesktopforMac和QEMU。
超虚拟化(Paravirtualization)
这是一种修改GuestOS部分访问特权状态的代码以便直接与VMM交互的技术。在超虚拟化虚拟机中,部分硬件接口以软件的形式提供给客户机操作系统,这可以通过Hypercall(VMM提供给GuestOS的直接调用,与系统调用类似)的方式来提供。例如,GuestOS把切换页表的代码修改为调用Hypercall来直接完成修改影子CR3寄存器和翻译地址的工作。由于不需要产生额外的异常和模拟部分硬件执行流程,超虚拟化可以大幅度提高性能,比较著名的VMM有Denali、Xen。
硬件辅助虚拟化(Hardware-AssistedVirtualization)
硬件辅助虚拟化是指借助硬件(主要是主机处理器)的支持来实现高效的全虚拟化。例如有了Intel-VT技术的支持,GuestOS和VMM的执行环境自动地完全隔离开来,GuestOS有自己的””套寄存器”,可以直接运行在最高级别。因此在上面的例子中,GuestOS能够执行修改页表的汇编指令。Intel-VT和AMD-V是目前x86体系结构上可用的两种硬件辅助虚拟化技术。
这种分类并不是绝对的,一个优秀的虚拟化软件往往融合了多项技术。例如VMwareWorkstation是一个著名的全虚拟化的VMM,但是它使用了一种被称为动态二进制翻译的技术把对特权状态的访问转换成对影子状态的操作,从而避免了低效的Trap-And-Emulate的处理方式,这与超虚拟化相似,只不过超虚拟化是静态地修改程序代码。对于超虚拟化而言,如果能利用硬件特性,那么虚拟机的管理将会大大简化,同时还能保持较高的性能。
三、KVM技术简介
资源与参考资料Redhat官方文档
https://access.redhat.com/documentation
Virtualization Getting Started Guide
Virtualization Deployment and Administration Guide
Virtualization Tuning and Optimization Guide
Virtualization Security Guide
KVM主页
http://www.linux-kvm.org/
提供了KVM的详细信息,以及大量信息来源和相关站点的链接
libvirt Virtualization API网站
http://www.libvirt.org/
提供了有关该API、所支持的虚拟化抽象及其使用的XML格式的详细信息。
1、KVM架构
2、kvm架构解析
从rhel6开始使用,红帽公司直接把KVM的模块做成了内核的一部分。
xen用在rhel6之前的企业版中默认内核不支持,需要重新安装带xen功能的内核
KVM针对运行在x86硬件上的、驻留在内核中的虚拟化基础结构。KVM是第一个成为原生Linux内核(2.6.20)的一部分的hypervisor,它是由AviKivity开发和维护的,现在归RedHat所有。
这个hypervisor提供x86虚拟化,同时拥有到PowerPC⑧和IA64的通道。另外,KVM最近还添加了对对称多处理(SMP)主机(和来宾)的支持,并且支持企业级特性,比如活动迁移(允许来宾操作系统在物理服务器之间迁移)。
KVM是作为内核模块实现的,因此Linux只要加载该模块就会成为一个hypervisor。KVM为支持hypervisor指令的硬件平台提供完整的虚拟化(比如Intel⑧VirtualizationTechnology[IntelVT]或AMDVirtualization[AMD-V]产品)。KVM还支持准虚拟化来宾操作系统,包括Linux和Windows@。
这种技术由两个组件实现。第一个是可加载的KVM模块,当在Linux内核安装该模块之后,它就可以管理虚拟化硬件,并通过/proc文件系统公开其功能。第二个组件用于PC平台模拟,它是由修改版QEMU提供的。QEMU作为用户空间进程执行,并且在来宾操作系统请求方面与内核协调。
当新的操作系统在KVM上启动时(通过一个称为KVM的实用程序),它就成为宿主操作系统的一个进程,因此就可以像其他进程一样调度它。但与传统的Linux进程不一样,来宾操作系统被hypervisor标识为处于”来宾”模式(独立于内核和用户模式)。
每个来宾操作系统都是通过/dev/KVM设备映射的,它们拥有自己的虚拟地址空间,该空间映射到主机内核的物理地址空间。如前所述,KVM使用底层硬件的虚拟化支持来提供完整的(原生)虚拟化。1/0请求通过主机内核映射到在主机上(hypervisor)执行的QEMU进程。
KVM在Linux环境中以主机的方式运行,不过只要底层硬件虚拟化支持,它就能够支持大量的来宾操作系统.
四、KVM软件安装
1、环境准备
2、查看CPU是否支持VT技术
# vmx指当前CPU支持intel虚拟化,svm指支持ADM[root@foo~]# cat /proc/cpuinfo | grep -E 'vmx|svm'
3、清理环境:卸载KVM
[root@foo~]# yum remove `rpm -qa | egrep 'qemu|virt|KVM'` -y# 存储磁盘镜像目录 /var/lib/libvirt[root@foo~]# rm -rf /var/1ib/libvirt /etc/1ibvirt/
4、安装软件
Centos6
[root@foo~]# yum group install "Virtualization" "VirtualizationClient" "VirtualizationPlatform" "VirtualizationTools" -y
Centos7
[root@foo~]# uname -r3.10.0-1062.e17.x86_64[root@foo~]# yum install *qemu* *virt* librbdl-devel-y(在安装虚拟机出错的情况下,一般是操作系统的版本问题)[root@foo~]# yum upgrade
gemu-KVM:主包
libvirt:API接口
virt-manager:图形管理程序
在所谓的kvm技术中,应用到的其实有2个东西:qemu+kvm
kvm负责cpu虚拟化+内存虚拟化,实现了cpu和内存的虚拟化,但kvm不能模拟其他设备;
qemu是模拟IO设备(网卡,磁盘),kvm加上qemu之后就能实现真正意义上服务器虚拟化。
因为用到了上面两个东西,所以一般都称之为qemu-kvm。
libvirt则是调用kvm虚拟化技术的接口用于管理的,用libvirt管理方便
Centos8
yum 组安装已经可以使用了
问题:在进行组安装的时候会出现关于rpm版本的错误问题
解决:
[root@foo~]# yum upgrade rpm -y[root@foo~]# yum install virt-manager
5、启动服务
[root@foo~]# systemct1 start libvirtd
6、查看KVM模块加载
[root@foo~]# lsmod | grep KVMKVM_intel 53484 3KVM 316506 1 KVM_intel
五、GuestOS的安装
- 图形方式(非常重要非常简单)
- 完全文本模式(现场配置虚拟机的规格)
- 命令行模式(重中之重最常用模板镜像+配置文件方式配置规格)
- 通过飞机驾驶舱(web界面的应用)安装和管理虚拟机
[root@foo~]# yum install cockpit -y[root@foo~]# systemct1 start cockpit
访问: 浏览器访问 服务器地址:9090
1、图形模式安装GuestOS
[root@foo~]# virt-manager
2、命令行模式安装
极端情况-服务器没有图形客户端也没有图形
virt-install --connectqemu:///system -n vm6 -r 512 --disk path=/virhost/vmware/vm6.img,size=7 --os-type=1inux --os-variant=rhe16 --vcpus=1 --network bridge=br0 --location=http://127.0.0.1/rhe16u4 -x console=ttyS0 --nographicsvirt-install --connect qemu:///system -n vm9 -r 2048 --disk path=/var/lib/1ibvirt/images/vm9.img,size=7 --os-type=1inux --os-variant=centos7.0 --vcpus=1 --location=ftp://192.168.100.230/centos7u3 -x console=ttyS0 --nographics
—connectqumu 连接虚拟系统 也就是 hypervisor
-n 虚拟机name
-r 内存 RAM 单位m
—disk path 磁盘镜像路径
size 磁盘大小
—os-type 系统类型
—os-variant 系统版本
—cpus cpu数量
—location 安装服务器 需要将镜像挂载到ftp服务器上
-x 分配一个终端
—nographics 无图形界面
注意:
1.用这种方式安装的操作系统,大小写会胡乱变化,不影响远程操作
2.内存必须2G以上
查看KVM支持的OS版本:
[root@foo~]# man virt-install[root@foo~]# 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: line273: printf: write error: No space left on device
逃脱符:
Escape character is ^]
Kickstart安装
Kickstart是一种无人值守的安装方式
如果在安装过程中出现要填写参数的情况,安装程序首先会去查找
Kickstart生成的文件,如果找到合适的参数,就采用所找到的参数;
如果没有找到合适的参数,便需要安装者手工干预了
virt-install\--name=vm1\--disk path=/vm/vm1 -disk1.qcow2\--vcpus=1--ram=1024\--network network=default\--graphics vnc,listen=0.0.0.0\--os-type=linux\--os-variant=rhel6\--location /iso/Centos-6.4-i386-bin-DVD1.iso\--extra-args="ks=http://192.168.1.11/mini.txt"
PXE安装
virt-install --hvm --connect qemu:///system \--network=bridge:br0--pxe --graphics spice\--name=rhe16-machine --ram=756 --vcpus=4\--os-type=linux --os-variant=rhel6\--disk path=/var/lib/libvirt/images/rhel6-machine.img,size=10
3、文本模式安装
虚拟机的组成部分
1.虚拟机配置文件
[root@foo~]# ls /etc/1ibvirt/qemunetwork svm1.xml
2.储存虚拟机的介质
[root@foo~]# ls /var/lib/1ibvirt/images/vm1.img
根据配置文件创建虚拟机
1.拷贝模板镜像和配置文件[root@foo~]# cp vm1.img vm2.img[root@foo~]# cp vm1.xm1 vm2.xm12.修改配置文件vim /etc/1ibvirt/qemu/vm2.xm13.创建虚拟机:[root@foo~]# virsh define /etc/1ibvirt/qemu/vm2.xm14.重启一下:[root@foo~]# systemctl restart libvirtd5.宿主机开启路由转发:[root@foo~]# vim /etc/sysct1.confnet.ipv4.ip_forward=16.sysctl -p 从指定的文件加载系统参数,如不指定即从/etc/sysctl.conf中加载[root@foo~]# sysctl -p # 查看路由转发是否开启,未开启需要开启net.ipv4.ip_forward =1
4、实例
模板镜像+配置文件方式创建虚拟机
#1.拷贝模板镜像和配置文件[root@foo~]# cp /var/1ib/1ibvirt/images/vm2.img /var/lib/libvirt/images/vm3.img[root@foo~]# cp /etc/1ibvirt/qemu/vm2.xm1 /etc/1ibvirt/qemu/vm3.xm1#2.修改配置文件[root@foo~]# vim /etc/1ibvirt/qemu/vm3.xm1<domain type='KVM'><name>vm3</name>/* 修改项 */<uuid>a2f62549-c6b7-4b8f-a8e2-c14edda35a78</uuid><memory unit='KiB'>2099200</memory><currentMemory unit='KiB'>2099200</currentMemory><vcpu placement='static'>2</vcpu><os><type arch='x86_64' machine='pc-i440fx-rhe17.0.0'>hvm</type><boot dev='hd'/></os><features><acpi/><apic/></features><cpu mode='custom' match='exact' check='partial'><model fallback='allow'>Haswe11-noTSX</model></cpu><clock offset='utc'><timer name='rtc' tickpolicy='catchup'/><timer name='pit' tickpelicy='delay'/><timer name='hpet'present='no'/></clock><on_poweroff>destroy</on_poweroff><on_reboot>restart</on_reboot><on_crash>destroy</on_crash><pm><suspend-to-mem enab1ed='no'/><suspend-to-disk enab1ed='no'/>I</pm><devices><emulator>/usr/1ibexec/qemu-KVM</emulator><disk type='file' device='disk'><driver name='qemu' type='qcow2'/>/* 修改项 虚拟机磁盘镜像文件 */<source file='/var/1ib/1ibvirt/images/vm3.qcow2'/><target dev='vda' bus='virtio'/><address type='pci' domain='Ox0000' bus='Oxoo' slot='0x06' function='0x0'/></disk><disk type='file' device='disk'><driver name='qemu' type='qcow2'/><source file='/var/1ib/libvirt/images/vm3-1.img'/><target dev='vda' bus='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x16' function='0x0'/></disk><controller type='usb' index='0' mode1='ich9-ehcil'><address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x7'/></controller><controller type='usb' index='0' mode1='ich9-uhci1'><master startport='0'/><address type='pci' domain='Ox0000' bus='0x00' slot='0x04' function='0x0' multifunction='on'/></controller><controller type='usb' index='0' mode1='ich9-uhci2'><master startport='2'/><address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x1'/></controller><controller type='usb' index='0' model='ich9-uhci3'><master startport='4'/><address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x2'/></controller><controller type='pci' index='0' model='pci-root'/><controller type='virtio-serial' index='0'><address type='pci' domain='0x0000' bus='0x00' s1ot='0x05' function='0x0'/></controller><interface type='network'>/* 修改项 mac地址值只能修改后3组 */<mac address='52:54:00:f2:28:6f'/><source network='default'/><model type='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/></interface><serial type='pty'><target type='isa-serial' port='0'><model name='isa-serial'/></target></serial><console type='pty'><target type='serial' port='0'/></console><channel type='unix'><target type='virtio' name='org.qemu.guest_agent.0'/><address type='virtio-serial' controller='0' bus='0' port='1'/></channel><channel type='spicevmc'><target type='virtio' name='com.redhat.spice.0'/><address type='virtio-serial' controller='0' bus='0' port='1'/></channel><channel type='spicevmc'><target type='virtio' name='com.redhat.spice.0'/><address type='virtio-serial' controller='0' bus='0' port='2'/></channel><input type='tablet' bus='usb'><address type='usb' bus='0' port='1'/></input><input type='mouse' bus='ps2'/><input type='keyboard'bus='ps2'/><graphics type='spice' autoport='yes'><listen type='address'/><image compression='off'/></graphics><sound model='ich6'><address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x0'/></sound><video><model type='qxl' ram='65536' vram='65536' vgamem='16384' heads='I' primary='yes'/><address type='pci' domain='0x0000' bus='0x00' slot='0x02' function=' 0x0'/></video><redirdev bus='usb' type='spicevmc'><address type='usb' bus='0' port='2'/></redirdev><redirdev bus='usb' type='spicevmc'><address type='usb' bus='0'port='3'/></redirdev><memballoon model='virtio'><address type='pci' domain='0x0000' bus='0x00'slot='0x08'function='0x0'/></memballoon></devices></domain>
5、常见问题解析
问题1:用图形安装guest os的时候卡住不动
解决:升级系统
[root@foo~]#yum upgrade -y
问题2:升级系统后安装guest os的时候还是-卡住不动
解决:需要在安装宿主机的时候安装兼容性程序
问题3:如果安装了各种兼容程序之后还是不行
[root@model network-scripts] # rpm .q qemu-kvmqemu kvm 1.5.3 160. el7_6.2.x86_64[root@model network-scripts] # rpm - q qemu-kvm ev未安装软件包qemu-kvm-ev[rootGmodel network-scripts] # rpm -qa | grep kvmoci- kvm-hook 0.3 1.el7.x86_64pcp- pmda-kvm 4.1.0-5.el7_6.x86_64qemu-kvm tools-1.5.3 160. el7_6.2. x86_64qemu kvm 1.5.3 160. el7_6.2.x86_64libvirt-daemon-kvm 4.5.0- 10. el7_6.10.x86_64qemu kvm common 1.5.3 160. el7_6.2. x86_64new problem: 有的同学安装的主包是:qemu-kvm-ev,但是这个包不能用,必须用qemu-kvm才行如果不解决会出现安装guestos的时候卡住的现象
如果所有问题都排查过后还是安装不上guestos,最后的原因就是在安装宿主机系统的时候各种兼容性软件没
有安装而且Yum也没有自动处理导致的
6、升级配置
1.修改配置文件(比如添加磁盘,那就添加如下配置)
root@test qemu]# vim vm1.xml
复制下面代码 修改之后就可以增加磁盘
<disk type="file" device=" disk"><driver name="qemu" type=" qcow2"/>/* 镜像文件路径 */<source file="/var/lib/1ibvirt/images/vm3-1.qcow2"/>/* dev 磁盘名 需要修改 */<target dev="vda" bus="virtio"/>/* slot 插槽 需要修改*/<address type="pci" domain=" 0x0000" bus="0x00" s1ot="0x16" function="0x0"/></disk>
特别注意:centos8里面硬盘和网-卡的添加已经不能修改slot了,要求修改的是bus地址
root@test qemu]# virsh define vm1.xml 错误:从vm1.xm1定义域失败 错误:XML错误:无效PCI地址0000:04:01.0。slot必须 <= 0
2.创建新的空磁盘卷:
[root@foo~]# qemu-img create -f qcow2 /var/lib/libvirt/images/vm3-1.qcow2 10G
3.重新定义:
[root@foo ~]# virsh define /etc/1ibvirtd/qemu/vm3.xm1
七、KVM存储
存储池管理
KVM必须要配置一个目录当作他存储磁盘镜像(存储卷)的目录,我们称这个目录为存储池
默认存储池
/var/lib/libvirt/imqges/
1.创建基于文件夹的存储池(目录)
[root@foo~]#mkdir-p /data/vmfs
2.定义存储池与其目录
将/data/vmfs 定义为一个存储池 池的名字时vmdisk [root@foo~]#virsh pool-define-as vmdisk —type dir —target /data/vmfs
3.创建已定义的存储池
(1)创建已定义的存储池
[root@foo ~]# virsh pool-build vmdisk
(2)查看已定义的存储池,存储池不激活无法使用。
[root@foo ~]# virsh pool-list —all
4.激活并设置已定义的存储池为开机自动启动
[root@foo ~]# virsh pool-start vmdisk [root@foo~]# virsh pool-autostart vmdisk
这里vmdisk存储池就已经创建好了,可以直接在这个存储池中创建虚拟磁盘文件了。
5.在存储池中创建虚拟机存储卷
[root@foo~]# virsh vol-create-as vmdisk oe1test03.qcow2 20G —format qcow2
- 注1:KVM存储池主要是体现一种管理方式,可以通过挂载存储目录,1vm逻辑卷的方式创建存储池,虚拟机存储卷创建完成后,剩下的操作与无存储卷的方式无任何区别了
- 注2:KVM存储池也要用于虚拟机迁移任务。
6.存储池相关管理命令
(1)在存储池中删除虚拟机存储卷
[root@foo ~]# virsh vo1-delete —pool vmdisk oe1test03.qcow2
(2)取消激活存储池
[root@foo ~]# virsh pool-destroy vmdisk
(3)删除存储池定义的目录/data/vmfs
[root@foo ~]# virsh pool-delete vmdisk
(4)取消定义存储池
[root@foo ~]# virsh pool-undefine vmdisk
生产环境存储池使用
磁盘格式
raw
原始格式,性能最好
qcow
先去网上了解一下cow(写时拷贝copyon write),性能远不能和raw相比, 所以很快天折了,所以出现了qcow2
qcow2
性能上还是不如raw,但是raw不支持快照,qcow2支持快照。
qed
现在默认安装好的用的是raw格式,所有做快照要把他转换成qcow2格式
写时拷贝
raw立刻分配空间,不管你有没有用到那么多空间
qcow2只是承诺给你分配空间,但是只有当你需要用空间的时候,才会给你空间。最多只给你承诺空间的大小,避免空间浪费
工作当中用哪个
看你用不用快照。工作当中虚拟机会有多个备份,一个坏了,再起一个就行了,所有没必要用快照。当然也不一定。数据绝对不会存储到本地。
创建磁盘文件
建立qcow2格式磁盘文件:[root@foo ~]# qemu-img create -f qcow2 test.qcow2 20G建立raw格式磁盘文件:[root@foo ~]# qemu-img create -f raw test.raw 20G查看已经创建的虚拟磁盘文件:[root@foo ~]# qemu-img info test.qcow2
挂载磁盘
作为虚拟化环境管理员,你肯定遇到过虚拟机无法启动的情况。实施排错时,你需要对虚拟机的内部进行检查。而Libguestfs Linux工具集可以在这种情况下为你提供帮助。
利用Libguestfs找出损坏的虚拟机文件
Libguestfs允许在虚拟机。上挂载任何类型的文件系统,以便修复启动故障。
使用Libguestfs,首先需要使用Libvirt。 Libvirt是一个管理接口,可以和KVM、Xen和其他一些基于Liunx的虚拟机相互连接。Libguestfs的功能更加强大, 可以打开Windows虚拟机上的文件。但是首先你需要将虚拟机迁移到libguestfs可用的环境当中,也就是Linux环境。
假如你是vmware的ESXI虚拟机,为了将虚拟机迁移到Linux当中,你可以使用SSH连接到ESXi主机,这意味着你首先需要启用ESXi主机上的SSH访问方式。完成之后,在Linux平台上运行下面的scp命令:
# 查看磁盘镜像分区信息:[root@foo ~]#virt-df-h -dvm1Filesystem Size Used Available Use%vm1:/dev/sda1 484M 32M 428M 7%vm1:/dev/sdb1 3.5G 3.5G o 100%vm1:/dev/vo1Group/1v_root 6.1G 1.1G 4.7G 18%[root@foo ~]# virt-filesystems -d vm1/dev/sda1/dev/sdb1/dev/Vo1Group/1v_root# 挂载磁盘镜像分区:[root@foo ~]# guestmount -dvm1-m/dev/vda1 --rw/mnt# 取消挂载[root@foo ~]# guestunmount /mnt
注:mtab文件在centos7的启动过程中非常有用,删掉会导致不能启动
八、KVM管理
KVM基本管理
查看 启动 关闭 重启 重置 查看
#查看虚拟机:[root@foo ~]# virsh listId Name State---------------------------------2 vm1 running[root@foo ~]# virsh list --all---------------------------------Id Name State2 vm1 running#查看KVM虚拟机配置文件(X):[root@foo ~]# virsh dumpxm7 name#将node4虚拟机的配置文件保存至node6.xm1(X):[root@foo ~]# virsh dumpxm1 node4 >/etc/1ibvirt/ qemu/node6.xm1#修改node6的配置文件(X):[root@foo ~]# virsh edit node6如果直接用vim编辑器修改配置文件的话,需要重启1ibvirtd服务#启动:[root@foo ~]# virsh start vm1Domain vml started#暂停虚拟机:[root@foo ~]# virsh suspend vm_name#恢复虚拟机:[root@foo ~]#virsh resume vm_name#关闭:方法1:[root@foo ~]# virsh shutdown vm1Domain vm1 is being shutdown方法2(X):[root@foo ~]#virsh destroy vm1Domain vm1 destroyed#重启:[root@foo ~]#virsh reboot vm1Domain vm1 is being reboote#重置:[root@foo ~]#virsh reset vm1Domain vm1 was reset#删除虚拟机:[root@foo ~]#virsh undefinevm2Domain vm2 has been undefined //注意:虚拟机在开启的情况下undefine是无法删除的,但是如果再destroy会直接被删除掉#虚拟机开机自动启动:[root@foo ~]#virsh autostart vm1#域vm1标记为自动开始[root@foo ~]# 1s /etc/libvirt/qemu/autostart/ //此目录默认不存在,在有开机启动的虚拟机时自动创建vm1.xm7[root@foo ~]# virsh autostart --disable vml //域vm1取消标记为自动开始#查看所有开机自启的guest os:[root@foo ~]# ls /etc/1ibvirt/qemu/autostart/[root@foo ~]# virsh list --all --autostart
虚拟机克隆
1.图形界面
Applications(左上角)——->System Tools ——->Virtual Machine Manager
关闭要克隆的虚拟机,右键点击虚拟机选择Clone
2.字符终端,命令克隆
#-o origin[root@foo ~]# virt-clone -o vm1 --auto-cloneWARNING设置图形设备端口为自动端口,以避免相互冲突。正在分配"vm1-c1one.qcow2" |6.0 GB 00:00:05成功克隆"vm1-clone"。[root@foo ~]#virt-clone -o vm1 -n vm2 --auto-cloneWARNING设置图形设备端口为自动端口,以避免相互冲突。正在分配"vm2.qcow2" |6.0 GB 00:00:06成功克隆"vm2"#-f,--file NEW_DISKFILE: 为新客户机使用新的磁盘镜像文件[root@qfebu.com~]#virt-clone -o vm1 -n vm2 -f/var/lib/1ibvirt/images/vm2.img正在克隆"vm1.img" |8.0 GB 01:03clone"vm2" created successfully.
增量镜像
1、概述
实验目的:
通过一个基础镜像(node.img),里面把各个虚拟机都需要的环境都搭建好,然后基于这个镜像建立起一个个增量镜像,每个增量镜像对应一个虚拟机,虚拟机对镜像中所有的改变都记录在增量镜像里面,基础镜像始终保持不变。
功能:
节省磁盘空间,快速复制虚拟机。
环境:
基本镜像文件:node.img虚拟机D:node
增量镜像文件:node4.img虚拟机ID: node4
要求:
以基本镜像文件node.img为基础,创建一 个镜像文件node4.img,以此创建一 个虚拟机
node4,虚拟机node4的改变将存储于node4.img中。
2、创建增量镜像文件
[root@foo~]#qemu-img create -b node.img -f qcow2 node4.img[root@foo~]#qemu-img info node4.imgimage: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配置文件
[root@foo~]# cp /etc/1ibvirt/qemu/node.xm1 /etc/1ibvirt/qemu/node4.xm1[root@foo~]# vim /etc/1ibvirt/qemu/node4.xm1
<domain type="KVM"><--#node4的虚拟机名,须修改,否则与基本虚拟机冲突--><name>node4</name><--#node4的UUID,必须修改,否则与基本虚拟机冲突--><uuid>4b7e91eb-6521-c2c6-cc64-c1ba72707fe4</uuid><memory>524288</memory><currentMemory>524288</currentMemory><vcpu cpuset="0-1">2</vcpu><os><type arch="x86_64" machine="rhe15.4.0">hvm</type><boot dev="hd"/></os><features><acpi/><apic/><pae/></features><clock offset="localtime"/><on_poweroff>destroy</on_poweroff><on_reboot>restart</on_reboot><on_crash>restart</on_crash><devices><emulator>/usr/1ibexec/qemu-KVM</emulator><disk type="file" device="disk"><driver name="qemu"type="qcow2"/><--#将原指向/virhost/KVM_node/node.img改为node4.img--><source file="/virhost/KVM_ node/node4.img"/><target dev="vda" bus="virtio"/><address type="pci" domain="Ox0000" bus="Ox00" s1ot="Ox04" function="0x0"/></disk><interface type="bridge"><--#修改网卡MAC,防止冲突--><mac address="54:52:00:69:d5:f4"/><source bridge="br0"/><model type="virtio"/><devices>
4、根据xml配置定义虚拟机node4
[root@foo~]#virsh define /etc/1ibvirt/qemu/node4.xm1[root@foo~]#virsh start node4
5、测试
[root@foo~]#du -h node.img6.3G node.img[root@foo~]#du-h node4.img33M node4.img[root@foo~]#dd if=/dev/zero of=test bs=1M count=200 #在虚拟机node4上增量200M大小文件200+0 records in200+0 records out209715200 bytes (210 MB) copied, 1.00361 seconds,209 MB/s[root@foo~]#du -h node.img #基本镜像文件node.img大小未变6.3G node.img[root@foo~]#du-h node4.img #增量镜像文件node4.img增加200M了234M node4.img
快照
为虚拟机vm8创建一个快照
[root@foo~]#virsh snapshot-create-as vm8 vm8.snaperror: unsupported confi guration: internal snapshot for disk vda unsupported for storage type raw
raw
使用文件来模拟实际的硬盘(当然也可以使用一 块真实的硬盘或一个分区)。由于原生的裸格式,不支持snapshot也是很正常的。但如果你使用LVM的裸设备,那就另当别论。说到LVM还是十分的犀利的目前来LVM的snapshot、性能、可扩展性方面都还是有相当的效果的。目前来看的话,备份的话也问题不大。就是在虚拟机迁移方面还是有很大的限制。但目前虚拟化的现状来看,真正需要热迁移的情况目前需求还不是是否的强烈。虽然使用LVM做虚拟机镜像的相关公开资料比较少,但目前来看牺牲一点灵活性,换取性能和便于管理还是不错的选择。
qcow2
现在比较主流的一种虚拟化镜像格式,经过一代的优化,目前qcow2的性能上接近raw裸格式的性能,这个也算是redhat的官方渠道了
对于qcow2的格式,几点还是比较突出的,qcow2的snapshot,可以在镜像上做N多个快照:
- 更小的存储空间
- Copy-on-write support
- 支持多个snapshot,对历史snapshot进行管理
- 支持zlib的磁盘压缩
- 支持AES的加密
实战
#为虚拟机vm2创建一个快照(磁盘格式必须为qcow2)[root@foo~]#virsh snapshot-create-as vm2 vm2.snap#查看磁盘文件格式[root@foo~]# qemu-img info /var/1ib/1ibvirt/images/vm2.qcow2image:/var/lib/1ibvirt/images /vm2.qcow2file format: qcow2virtual size:5.0G (5368709120 bytes)disk size:5.0Gcluster_size: 65536Snapshot list:ID TAG VM SIZE DATE VM CLOCK1 vm2.snap 0 2020-04-15 13:01:42 00:00:00.000Format specific information:compat: 1.1lazy refcounts: true[root@foo~]# virsh snapshot-list vm2Name Creation Time State---------------------------------------------------vm2.snap 2020-04-15 13:01:42 +0800 shutoff#创建一快磁盘[root@foo~]# qemu-img create -f raw /var/lib/libvirt/images/vm2-1.raw 2GFormatting "/var/lib/libvirt/ images/vm2-1.raw",fmt=raw size=2147483648# 通过修改配置文件将其添加到vm2虚拟机上[root@foo~]# cd /etc/libvirt/qemu/[root@foo~]# vim vim2.xml
<devices><emulator>/usr/libexec/qemu- kvm</emulator><--添加磁盘,复制########中间内容--><--#####################################################--><disk type="file" device="disk"><driver name="qemu" type="qcow2"/><source file="/var/lib/libvirt/images/vm2.img"/><target dev="vda" bus="virtio"/><address type="pci" domain="0x0000" bus="0x00" slot="0x07" function="0x0"/></disk><--#####################################################--><--#####################################################--><disk type="file" device="disk"><--qcow2修改成raw--><driver name="qemu" type="raw"/><--vm2-1.img修改成vm2-1.raw--><source file="/var/lib/libvirt/images/vm2-1.raw"/><--vda修改成vdb--><target dev="vda" bus="virtio"/><address type="pci" domain="0x0000" bus="0x00" slot="0x07" function="0x0"/></disk><--#####################################################-->
[root@foo~]# virsh define /etc/1ibvirt/qemu/vm2.xm7[root@foo~]#virsh startvm2[root@foo~]# virsh snapshot-create-as vm2 vm2.snap1错误:不支持的配置:存储类型vdb不支持磁盘raw的内部快照,这里只是为了演示后续的格式转换操作,真实环境中可以直接配置qcow2格式
格式转换:
把raw格式转换成qcow2格式
[root@foo~]#qemu-img convert -o qcow2 /var/1ib/1ibvirt/images/vm2-1.raw /var/lib/libvirt/images/vm2-1.qcow2[root@foo~]# cd /var/lib/libvirt/images/[root@foo~]# ll -h-rw-r--r-- 1 root root 193K 10月25 16:44 vm2-1.qcow2-rw-r--r--1 root root 2.0G 10月25 16:25 vm2-1.raw#查看格式[root@foo~]# qemu-img info /var/lib/libvirt/images/vm2-1. qcow2image: /var/1ib/1ibvirt/images/vm2-1.qcow2file format:qcow2virtual size:2.0G (2147483648 bytes)disk size:196Kcluster_size: 65536Format specific information:compat: 1.1lazy refcounts: false
将虚拟机的硬盘指向转换后的qcow2.img
[root@foo~]#virsh shutdown vm2# 修改配置文件之前先关闭虚拟机[root@fooimages]# vim /etc/1ibvirt/qemu/vm2.xm1# 将之前修改的.raw格式改成qcow2[root@fooimages]# vim /etc/1ibvirt/qemu/vm2.xm1[root@foo images]#virsh define /etc/1ibvirt/qemu/vm2.xm1#创建快照[root@foo qemu]# virsh snapshot-create-as vm2 vm2.snap2#己生成域快照vm2.snap2
在虚拟机中创建一个空目录
[root@foo ~]# mkdir test[root@foo~]# ls /test
给虚拟机vm2创建第三个快照vm2.snap3
[root@foo~]#virsh snapshot-create-as vm2 vm2.snap3
在虚拟机中,给test中复制2个文件
[root@foo~]#cp install.log anaconda-ks.cfg /test[root@foo~]# ls /testanaconda-ks.cfg install.log
给虚拟机vm2创建第四个快照vm2.snap4
[root@foo~]#virsh snapshot-create-as vm2 vm2.snap4Domain snapshot vm2.snap2 created
查看虚拟机快照
[root@foo~]#virsh snapshot-1ist vm2
关闭虚拟机,恢复到第三个快照
[root@foo~]#virsh shutdown vm2[root@foo~]# virsh snapshot-revert vm2 vm2.snap3
在虚拟机中,发现/test目录为空
[root@foo~]# Is /test
关闭虚拟机,恢复到第四个快照
[root@foo~]#virsh shutdown vm2[root@foo~]#virsh snapshot-revert vm2 vm2.snap4
在虚拟机中,发现/test有拷贝的2个文件
[root@foo~]# Is /testanaconda-ks.cfg install.log
查看虚拟机快照
[root@foo~]# virsh snapshot-list vm2
删除虚拟机快照
[root@foo~]# virsh snapshot-delete --snapshotname vm2.snap3 vm2[root@foo~]#v irsh snapshot-1ist vm2
九、KVM网络
分类
nat 同virtualbox的nat
isolated 同virtualbox的hostonly
接口
bridge 桥接口
在虚拟机上做了个桥接口,在把五理解的网卡和桥接口邦在一起
交换机
linux-bridge(linux自带)
ovs(open-Yswitch)
NAT网络拓扑
isolated隔离网路拓扑图
桥接网络拓扑图

配置文件的方式配置birdge桥接网络
在宿主机上1.修改配置文件[root@foo~]# cat ifcfg-br0TYPE=BridgeNAME=br0DEVICE=br0ONBOOT="yes" # 系统启动是是否激活网卡BOOTPROTO=static # 设置IP为静态IPADDR=10.18.44.251GATEWAY=10.18.44.1NETMASK=255.255.255.0DNS1=10.18.44.100DNS2=8.8.8.8[root@foo~]# cat ifcfg-enp3s0DEVICE="enp3s0"ONBOOT="yes"BRIDGE=br02.重启libvirtd服务3.重启network服务删除桥接网卡步骤:1.删除bro的配置文件2.修改正常网卡的配置文件3.重启系统
Virbro的DHCP
VirbrQ是KVM默认创建的一个Bridge,其作用是为连接其上的虚机网卡提供NAT访问外网的功能。
Virbr0默认分配了一个IP 192.168.122.1, 并为连接其上的其他虚拟网卡提供DHCP服务。
Virbro使用dnsmasq提供DHCP服务,可以在宿主机中查看该进程信息
[root@foo~]#ps-e1f Igrep dnsmasq5 s 1ibvirt+2422 1080 0 - 7054 poll_s 11:26 ? 00: 00:00/usr/sbin/dnsmasq --conf-file=/var/1ib/1ibvirt/dnsmasq/defau1t.conf# 在/var/1ib/libvirt/dnsmasq/ 目录下有一个virbr0.status 文件,当VM1成功获得DHCP的IP后,可以在该文件中查看到相应的信息[root@foo~]# cat virbr0.status[{"ip-address": "192.168.122.28""mac-address": "52:54:00:94:a7:al","hostname": "vm1","expiry-time": 1511626337}]
配置文件方式创建nat网络
[root@foo~]# cp /etc/libvirt/qemu/networks/default.xml /etc/1ibvirt/qemu/networks/nat1.xml[root@foo~]# vim /etc/libvirt/qemu/networks/nat1.xml<network><name>nat1</name><uuid>4d8b9b5c-748f -4e16-a509-848202b9c83b</uuid><forward mode="nat"/>#和隔离模式的区别<bridge name="virbr4" stp="on" de1ay="0"/><mac address="52:57:00:62:0c:d4"/><domain name="nat1"/><ip address="192.168.104.1" netmask="255.255.255.0"><dhcp><range start="192.168.104.128" end="192.168.104.254"/></dhcp></ip></network>#重启服务:[root@foo~]# systemctl restart libvirtd
配置文件方式创建isotated网络
[root@foo networks]# cp defau1t.xm1 iso1ated200.xm1[root@foo networks]# vim iso1ated200.xm7<network><name>isolated200</name><uuid>6341d3a6-7330-4e45-a8fe-164a6a68929a</uuid><bridge name="virbr2" stp=" on"delay="0"/><mac address="52:54:00:6b:39:0c"/><domain name="isolatel"/><ip address="192.168.101.1" netmask="255.255.255.0"><dhcp><range start="192.168.101.128" end="192.168.101.254"/></dhcp></ip></network>[root@foo networks]# systemct1 restart libvirtd
查看所有的网络:[root@foo ~]# virsh net-list启动网络:[root@foo ~]# virsh net-start isolated200开机自启动:[root@foo ~]# virsh net-autostart isolated200网络相关基本命令查看一个guest主机的网络接口信息:[root@foo ~]#virsh domiflist vm2接口 类型 源 型号 MACvneto network default virtio 52:54:00:94:a7:al
十、脚本管理KVM
批量创建虚机脚本
扩展功能:
查看现在虚拟机
查看某个虚拟机的配置
升配/降配
添加/删除网络
#!/bin/bash#KVM batch create vm tool#version: 0.1#author: wing#需要事先准备模板镜像和配置文件模板echo "1.创建自定义配置单个虚拟机2.批量创建自定义配置虚拟机3.批量创建默认配置虚拟机4.删除虚拟机"read -p "选取你的操作(1/2/3):" opbatch_self_define(){KVMname=`openssl rand -hex 5`sourceimage=/var/1ib/1ibvirt/images/vmmodel.imgsourcexml=/etc/libvirt/qemu/vmmodel.xmlnewimg=/var/1ib/1ibvirt/images/${KVMname}. imgnewxm1=/etc/1ibvirt/qemu/${KVMname}.xmlcp $sourceimage $newimgcp $sourcexml $newxmlKVMuuid=`uuidgen`KVMmem=${1}000000KVMcpu=$2KVMimg=$newimgKVMmac=`openss1 rand -hex 3 | sed -r "s/..\B/&:/g"`sed -i "s@KVMname@ $KVMname@;s@KVMuuid@$KVMuuid@;s@KVMmem@ $KVMmem@;s@KVMcpu@$KVMcpu@;s@KVMimg@$KVMimg@;s@KVMmac@$KVMmac@" $newxmlvirsh define $newxmlvirsh list --all}case $op in1)self_define;;2)read -p "请输入要创建的虚拟机的个数:" numread -p "请输入新虚机内存大小(G):"newmemread -p "请输入新虚机cpu个数:" newcpufor((i=1;i<=$num;i++))dobatch_self_define $newmem $newcpudone;;3)read-p"请输入要创建的虚拟机的个数:" numfor((i=1;i<=$num;i++))dobatch_self_define 1 1done;;*)echo "输入错误,请重新执行脚本"exit;;esac
配置文件模板
[root@foo ~]#vim /etc/1ibvirt/qemu/vmmodel.xml<domain type="KVM"><name>KVMname</name><uuid>KVMuuid</uuid><memory unit="KiB">KVMmem</memory><currentMemory unit="KiB ">KVMmem</currentMemory><vcpu placement="static ">KVMcpu</vcpu><os><type arch="x86_64" machine="pc-i440fx-rhe17.0.0">hvm</type><boot dev="hd"/></os><features><acpi/><apic/></features><cpu mode="custom" match=" exact"check="partial"><model fallback=" a11ow">Haswe11-noTSX</model></cpu><clock ottset="utc"><timer name="rtc" tickpo1icy="catchup"/><timer name="pit" tickpolicy=" delay"/><timer name="hpet" present="no"/></clock><on_poweroff>destroy</on_poweroff><on_reboot>restart</on_reboot><on_crash>destroy</on_crash><pm><suspend-to-mem enab1ed="no"/><suspend-to-disk enab1ed="no"/></pm><devices><emulator>. /usr/1ibexec/qemu-KVM</emulator><disk type="file" device="disk"><driver name="qemu" type=" qcow2"/><source file="KVMimg"/><target deve"vda" bus="virtio"/></disk><controller type="usb" index="0" mode1="ich9-ehci1"><address type=" pci"domain="0x0000" bus="0x00" s1ot="0x04" function="0x7"/></controller><controller type="usb" index="0" mode1="ich9-uhci1"><master startport="0"/><address type="pci" domain="0x0000" bus="0x00" slot="0x04" function="Ox0"nultifunction="on"/></controller><controller type="usb" index="0" model=" ich9-uhci2"><master startport="2"/><address type="pci" domain="0x0000" bus="0x00" slot=" 0x04" function="0x1"/></controller><controller type="usb" index= "0"mode1="ich9-uhci3"><master startport="4"/><address type=" pci" domain="0x0000" bus="0x00" s1ot="0x04" function="0x2"/></controller><controller type="pci" index= "0" model="pci-root"/><controller type="virtio-serial" index="0"><address type="pci"domain="0x0000" bus="0x00" slot="0x05" function=" 0x0"/></controller><interface type="network"><mac address="52:54:00:KVMmac"/><source network="default"/><model type="virtio"/><address type="pci" domain="Ox0000" bus="0x00" slot=" 0x03" function="0x0"/></interface><serial type="pty"><target type="isa-serial" port="0"><model name="isa-serial"/></target></serial><console type="pty"><target type="serial" port="0"/></console><channel type="unix"><target type="virtio" name="org.qemu.guest_agent.0"/><address type="virtio-serial" controller="0" bus="0" port="1"/></channel><input type="mouse" bus="ps2"/><input type="keyboard" bus="ps2"/><memballoon model="virtio"><address type="pci"domain="0x0000" bus="0x00" s1ot="0x07" function= "0x0"/></memballoon></devices></domain>
随机生成 mac地址
[root@foo ~]#echo $[$RANDOM%9]$[$RANDOM%9]:$[$RANDOM%9]$[$RANDOM%9]:$[$RANDOM%9]$[$RANDOM%9]65:42:31[root@foo ~]#echo `openssl rand -hex 1`:`openssl rand -hex 1`:`openssl rand -hex 1`99:6e:67[root@foo ~]# openssl rand -hex 3 | sed -r "s/(..)/\1:/g" | sed "s/.$//"e9:b6:12[root@foo ~]# openssl rand -hex 3 | sed -r "s/(..)(..)(..)/\1:\2:\3/g"94:89:e3[root@foo ~]# openssl rand -hex 3 | sed -r "s/..\B/&:/g"c5:66:90\B 表示非单词边界\b 表示单词边界<a 表示以a开头的单词b> 表示以b结尾的单词使用UUID:[root@foo ~]# uuidgen | sed -r "s/(..)(..)(..)(.*)/\1:\2:\3/"使用熵池里的随机数[root@foo ~]# cat /dev/urandom | head -1 | md5sum | head -c 6
简历上可写的KVM相关项目
1、迁移
从物理机器迁移到KVM
从KVM迁移到云主机
2、文件管理服务(ftp nfs jira+wiki)
3、日志服务
