KVM的组件

  • ① kvm.ko:模块

    • API 应用程序编程接口
  • ② qemu-kvm:用户空间的工具程序;

    • qemu-KVM 是一种开源虚拟器,它为KVM管理程序提供硬件仿真。
    • 运行中的一个 kvm 虚拟机就是一个 qemu-kvm 进程,运行 qemu-kvm 程序并传递给它合适的选项及参数即能完成虚拟机启动,终止此进程即能关闭虚拟机;
  • ③ libvirt 虚拟化库:Libvirt是C工具包,

    • libvirt可以与最近版本的Linux(以及其他操作系统)的虚拟化功能进行交互。主包包含了导出虚拟化支持的libvirtd服务器。
    • libvirt 包含 C/S:
      • Client:
        • libvirt-client
        • virt-manager
      • Daemon:
        • libvirt-daemon

KVM模块load进内存之后,系统的运行模式

  • 内核模式:GuestOS 执行 IO 类的操作时,或其它的特殊指令操作时的模式;它也被称为"Guest-Kernel"模式;

  • 用户模式:Host OS的用户空间,用于代为GuestOS发出IO请求;

  • 来宾模式:GuestOS 的用户模式;所有的非IO类请求

部署KVM

下面开始套娃,我vmware开的虚拟机,给了4C16G,KVM的最低要求是内存不能低于4G

基础配置
  • 必须跑在 x86 系统的架构上

  • 必须支持硬件级虚拟化

    • vmx: Intel VT-x
    • svm: AMD AMD-v
  • 虚拟机上再虚拟化,需开启虚拟化 Intel VT-x/EPT

判断CPU是否支持硬件虚拟化
# egrep -i 'vmx|svm|lm' /proc/cpuinfo
  • 注意:vmx 或 svm 必须出现一个,表示是支持的
    • vmx: Intel VT-x
    • svm: AMD AMD-v
flags           : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ss ht syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc 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 ssbd ibrs ibpb stibp tpr_shadow vnmi ept vpid fsgsbase tsc_adjust bmi1 avx2 smep bmi2 invpcid xsaveopt arat spec_ctrl intel_stibp flush_l1d arch_capabilities
检测 kvm 模块是否装载
# lsmod | grep kvm
kvm_intel             183621  0
kvm                   586948  1 kvm_intel
irqbypass              13503  1 kvm

如果没有装载 kvm 模块,执行 modprobe kvm 命令即可

安装用户端工具 qemu-kvm
# yum install -y libvirt* virt-* qemu-kvm*
  • libvirt 虚拟机管理
  • virt 虚拟机安装克隆
  • qemu-kvm 管理虚拟机磁盘

安装的比较多,有300多个包

启动服务
# systemctl start libvirtd.service
查看网卡
# virsh net-list
 Name                 State      Autostart     Persistent
----------------------------------------------------------
 default              active     yes           yes
配置桥接网卡br0

这一步,根据实际情况操作,启动KVM后,会生成virbr0网卡,供KVM创建的虚拟机使用,KVM默认虚拟机的网络为NAT模式

先备份一下网卡配置文件,万一有问题,还能恢复

如果是CentOS发行版,可以关掉NetworkManager服务,免得他捣乱

# systemctl disable NetworkManager --now
# virsh iface-bridge eth0 br0

把自己的物理网卡 eth0 作为交换机,把 br0 当网卡,提供IP(切记,别复制直接用,将eth0改为自己的网卡名称,使用ip a命令可以查看自己的网卡名称)

注意:命令可能会卡死或出错,终端被强制退出;等一会,在登录就OK 了

# cp /etc/libvirt/qemu/networks/default.xml /etc/libvirt/qemu/networks/br0.xml
# vim /etc/libvirt/qemu/networks/br0.xml
<network>
  <name>br0</name>
  <forward mode='bridge'/>
  <bridge name='br0'/>
</network>
启动br0网卡
# virsh net-define /etc/libvirt/qemu/networks/br0.xml
# virsh net-autostart br0
# virsh net-start br0
# virsh net-list
 Name                 State      Autostart     Persistent
----------------------------------------------------------
 br0                  active     yes           yes
 default              active     yes           yes

使用KVM创建虚拟机

图形化界面,可以使用 virt-manager 来创建虚拟机,都是点点点的操作

这里就使用命令行的方式创建虚拟机了

注意:需要先上传一个系统镜像文件到KVM服务器上

使用VNC的方式
安装VNC
# yum install -y tightvnc
使用命令创建虚拟机
# mkdir /opt/kvm
# virt-install --virt-type kvm \
--name suse12-sp3 \
--memory 2048 \
--vcpus 1 \
--disk /opt/kvm/suse12-sp3.qcow2,format=qcow2,size=30 \
--cdrom /opt/kvm/SLE-12-SP3-Server-DVD-x86_64-GM-DVD1.iso \
--network network=default \
--graphics vnc,listen=0.0.0.0,port=5900 \
--noautoconsole

打开VNC,输入本机的IP加上创建的时候指定的端口5900,即可开始安装虚拟机

端口是自定义的,并非固定的5900

# vncviewer               # 打开 VNC

使用VNC部署的虚拟机,当虚拟机启动的时候,会自动启用创建时所指定的端口,可以再次使用VNC远程连接虚拟机,当虚拟机关机的时候,端口也会自动关闭

# 关机状态下的虚拟机,需要加上--all参数才会看得到
# virsh list --all
 Id    Name                           State
----------------------------------------------------
 -     suse12-sp3                     shut off

# ss -nltp | grep 5900
# virsh start suse12-sp3
Domain suse12-sp3 started

# virsh list --all
 Id    Name                           State
----------------------------------------------------
 6     suse12-sp3                     running

# ss -nltp | grep 5900        # 虚拟机启动后,端口就出来了
LISTEN     0      1            *:5900                     *:*                   users:(("qemu-kvm",pid=31317,fd=19))
参数说明
参数说明
--virt-type要使用的虚拟化名称(kvm, qemu, xen, …)
--name虚拟机的名称
--memory配置内存大小,默认单位为MiB
--vcpus配置虚拟 CPU(vcpu) 数量
--disk指定存储的各种选项
--cdrom安装的介质
--network虚拟机使用的网络接口,可以使用 virsh net-list 命令查看当前拥有的网络接口
--graphics配置虚拟机的显示设置,有vnc、none、spice
--noautoconsole不要自动尝试连接到客户端控制台
不使用VNC的方式
# virt-install --virt-type=kvm \
--name=centos7.7 \
--vcpus=1 \
--memory=2048 \
--location /opt/kvm/CentOS-7.7-x86_64-DVD-1908.iso \
--disk /opt/kvm/centos7.7.qcow2,format=qcow2,size=30 \
--network network=default \
--graphics none \
--extra-args='console=ttyS0'
使用kickstart文件的方式
# centos系统安装完成后,在/root目录下会有一个cfg后缀的kickstart文件
# cp anaconda-ks.cfg /opt/kvm/
# cd /opt/kvm/
# vim anaconda-ks.cfg

由于kvm安装的虚拟机,磁盘都是vda,所以需要将文件内的sda全部修改为vda

由于虚拟机分配的是100G,但是KVM创建的虚拟机,咱给的是30G,所以需要修改分区,为了省事,直接使用了自动分区autopart --type=lvm

kickstart文件之前没接触过,就没有过多的修改了,以后有时间再去研究一下

#version=DEVEL
# System authorization information
auth --enableshadow --passalgo=sha512
# Use graphical install
# graphical
text
# Run the Setup Agent on first boot
firstboot --enable
ignoredisk --only-use=vda
# Keyboard layouts
keyboard --vckeymap=us --xlayouts='us'
# System language
lang en_US.UTF-8

# Network information
network  --bootproto=dhcp --device=eth0 --ipv6=auto --activate
network  --hostname=localhost.localdomain

# Root password
rootpw --iscrypted $6$3IMre6QwQrXPP1tr$2t6ACeLAG/Ogg.nSdX.iNwxZLkrpN.sC6u/e6GYqV.GOvsmA1zu9rA7ceYZmgUvWgPy2NyuM8q4S75Kk9cjKn.
# System services
services --enabled="chronyd"
services --disabled="NetworkManager"
services --disabled="firewall"
# System timezone
timezone Asia/Shanghai --isUtc --nontp
# System bootloader configuration
bootloader --location=mbr --boot-drive=vda
# Partition clearing information
clearpart --all --initlabel --drives=vda
# Disk partitioning information
autopart --type=lvm

%packages
@^minimal
@core
@development
@system-admin-tools
chrony

%end

%addon com_redhat_kdump --disable --reserve-mb='auto'

%end
# virt-install --virt-type=kvm \
--name=centos7.7-ks \
--vcpus=1 \
--memory=2048 \
--location /opt/kvm/CentOS-7.7-x86_64-DVD-1908.iso \
--disk /opt/kvm/centos7.7-ks.qcow2,format=qcow2,size=30 \
--network network=default \
--graphics none \
--initrd-inject=/opt/kvm/anaconda-ks.cfg \
--extra-args='ks=file:/anaconda-ks.cfg console=ttyS0'
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐