搭建部署与概述(一)
1.KVM概述
1.1 虚拟化概述
在计算机技术中,虚拟化意味着创建设备或资源的虚拟版本,如服务器,存储设备,网络或者操作系统等等
虚拟化技术分类:
- 系统虚拟化(我们主要讨论的反向)
- 存储虚拟化(raid,lvm)
- 网络虚拟化(sdn)
- GPU虚拟化(比特币)
- 软件虚拟化
- 硬件支持虚拟化
1.1.1 系统虚拟化
- 这种虚拟化通常表现为在单一系统上运行多个操作系统
- 这些虚拟操作系统同时运行,每个操作系统又是相互独立
1.1.2 虚拟化的三种实现方式
(1)纯软件仿真
- 通过模拟完整的硬件环境来虚拟化用户平台
- 模拟X86,ARM,PowerPC等多种CPU
- 效率比较低
- QEMU,Bochs,PearPC
(2)虚拟化层翻译
- 多数的虚拟化而采用虚拟机管理程序Hypervisor
- Hypervisor是一个软件层或子系统 ,也称为VMM(Virtual Machine Monitor,虚拟机监控器)
- 允许多种操作系统在相同的物理系统中运行
- 控制硬件并向用户操作系统提供访问底层硬件的途径
- 向来宾操作系统提供虚拟化的硬件
无硬件辅助的全虚拟化
- 基于二进制翻译的全虚拟化
- Hypervisor运行在Ring 0
- Guest OS运行在Ring 1
- 机制:异常,捕获,翻译
示例:
- VMware Workstation
- QWMU
- Virtual PC
硬件辅助的全虚拟化
- Intel VT 和 AMD-V创建一个新的Ring -1 单独给Hypervisor使用
- Guest OS可以直接使用Ring 0 而无须修改
示例:
- VMware ESXi
- Microsoft Hyper-V
- Xen3.0
- KVM
2.KVM安装
2.1 实现环境准备
CentOS7.5
2.1.1 生产环境硬件配置
- CPU必须支持虚拟化技术,在BIOS设置为启动
- 目前,多数服务器基础桌面计算机均处理启动状态
2.1.2 实验准备
我们需要先用虚拟机,然后在虚拟机里再用虚拟化,也就是嵌套虚拟化
VMware 嵌套虚拟化
- 产品:Workstation,Player,ESXi
- 支持:ESXi,Hyper-V,KVM,Xen
2.2 KVM安装
装机时虚拟机需要安装如下软件
2.2.1 安装必备安装包
#我们的装机方式已经安装了如下软件组
@base
@core
@virtualization-hypervisor #虚拟化主机选项
@virtualization-platform #虚拟化平台选项
@virtualization-tools #虚拟化主机选项
#我们还需要增加如下软件包
[root@KVM yum.repos.d]# yum -y update #首先保证系统软件都是最新的
[root@KVM yum.repos.d]# yum -y group install virtualization-client
[root@KVM yum.repos.d]# yum -y group install gnome-desktop
2.2.2 修改虚拟化引擎配置并检查CPU特性
#检查CPU特性
[root@KVM ~]# grep vmx /proc/cpuinfo
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 epb tpr_shadow vnmi ept vpid fsgsbase tsc_adjust bmi1 avx2 smep bmi2 invpcid rdseed adx smap xsaveopt dtherm ida arat pln pts
#以下省略若干。。。
[root@KVM ~]# egrep '^flags.*(vmx|svm)' /proc/cpuinfo
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 epb tpr_shadow vnmi ept vpid fsgsbase tsc_adjust bmi1 avx2 smep bmi2 invpcid rdseed adx smap xsaveopt dtherm ida arat pln pts
#以下省略若干。。。
2.3 KVM远程管理
[root@KVM ~]# which virsh #查看虚拟机管理命令
/usr/bin/virsh
[root@KVM ~]# virsh list --all #查看所有虚拟机
Id 名称 状态
----------------------------------------------------
[root@KVM ~]# startx #切换到图形界面模式
咱们在工作中通常需要远程来管理KVM环境,但SSH方式是看不到桌面模式的。
2.3.1 KVM的两种远程管理方式
(1)SSH图形化显示
windows安装软件x-manager。然后xshell软件开启X11转发
然后咱们连接上虚拟机以后,输入virt-manager
出现下图
#备注:如果输入`virt-manager`出现乱码,只需要这样做即可
[root@KVM ~]# tail -1 /etc/profile
export LANG="zh_CN.UTF8"
[root@KVM ~]# cp /etc/profile /usr/share/fonts/
[root@KVM ~]# ll /usr/share/fonts/profile
-rw-r--r--. 1 root root 1844 12月 18 11:53 /usr/share/fonts/profile
[root@KVM ~]# source /usr/share/fonts/profile
(2)VNC图形化显示
VNC是一个优秀的远程管理软件,它有两部分组成VNCServer,VNCViewer。
#看一下系统里是否有必须的包
[root@KVM ~]# rpm -qa | grep vnc
gtk-vnc2-0.7.0-3.el7.x86_64
tigervnc-server-minimal-1.8.0-13.el7.x86_64 #必须有的
tigervnc-license-1.8.0-13.el7.noarch #必须有的
gvnc-0.7.0-3.el7.x86_64
#安装vnc-server
[root@KVM ~]# yum -y install tigervnc-server
[root@KVM ~]# rpm -qa tigervnc-server
tigervnc-server-1.8.0-13.el7.x86_64
[root@KVM ~]# cat /etc/sysconfig/vncservers #查看vnc配置文件
# THIS FILE HAS BEEN REPLACED BY /lib/systemd/system/vncserver@.service
[root@KVM ~]# ll /lib/systemd/system/vncserver@.service #原来这才是配置文件
-rw-r--r--. 1 root root 1828 11月 3 03:05 /lib/systemd/system/vncserver@.service
#然后我们需要创建vnc密码
[root@KVM ~]# vncpasswd
Password:123123
Verify:123123
Would you like to enter a view-only password (y/n)? y
Password:123123
Verify:123123
#启动vnc-server
[root@KVM ~]# vncserver
New 'KVM:1 (root)' desktop is KVM:1
Creating default startup script /root/.vnc/xstartup
Creating default config /root/.vnc/config
Starting applications specified in /root/.vnc/xstartup
Log file is /root/.vnc/KVM:1.log
[root@KVM ~]# ps aux | grep vnc
root 10671 3.6 1.9 222512 36628 pts/2 Sl 12:34 0:00 /usr/bin/Xvnc :1 -auth /root/.Xauthority -desktop KVM:1 (root) -fp catalogue:/etc/X11/fontpath.d -geometry 1024x768 -pn -rfbauth /root/.vnc/passwd -rfbport 5901 -rfbwait 30000
root 10680 0.0 0.0 113176 1208 pts/2 S 12:34 0:00 /bin/sh /root/.vnc/xstartup
root 11572 0.0 0.0 112728 988 pts/2 S+ 12:35 0:00 grep --color=auto vnc
#备注:要注意关闭防火墙,否则vnc客户端连接不上
[root@KVM ~]# service firewalld stop
Redirecting to /bin/systemctl stop firewalld.service
[root@KVM ~]# systemctl disable firewalld.service
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
接下来我们在windows主机上安装vnc客户端
3.创建虚拟机
3.1 使用virt-manager创建虚拟机
virt-manager 基本使用
实验
- 环境准备
- 创建Windows虚拟机
- 创建Linux虚拟
(1)我们需要添加一块60G的硬盘来存储操作系统的安装介质,ISO文件
(2)利用fdisk分出一块30G的分区
[root@KVM ~]# ll /dev/sdb*
brw-rw----. 1 root disk 8, 16 12月 19 08:20 /dev/sdb
[root@KVM ~]# mkfs.ext4 /dev/sdb #磁盘格式化
[root@KVM ~]# fdisk /dev/sdb
#中间省略若干。。。
设备 Boot Start End Blocks Id System
/dev/sdb1 2048 62916607 31457280 83 Linux
#以下省略若干。。。
(3)创建LVM逻辑卷
[root@KVM ~]# ll /dev/sdb*
brw-rw---- 1 root disk 8, 16 12月 20 08:24 /dev/sdb
brw-rw---- 1 root disk 8, 17 12月 20 08:24 /dev/sdb1 #30G
[root@KVM ~]# pvcreate /dev/sdb1
Physical volume "/dev/sdb1" successfully created.
[root@KVM ~]# pvs
PV VG Fmt Attr PSize PFree
/dev/sda2 centos_kvm lvm2 a-- <19.00g 0
/dev/sdb1 lvm2 --- 30.00g 30.00g
[root@KVM ~]# vgcreate vmvg /dev/sdb1
Volume group "vmvg" successfully created
[root@KVM ~]# vgs
VG #PV #LV #SN Attr VSize VFree
centos_kvm 1 2 0 wz--n- <19.00g 0
vmvg 1 0 0 wz--n- <30.00g <30.00g
[root@KVM ~]# vgdisplay #查看vg详细
--- Volume group ---
VG Name vmvg
System ID
Format lvm2
Metadata Areas 1
Metadata Sequence No 1
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 0
Open LV 0
Max PV 0
Cur PV 1
Act PV 1
VG Size <30.00 GiB
PE Size 4.00 MiB
Total PE 7679
Alloc PE / Size 0 / 0
Free PE / Size 7679 / <30.00 GiB vmvg可用的PE一共7679
VG UUID GsgAro-mTYG-veWd-DgHX-Er2l-wzlR-9sdgrr
--- Volume group ---
VG Name centos_kvm
System ID
Format lvm2
Metadata Areas 1
Metadata Sequence No 3
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 2
Open LV 2
Max PV 0
Cur PV 1
Act PV 1
VG Size <19.00 GiB
PE Size 4.00 MiB
Total PE 4863
Alloc PE / Size 4863 / <19.00 GiB
Free PE / Size 0 / 0
VG UUID MHqXwe-dDIR-AEvm-r3GG-puvc-0QWZ-XngvFT
[root@KVM ~]# lvcreate -n lvvm1 -l 7679 vmvg #将vmvg可以用PE全部分配给lvvm1
Logical volume "lvvm1" created.
[root@KVM ~]# lvs
LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert
root centos_kvm -wi-ao---- <17.00g
swap centos_kvm -wi-ao---- 2.00g
lvvm1 vmvg -wi-a----- <30.00g
[root@KVM ~]# mkfs.ext4 /dev/vmvg/lvvm1 #格式化lvvm1
#以下省略若干。。。
(4)挂载逻辑卷
[root@KVM ~]# mkdir /vm
[root@KVM ~]# mount /dev/vmvg/lvvm1 /vm/
[root@KVM ~]# df -hT
文件系统 类型 容量 已用 可用 已用% 挂载点
/dev/mapper/centos_kvm-root xfs 17G 3.9G 14G 23% /
devtmpfs devtmpfs 898M 0 898M 0% /dev
tmpfs tmpfs 910M 0 910M 0% /dev/shm
tmpfs tmpfs 910M 11M 900M 2% /run
tmpfs tmpfs 910M 0 910M 0% /sys/fs/cgroup
/dev/sda1 xfs 1014M 201M 814M 20% /boot
tmpfs tmpfs 182M 28K 182M 1% /run/user/0
/dev/sr0 iso9660 4.2G 4.2G 0 100% /run/media/root/CentOS 7 x86_64
/dev/mapper/vmvg-lvvm1 ext4 30G 45M 28G 1% /vm
[root@KVM ~]# echo "mount /dev/vmvg/lvvm1 /vm/" >> /etc/rc.local
(5)创建iso镜像文件存放目录
[root@KVM ~]# mkdir /iso
[root@KVM ~]# cd /iso/
[root@KVM ios]# ls
CentOS-6.5-x86_64-bin-DVD1.iso
将光盘安装镜像文件上传到/ios目录下:
3.1.1 virt-manager基本使用
- 启动virt-manager
- 虚拟机管理主窗口
- 硬件细节窗口
配置虚拟机启动选项
附加USB设备给虚拟机
准备工作
USB重定向- 虚拟机图形控制台
- 添加远程连接
- 显示虚拟机细节
- 性能监视
(1)使用向导的默认配置来创建虚拟机
启动VNC远程管理程序连接Linux,打开Virtual Machine Manager
最后新建的虚拟机自动进入装机状态
这里咱们选择全英文,最小化装机即可。由于咱们是嵌套的虚拟化,装机图形界面可能稍微有点卡。不过没关系,等一下就好。
特别提示:当我们以virt-manager进行手动管理创建虚拟机时,有可能在进入安装操作系统界面时大几率遭遇到键盘失灵的情况。如果遇到这个问题,不要着急,这是因为字符集混乱识别的问题,我们需要调整一下虚拟机的设置后,即可恢复。
我们做如下调整即可。
然后我们正常开机就会进入装机界面,你会发现键盘的操作恢复了。。。
(2)以自定义规划方式创建虚拟机
我们发现按照向导的默认方式安装虚拟机,虚拟机的磁盘并没有放在我们规划好的目录里
因此我们需要在安装过程中进行自定义存储池的操作,步骤如下
到此我们新的VM存储池就创建完了,但是在存储池里我们还需要创建一个Volume卷(磁盘)
3.2 使用virt-install创建虚拟机
#创建一块虚拟机的存储磁盘
[root@KVM ~]# qemu-img create -f qcow2 /vm/yangwenbo.qcow2 10G #qcow2格式磁盘 /vm/chensiqi.qcow2磁盘位置 10G为磁盘大小
Formatting '/vm/yangwenbo.qcow2', fmt=qcow2 size=10737418240 encryption=off cluster_size=65536 lazy_refcounts=off
[root@KVM ~]# ll -h /vm/
总用量 2.1M
-rw------- 1 qemu qemu 8.1G 12月 21 08:43 centos6.5-2.qcow2 #真占了8G
-rw-r--r-- 1 root root 193K 12月 21 09:04 yangwenbo.qcow2 #只是小文件
我们通过qemu-img来创建的磁盘在最初只是个小文件,直到磁盘空间被占满。 然而我们通过virt-manager创建的磁盘却真的占了8G
#创建一个虚拟机
[root@KVM ~]# virt-install \ #创建虚拟机命令
> --name=vm1 \ #虚拟机的名字
> --disk path=/vm/yangwenbo.qcow2 \ #虚拟磁盘路径
> --vcpus=1 --ram=1024 \ #分配的CPU和内存大小
> --cdrom=/iso/CentOS-6.5-x86_64-bin-DVD1.iso \ #系统安装盘位置
> --network network=default \ #网络模式,default为NAT
> --graphics vnc,listen=0.0.0.0 \ #虚拟机的显示类型为VNC
> --os-type=linux \
> --os-variant=rhel6
开始安装......
#以下省略若干。。。
virt-install --name=vm1 --disk path=/vm/yangwenbo.qcow2 --vcpus=1 --ram=1024 --cdrom=/iso/CentOS-6.5-x86_64-bin-DVD1.iso --network network=default --graphics vnc,listen=0.0.0.0 --os-type=linux --os-variant=rhel6
执行上边的命令就会弹出Virt Viewer的窗口,进入装机界面
3.3 半虚拟化驱动virtio
3.3.1 使用半虚拟化驱动virtio的目的
没有virtio的全虚拟化的设备访问路径如下图所示:
拥有virtio的全虚拟化的设备访问路径如下图所示:
3.3.2 virtio的半虚拟化设备统一接口原则
3.3.3 Linux虚拟机直接选择virtio半虚拟化驱动设备
3.4 QEMU Guest Agent
- 如果VM中安装了QEMU guest agent,Host就可以使用libivrt向VM发送命令,例如“冻结”,“释放”文件系统,虚拟CPU的热添加及移除等。
- RHEL/CetnOS7中有相应的安装包。qemu-guest-agent-xxx.rpm
- Windows需要手工安装
#这个管理包已经安装
[root@KVM ~]# rpm -qa | grep qemu-guest-agent
qemu-guest-agent-2.12.0-2.el7.x86_64
[root@KVM ~]# which virsh
/usr/bin/virsh
通过libvirt来使用QEMU guest agent
4.管理虚拟机
4.1 libvirt架构概述
libvirtd是一个守护进程,virsh,virt-install等等都是依靠这个守护进程来间接访问qemu-kvm及配置文件。如果我们关闭这个进程,那么virsh,virsh-install,virt-manager就都不能访问了。
4.2 使用virt-manager管理虚拟机
virt-manager主要功能:
- 定义和创建虚拟机
- 硬件管理
- 性能监视
- 虚拟机的保存和恢复,暂停和继续,关闭和启动
- 控制台
- 在线和离线迁移
virt-manager
- 方法1:Applications菜单>System Tools>Virtual Machine Manager (virt-manager)
- 方法2 :在SSH会话中输入virt-manager
4.3 使用virsh来管理虚拟机
4.3.1 virsh概述
- virsh是使用libvirt management API构建的管理工具
- virsh的名称的含义是virtualization shell。它有两种工作模式
立即模式
[root@KVM ~]# virsh list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
- vm1 关闭
交互模式
[root@KVM ~]# virsh
欢迎使用 virsh,虚拟化的交互式终端。
输入:'help' 来获得命令的帮助信息
'quit' 退出
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
- vm1 关闭
virsh #
4.3.2 关于virsh的命令帮助
[root@KVM ~]# virsh --help
4.3.3 virsh常用命令
命令 | 概述 |
attach-device | 使用XML文件中的设备定义在虚拟机中添加设备 |
attach-disk | 在虚拟机中附加新磁盘设备 |
attach-interface | 在虚拟机中附加新网络接口 |
create | 从XML配置文件生成虚拟机并启动新虚拟机 |
define | 为虚拟机输出XML配置文件 |
destroy | 强制虚拟机停止 |
detach-device | 从虚拟机中分离设备,使用同样的XML描述作为命令attach-device |
detach-disk | 从虚拟机中分离磁盘设备 |
detach-interface | 从虚拟机中分离网络接口 |
domblkstat | 显示正在运行的虚拟机的块设备统计 |
domid | 显示虚拟机ID |
domifstat | 显示正在运行的虚拟机的网络接口统计 |
dominfo | 显示虚拟机信息 |
domname | 显示虚拟机名称 |
domstate | 显示虚拟机状态 |
domuuid | 显示虚拟机UUID |
dumpxml | 输出虚拟机XML配置文件 |
help | 打印基本帮助信息 |
list | 列出所有虚拟机 |
migrate | 将虚拟机迁移到另一台主机中 |
nodeinfo | 有关管理程序的输出信息 |
quit | 退出这个互动终端 |
reboot | 重新启动虚拟机 |
restore | 恢复以前保存在文件中的虚拟机 |
resume | 恢复暂停的虚拟机 |
save | 将虚拟机当前状态保存到某个文件中 |
setmaxmem | 为管理程序设定内存上限 |
setmem | 为虚拟机设定分配的内存 |
setvcpus | 修改为虚拟机分配的虚拟CPU数目 |
shutdown | 关闭某个虚拟机 |
start | 启动未激活的虚拟机 |
suspend | 暂停虚拟机 |
undefine | 删除与虚拟机关联的所有文件 |
vcpuinfo | 显示虚拟机的虚拟CPU信息 |
vcpupin | 控制虚拟机的虚拟CPU亲和性 |
version | 显示virsh版本 |
4.3.4 实操演示virsh管理虚拟机
(1)通过命令开启和关闭虚拟机
#交互模式管理虚拟机
#启动虚拟机
[root@KVM ~]# virsh #进入交互模式
欢迎使用 virsh,虚拟化的交互式终端。
输入:'help' 来获得命令的帮助信息
'quit' 退出
virsh # list #显示所有启动状态的虚拟机
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
virsh # list --all #显示所有虚拟机
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
- vm1 关闭
virsh # start vm1 #启动名称为vm1的虚拟机
域 vm1 已开始
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
5 vm1 running #已经启动了
#关闭虚拟机
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
5 vm1 running
virsh # shutdown 5 #shutdown优雅的关闭计算机,但有时我们这样关闭不了
域 5 被关闭
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
5 vm1 running #仍旧在运行
virsh # destroy 5 #destroy强制关闭虚拟机
域 5 被删除
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
- vm1 关闭 #被强制关闭了。
(2)通过命令来设定虚拟机的主机开启自动引导启动
关于主机开机引导时是否自动启动虚拟机,我们可以通过虚拟机的图形界面或者命令来设置,图形界面设置方式如下图所示:
[root@KVM ~]# virsh list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
- vm1 running #设置主机开机自动引导后,重启我们发现虚拟机自动开启
通过命令来控制虚拟机的开机自动引导
[root@KVM ~]# virsh
欢迎使用 virsh,虚拟化的交互式终端。
输入:'help' 来获得命令的帮助信息
'quit' 退出
virsh # help autostart #查看autostart的帮助
NAME
autostart - 自动开始一个域
SYNOPSIS
autostart <domain> [--disable]
DESCRIPTION
设置一个域在启动时自动开始.
OPTIONS
[--domain] <string> domain name, id or uuid #可以通过域名,id或uuid来控制
--disable 禁止自动启动
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
- vm1 关闭
virsh # autostart vm1 #开启虚拟机的开机自引导
域 vm1标记为自动开始
virsh # autostart vm1 --disable #关闭虚拟机开机自引导
域 vm1取消标记为自动开始
virsh # autostart vm1
域 vm1标记为自动开始
重启主机后,我们发现虚拟机已经可以自动启动
[root@KVM ~]# virsh list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
- vm1 running
(3)通过命令进行虚拟机的暂停和唤醒
[root@KVM ~]# virsh
欢迎使用 virsh,虚拟化的交互式终端。
输入:'help' 来获得命令的帮助信息
'quit' 退出
virsh # help suspend #查看命令帮助
NAME
suspend - 挂起一个域
SYNOPSIS
suspend <domain>
DESCRIPTION
挂起一个运行的域。
OPTIONS
[--domain] <string> domain name, id or uuid
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
6 vm1 running
virsh # suspend vm1 #暂停虚拟机
域 vm1 被挂起
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
6 vm1 暂停
virsh # resume vm1 #唤醒虚拟机
域 vm1 被重新恢复
virsh # list --all
Id 名称 状态
----------------------------------------------------
3 centos6.5 running
6 vm1 running