安装kvm

· 环境检查

# 检查硬件是否支持虚拟化
LC_ALL=C lscpu | grep Virtualization
# 检查内核是否已经包含了支持虚拟化所必须的模块
zgrep CONFIG_KVM /proc/config.gz
# 确定模块是否已经加载
lsmod | grep kvm
# 这里输出中需要包含
virtiolsmod | grep virtio
# 没有 virtio 时执行
sudo modprobe virtio

· 安装软件安装需要的软件包

yay -S virt-manager qemu libvirt ebtables dnsmasq bridge-utils openbsd-netcat

· 安装软件libguestfs on Arch Linux / Manjaro

添加源

$ sudo vim /etc/pacman.conf
# Should have below lines
[archlinuxfr]SigLevel = NeverServer = http://repo.archlinux.fr/$arch

安装

sudo pacman -Syy

yay -S --noconfirm --needed libguestfs

virt-manager, 图形化的管理界面

qemu QEMU 软件,提供 qemu-img 等命令

libvirt 提供管理虚拟机、存储、网络的功能

ebtables 桥接网络管理,用于 default NAT 网络

dnsmasq DHCP DNS 服务,用于 default NAT 网络

bridge-utils 桥接网络管理,用于桥接网络

openbsd-netcat 用于通过 SSH 管理

libguestfs 用于重置或消除虚拟机的配置以获得全新的OS安装状态

· 启动服务执行以下命令启动所需服务:

# 启动虚拟机管理后台服务

sudo systemctl start libvirtd

# 启动 default NAT 网络sudo virsh net-start default

· 设置开机启动

sudo systemctl enable libvirtd.service

sudo systemctl start libvirtd.service

· 使用普通账号使用kvm(此方法问题多,在命令行下还是加上sudo去执行吧)

sudo vim /etc/libvirt/libvirtd.conf

# 将UNIX域套接字组所有权设置为libvirt(第85行):

unix_sock_group = "libvirt"

# 设置R/W套接字的UNIX套接字权限(第102行):

unix_sock_rw_perms = "0770"

#将你的用户帐户添加到libvirt组:

sudo usermod -a -G libvirt $(whoami)

# newgrp 命令使当前普通用户登入到这个群组

newgrp libvirt

# 重启libvirt守护进程:

sudo systemctl restart libvirtd.service

· 开启嵌套虚拟化嵌套虚拟化功能使你可以在VM中运行虚拟机,我的CPU是intel的,启用内核模块为kvmintel,如果是amd的需要改为kvmamd:

sudo modprobe -r kvm_intel

sudo modprobe kvm_intel nested=1

要使此配置持久,请运行:

echo "options kvm-intel nested=1" | sudo tee /etc/modprobe.d/kvm-intel.conf

确认嵌套虚拟化设置为是:

systool -m kvm_intel -v | grep nested

nested = "Y"

nested_early_check = "N"

cat /sys/module/kvm_intel/parameters/nested

Y

创建虚拟机

创建虚拟机可以通过图形化界面进行创建,也可以通过模板文件快速创建vm,如果需要大批量的创建vm那么通过模板文件进行创建将非常快。网上有很多模板文件的解释说明,可以参考。但是由于每个环境都不一样,直接拿过来的模板吧文件无法直接使用,需要修改很多地方,这时候可以通过图形化界面来创建一个vm,再生成一个模板文件,在此基础上进行修改就不会有问题;

通过Virtual Machine Manager创建vm

1. 打开软件点击'加号'来创建一个虚拟机




manjaro anzhuang kvm manjaro安装kvm_虚拟机批量克隆工具

打开vmm



2. 选择第一个iso,点击下一步




manjaro anzhuang kvm manjaro安装kvm_kvm虚拟机_02


3. 第一个选框中选择本地的iso系统盘,在下面的类型中需要输入才能显示不同的操作系统类型,这里输入c之后能模糊查询到相关的系统类型,选择centos8。


manjaro anzhuang kvm manjaro安装kvm_创建虚拟机_03


4. 设置内存及cpu数


manjaro anzhuang kvm manjaro安装kvm_无法为共享或远程虚拟机创建克隆_04


5. 这一步是创建磁盘,选择下面这个一步,可以自定义磁盘路径,默认的磁盘路径:/var/lib/libvirt/images


manjaro anzhuang kvm manjaro安装kvm_虚拟化_05


6. 点击manage之后能看到这个界面,首先自定一个磁盘的存储路径,点击左边下方的加号。


manjaro anzhuang kvm manjaro安装kvm_虚拟机批量克隆工具_06


7. name和target Path可以自定义


manjaro anzhuang kvm manjaro安装kvm_虚拟化_07


8. 创建好之后,左边列表上选择刚刚创建的路径,右边点击volumes旁边的加号,创建虚拟磁盘。


manjaro anzhuang kvm manjaro安装kvm_kvm虚拟机_08


9. 创建虚拟机磁盘,点击finish完成。


manjaro anzhuang kvm manjaro安装kvm_kvm虚拟机_09


10. 上一步创建完成之后,然后选择磁盘,点击下一步。


manjaro anzhuang kvm manjaro安装kvm_kvm虚拟机_10


11.这一步选择虚拟网卡,然后点击finish。到这一步就完成了所有的创建过程。接着就是虚拟机的安装过程了。


manjaro anzhuang kvm manjaro安装kvm_虚拟化_11


使用配置文件创建虚拟机

配置文件可以通过图形化界面创建而生成,配置文件路径:/etc/libvirt/qemu/

· 通过已经有的虚拟机生成新的模板
sudo virsh dumpxml k8s-master>/home/momi/kvm/kubernetes-cluster/template/k8s-node01.xml
· 编辑修改模板文件修改模板名称
k8s-node01
* 修改uuid 使用命令:uuidgen
06931581-29c4-4715-b2ab-19dc68d7c151
· 修改磁盘路径
...
· 修改网卡的mac地址
# 使用下面命令生成mac地址
openssl rand -hex 6 | sed 's/../&:/g; s/:$//'
# 修改文件中网卡信息的mac地址
...
· 通过模板定义虚拟机
sudo virsh define ./k8s-node02.xml
Domain k8s-node02 defined from ./k8s-node02.xml
sudo virsh list --all
Id Name State
-----------------------------
2 k8s-master paused
- k8s-node01 shut off
- k8s-node02 shut off

· 通过console登录虚拟机

# 为了可以通过virsh console 登录虚拟机需要对虚拟机进行设置,登录虚拟机后台执行如下命令
grubby --update-kernel=ALL --args="console=ttyS0"
# 执行之后,重启
reboot
# 登录,console后面需要输入已经启动的虚拟机的id,通过virsh list查询
sudo virsh console 4

克隆虚拟机

克隆虚拟机,可以避免手动来修改这个配置信息通过使用镜像克隆虚拟机

# 查询所有
vmsudo virsh list --all
# 停止需要进行克隆的虚拟机
sudo virsh stop k8s-master
# 克隆虚拟机
sudo virt-clone --connect qemu:///system --original k8s-master --name k8s-node01 --file /home/momi/kvm/kubernetes-cluster/k8s-node01.qcow2

重置虚拟机

# 使用virt-sysprep 命令时如果报错需要进行升级
sudo update-libguestfs-appliance
# 使用下面命令重置虚拟机,并设置主机名密码
sudo virt-sysprep -v -x -d k8s-node01 --hostname k8s-node01