去评论
海欣资源

使用KVM服务创建虚拟机教程

dscca
2022/05/09 20:28:29
kvm的概念
KVM(Kernel-based Virtual Machine)是一个开源软件,基于内核的虚拟化技术,实际是嵌入系统的一个虚拟化模块,通过优化内核来使用虚拟技术,该内核模块使得Linux变成了一个Hypervisor,虚拟机使用 Linux 自身的调度器进行管理。
KVM 是基于虚拟化扩展(Intel VT或者AMD-V)的X86硬件的开源的Linux原生的全虚拟化解决方案。KVM中,虚拟机被实现为常规的Linux进程,由标准Linux调度程序进行调度;虚机的每个虚拟CPU被实现为一个常规的Linux进程。这使得KVM能够使用 Linux内核的已有功能。但是,KVM本身不执行任何硬件模拟,需要客户空间程序通过/dev/kvm接口设置一个客户机虚拟服务器的地址空间,向它提供模拟的I/O,并将它的视频显示映射回宿主的显示屏。目前这个应用程序是QEMU。
前期准备
使用 VMWare Workstation 软件安装 CentOS 7.2 操作系统,镜像使用提供的CentOS-7-x86_64-DVD-1511.iso,关闭防火墙并且配置 SELinux 规则,配置 IP 地址。YUM源使用提供的 kvm_yum 文件夹【VMware 虚拟机直接使用 centos 镜像安装,不需要提供的文件夹】
案例实施

1.安装KVM
    配置本地yum源。
    [root@localhost ~]rm -rf /etc/yum.repos.d/*
    [root@localhost ~]# vi /etc/yum.repos.d/local.repo
    [centos]
    name=centos
    baseurl=file:///opt/centos7.2
    gpgcheck=0
    enabled=1
    [root@localhost ~]mkdir /opt/centos7.2
    [root@localhost ~]mount CentOS-7-x86_64-DVD-1511.iso /opt/centos7.2
    关闭防火墙。
    [root@localhost ~]systemctl stop firewalld
    [root@localhost ~]setenforce 0
    使用yum安装KVM的主要组件及工具。
    [root@localhost ~]yum install qemu-kvm openssl libvirt -y net-tools
    命令解释:
    qemu-kvm qemu-img (qcow2,raw)作用:管理虚拟机的虚拟磁盘
    openssl: 进行安全通信,避免窃听,同时确认另一端连接者的身份
    libvirt 作用: 虚拟机的管理软件
    启动libvirtd服务。
    [root@localhost ~]systemctl start libvirtd
    将/usr/libexec/qemu-kvm 链接为/usr/bin/qemu-kvm。
    [root@localhost ~]# ln -s /usr/libexec/qemu-kvm /usr/bin/qemu-kvm

2.创建 NAT 模式 KVM 虚拟机
    将cirros-0.3.3-x86_64-disk.img镜像与qemu-ifup-NAT脚本文件上传到系统/root目录下。

给脚本赋予执行权限。
    [root@localhost ~]# chmod +x /root/qemu-ifup-NAT
    通过 qemu-kvm 命令启动 KVM 虚拟机。
    [root@localhost ~]#qemu-kvm -m 1024 -drive file=/root/cirros-0.3.3-x86_64-disk.img,if=virtio -net nic,model=virtio -net tap,script=/root/qemu-ifup-NAT -nographic -vnc :1
        -m 内存大小
        drive file=/root/cirros-0.3.3-x86_64-disk.img 硬盘映像文件路径,采用这个镜像
        -net tap,[script=file]:通过物理机的TAP网络接口连接,可使用script=file指定的脚本(默认为/etc/qemu-ifup)来配置当前网络接口
        -nographic:默认情况下,qemu使用SDL来显示VGA输出,而此选项用于禁止图形接口,此时qemu类似于一个简单的命令行程序,其仿真串口设备将被重定向到控制台

3.验证
     创建虚拟机完成后,cirros 用户登录虚拟机,输入用户名为 cirros,密码为 cubswin。然后输入 ip addr list 命令查询 IP 地址,最后输入 route -n 命令查询路由表。示例代码如下:

查询后,退出KVM虚拟机,代码如下所示: