KVM入门


KVM

KVM(Kernel-based Virtual Machine)是众多虚拟化技术之一,它是Linux内核中的一个模块,该模块依赖于CPU,如果CPU支持虚拟化,那么该模块才可以被加载。KVM技术是硬件层面的虚拟化,它会为我们虚拟各种硬件设备,这样我们可以在已有操作系统上运行别的操作系统。

检查CPU是否支持虚拟化

sudo apt install cpu-checker -y
sudo kvm-ok

先安装cpu-checker工具,然后使用其带的kvm-ok命令检查kvm模块是否加载

  • 显示‘/dev/kvm does not exist’则表示kvm模块未被加载,执行sudo modprobe kvm_intel命令进行加载
  • 当然加载kvm模块需要开启CPU虚拟化技术,在BIOS中设置Intel Virtualization Technology为Enable

注:lsmod | grep kvm也可以查看kvm模块是否加载

安装软件包

安装服务端软件包

sudo apt install ubuntu-virt-server

软件包ubuntu-virt-server依赖的两个主要的软件包是qemu-kvm和libvirt-bin。

  • qemu将内核中的虚拟功能暴露给用户,提供了用户空间的虚拟机环境
  • libvirt是一个工具库,通过它可以方便的管理各种虚拟机软件。Libvirt几乎支持所有常见的虚拟技术,包括KVM,Xen,LXC,VMware,VirtualBox等
安装客户端软件包
sudo apt-get install virtinst

该软件包提供4个命令来管理虚拟机

  • virt-conver --------把一种格式的虚拟机转为另一种格式
  • virt-clone --------克隆虚拟机
  • virt-image -------创建虚拟机镜像
  • virt-install -------创建新的虚拟机

创建虚拟机

配置虚拟网卡

默认情况下,KVM新创建的虚拟机使用NAT网络(虚拟机可以访问外面,外面看不到它)。这种NAT机制不通过网卡,只通过内核内部的IP转发来进行数据传输,所以外面的机器访问不到虚拟机。为了能让外面的机器访问虚拟机,需要创建虚拟网桥,把虚拟机的虚拟网卡与外部物理网卡通过网桥桥接起来。

1. 启动IP转发

编辑/etc/sysctl.conf文件

# 去掉该行前面的#号,开启转发功能
net.ipv4.ip_forward = 1

执行sudo sysctl -p命令使配置生效

2. 创建桥接设备

在宿主机上安装bridge-utils软件包:

sudo apt-get install bridge-utils

编辑/etc/network/interfaces,然后添加虚拟网桥网桥br0,将物理网卡enp4s0f2添加到网桥。

注:将物理网卡enp4s0f2添加到br0后,物理网卡的IP地址将失去作用,所以下面的配置文件中没有为enp4s0f2指定IP

[...]
auto enp4s0f2
iface enp4s0f2 inet manual

auto br0
iface br0 inet dhcp
	address 10.10.10.2          网桥IP地址
    netmask 255.255.255.0       掩码
    gateway 10.10.10.1
	bridge_ports enp4s0f2           #将物理网卡添加到虚拟网桥中
	bridge_stp off
	bridge_maxwait 0
	bridge_fd 0
[...]

重启网络

#sudo  /etc/init.d/networking restart
或
#sudo service networking restart

重启网络之后,执行brctl show查看网桥是否添加成功,下面显示我的机器已成功创建网桥,并将enp4s0f2网卡添加到网桥中

11

3. 创建虚拟机

首先准备好镜像文件,我这里准备了ubuntu-server-adm64.iso镜像文件,然后通过前面提到的命令来创建虚拟机

sudo virt-install \
--name=myvps1 \
--ram=512 \
--network bridge:br0 \
--disk path=/var/lib/libvirt/images/myvps1.img,bus=virtio,size=10 \
--graphics vnc,listen=0.0.0.0
--noautoconsole \
--hvm \
--cdrom ./ubuntu-server-adm64.iso

下面解释一下各个参数的作用:

  • --name=myvps1 虚拟机名称为myvps1
  • --ram=512 虚拟机内存大小为512MB
  • --network bridge:br0 指定网络为网桥设备,后面具体解释
  • --disk 指定虚拟盘的位置,虚拟盘可以是一个文件,分区或者一个逻辑卷。例子指定为myvps1.img文件,空间为10G,总线使用virtio总线
  • --graphics 指定图形界面,例子中指定vnc远程桌面控制,即我们可以使用vnc客户端对虚拟机进行远程桌面控制
  • --noautoconsole 不要自动连接到虚拟机控制台,主要因为我们安装的服务器版虚拟机,它上面没有图形界面
  • --hvm 创建功能完整的虚拟机
  • --cdrom 指定安装镜像位置

当然关于参数的详解使用man virt-install来查看

如果虚拟机创建成功则会显示以下内容

11

4. 连接虚拟机

我们使用VNC软件来连接虚拟机,VNC软件是一款开源的Linux远程桌面控制软件,和Windows下的Teamviewer或者是QQ自带的远程桌面控制一样。VNC分服务端和客户端,安装客户端的电脑可以远程控制安装服务端的电脑,刚才我们在创建虚拟机的时候,指定支持vnc远程控制,所以我们下载一个vnc客户端就可以了。下载地址

下面是vnc软件的连接界面,VNS Server填写网桥的IP即可,Name可以随意命名。

图片服务器挂了

连接成功后就会开始装系统的步骤,这里就不介绍了。

5. 遗留问题

创建虚拟机的时候会自动创建两块虚拟网卡出来,虚拟机内部有一块(ens3),虚拟机外部也有一块(vnet0),这个下图有显示。在创建虚拟机的我们指定为网桥,意思是将来把外部那块网卡(vnet0)添加到网桥中。而物理机的网卡(enp4s0f2)已被添加的网桥中,这样外部就可以和虚拟机进行通信了(虚拟机内部那块网卡IP必须和网桥在一个IP段)。

外部虚拟网卡

图片服务器挂了

网桥br0中添加了两块网卡(端口)

图片服务器挂了

管理虚拟机

启动虚拟机

使用下面的命令来启动刚创建的虚拟机

# virsh start myvps1

让虚拟机随物理机一起启动

# virsh autostart myvps1

列出正在运行的虚拟机,所有虚拟机,关闭的虚拟机

# virsh list

# virsh list --all

# virsh list --inactive

重启,关机

重启

# virsh reboot myvps1

关机

# virsh shutdown myvps1

保存,恢复状态

有时我们需要把某个虚拟机暂时关闭,而又想启动时恢复当时的状态,这是需要用到save命令

# virsh save myvps1 myvps1-20171202.state

执行上面的命令后,虚拟机的内存会被保存到一个文件中,然后虚拟机自动关闭

# virsh restore myvps1-20171202.state

恢复虚拟机

挂起,恢复

挂起

# virsh suspend myvps1

恢复

# virsh resume myvps1

空间扩容

在虚拟机运行一段时间后可能会需要添加更多的磁盘空间。这里可以使用attach-disk命令对磁盘扩容。

1. 生成文件

我们使用dd命令来产生一个文件

# sudo dd if=/dev/zero   of=/var/lib/libvirt/images/myvps1-disk2.image bs=1M count=4096

该命令会为我们生成一个4GB大小的文件

2. 把文件添加到虚拟机

使用attach-disk命令,把刚刚创建的文件添加到myvps1虚拟机,作为其磁盘使用:

# virsh attach-disk myvps1 \
/var/lib/libvirt/images/myvps1-disk2.img vdb \
--live \
--cache none

这样一个名为vdb的虚拟磁盘就被添加到虚拟机中了

3. 分区

将硬盘添加到虚拟机后,需要在虚拟机中对新的硬盘进行格式化才能使用。下面的操作都是在虚拟机myvps1中进行的

查看硬盘是否添加成功

# sudo fdisk -l

图片服务器挂了

上图可以看到已经有磁盘/dev/vdb,但是未分区和格式化,关于Linux下如何对分区进行格式化请自行百度

增加CPU核数

查看主机cpu核数

# virsh nodeinf0

我的机器显示两个核,也就是每个虚拟机最多能有两个CPU核

图片服务器挂了

查看当前虚拟机(myvps1)虚拟机核数,显示只有一个核,vcpu 0表示第0个核,而不是核数为0

# virsh vcpuinfo myvps1

图片服务器挂了

关闭虚拟机
# virsh shutdown myvps1
修改最大核数为2核,并设置到配置文件(/etc/libvirt/qemu下)
# virsh setvcpus myvps1 2 --maximum --config
设置核数为2到配置文件(/etc/libvirt/qemu下)
# virsh setvcpu2 myvps1 2 --config
重启虚拟机
# virsh start myvps1

图片服务器挂了

上图显示出两个cpu核表示我们设置成功

增加内存

增加内存核增加CPU核数一样,先设置最大内存,在设置当前内存

查看当前虚拟机信息,可以看到当前的内存设置
# virsh dominfo myvps1
设置最大内存为2G
# virsh setmaxmem myvps1 2097152 --config
设置当前内存为1G
# virsh setmem myvps1 1048576 --config
重启虚拟机
# virsh shutdown myvps1
# virsh start myvps1

克隆虚拟机

有时我们需要几台环境相同的虚拟机,这时,我们不需要从头创建,只需要克隆即可

先关闭虚拟机
# virsh shutdown myvps1
克隆虚拟机
# sudo virsh-clone \
--original myvps1 \
--name myvps3 \
--file /var/lib/libvirt/images/myvps3.img
启动克隆的虚拟机
# virsh start myvps3

虚拟机镜像管理

虚拟机镜像做好后,我们可能需要修改虚拟机的IP地址,虚拟机内部的文件等。当然可以先启动虚拟机,然后通过VNC或者SSH进去修改。不过,方便的方法时使用virt-edit命令来直接编辑虚拟机镜像文件即可。virt-edit是libguestfs-tools包提供的命令。

# sudo apt install libguestfs-tools

这个软件包专门管理虚拟机的虚拟磁盘文件,提供的工具有:

  • virt-cat 显示虚拟机中文件的内容(相当于cat命令)
  • virt-edit 编辑虚拟机中的文件(相当于vi命令)
  • virt-inspector 显示虚拟机的操作系统等详细信息
  • virt-tar 在虚拟机和主机之间传递文件

当然还有很多命令,这里就不一一列出了

删除虚拟机

# virsh undefine myvps1
# virsh pool-refresh default

在执行virsh undefine myvps1时,虚拟机的虚拟磁盘文件/var/lib/libvirt/images/myvps1.img文件不会被删除,需要手动删除。删除完毕后需要执行virsh pool-refresh default命令清楚虚拟机的缓存记录


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM