kvm虚拟化技术
目录
一.虚拟化介绍
二.全虚拟化和半虚拟化
三.kvm介绍
四.kvm部署准备工作
五.部署kvm
六.部署kvm web管理界面
七.kvm web界面管理
kvm连接管理
创建ssh连接
kvm存储管理
kvm网络管理
实例管理
一.虚拟化介绍
虚拟化是一种将计算机资源进行抽象化的技术,可以将一台物理计算机划分为多个虚拟计算机,每个虚拟计算机都具有独立的操作系统和应用程序。通过虚拟化,可以将计算机的处理能力、存储空间和网络带宽等资源进行有效的利用和管理。
虚拟化技术有多种形式,包括服务器虚拟化、存储虚拟化和网络虚拟化等。其中,服务器虚拟化是最常见的形式,它可以将一台物理服务器划分为多个虚拟服务器,每个虚拟服务器都可以独立运行不同的操作系统和应用程序。这样可以提高服务器的利用率,减少硬件成本,并且方便管理和维护。
虚拟化技术的好处包括:
资源利用率提高:通过虚拟化,可以将计算机的资源进行合理的分配和利用,提高资源的利用率,减少资源的浪费。
灵活性增强:虚拟化可以将计算机的资源进行灵活的配置和管理,可以根据需求动态地分配资源,提高系统的灵活性和可扩展性。
管理简化:虚拟化可以将多个物理计算机集中管理,简化了系统的管理和维护工作,提高了管理效率。
高可用性:通过虚拟化,可以实现虚拟机的快速迁移和容错,提高系统的可用性和容灾能力。
虚拟化技术在云计算、数据中心和企业IT环境中得到广泛应用,为用户提供了更加灵活、可靠和高效的计算资源。
二.全虚拟化和半虚拟化
全虚拟化和半虚拟化是虚拟化技术的两种主要形式。
全虚拟化是指在虚拟机中运行的操作系统不需要进行任何修改,可以直接运行在虚拟化层之上。在全虚拟化中,虚拟机管理器(Hypervisor)负责将物理计算机的资源虚拟化,并提供给虚拟机使用。虚拟机管理器需要模拟硬件设备,如处理器、内存、硬盘和网络等,以便虚拟机可以在虚拟化环境中运行。全虚拟化提供了更高的隔离性和安全性,但由于需要模拟硬件设备,性能开销较大。
半虚拟化是指在虚拟机中运行的操作系统需要进行修改,以便与虚拟化层进行通信和协作。在半虚拟化中,虚拟机管理器与虚拟机之间可以直接通信,虚拟机可以主动向虚拟机管理器发出请求,并获取物理计算机的资源。由于虚拟机操作系统与虚拟化层的协作,半虚拟化可以减少虚拟化的性能开销,提高系统的性能和效率。然而,半虚拟化要求操作系统进行修改,因此不适用于所有操作系统。
总的来说,全虚拟化提供了更高的隔离性和安全性,适用于各种操作系统,但性能开销较大。而半虚拟化可以提供更好的性能和效率,但需要操作系统进行修改。选择全虚拟化还是半虚拟化取决于具体的应用场景和需求。
三.kvm介绍
KVM(Kernel-based Virtual Machine)是一种开源的虚拟化技术,它是在Linux内核中实现的一种全虚拟化解决方案。KVM利用虚拟化技术,可以在一台物理主机上同时运行多个虚拟机,每个虚拟机都可以运行不同的操作系统和应用程序,实现服务器资源的最大化利用和灵活性。
KVM的优点包括:
高性能:KVM利用Linux内核的虚拟化技术,避免了传统虚拟化技术中的性能瓶颈,虚拟机的性能接近于物理机。
安全性:KVM的虚拟机之间是完全隔离的,可以提供更高的安全性。
灵活性:KVM支持多种操作系统和应用程序,可以在同一台主机上运行不同的操作系统和应用程序。
可扩展性:KVM可以通过集群的方式进行扩展,提高服务器的可用性和容错性。
开源:KVM是一种开源技术,拥有庞大的社区支持和开发者参与,可以获得更多的技术支持和更新。
总之,KVM是一种高性能、安全、灵活和可扩展的虚拟化技术,适用于大规模的服务器虚拟化和云计算环境。
四.kvm部署准备工作
部署前请确保你的CPU虚拟化功能已开启。分为两种情况:
- 虚拟机要关机设置CPU虚拟化
- 物理机要在BIOS里开启CPU虚拟化
主机说明 | 主机名 | ip | 系统 |
kvm服务机 | c71.example.com | 192.168.187.150 | centos7 |
kvm web机 | c72.example.com | 192.168.187.160 | centos8 |
五.部署kvm
阿里云官方镜像站centos镜像下载
# 1.配置yum源,这里使用阿里云官方镜像源
# 备份原先的本地yum源
[root@c71 ~]# mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup# 下载yum源
[root@c71 yum.repos.d]# curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo# 下载epel源
[root@c71 yum.repos.d]# wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo# 重新加载缓存
[root@c71 yum.repos.d]# yum makecache# 非阿里云ECS用户会出现 Couldn't resolve host 'mirrors.cloud.aliyuncs.com' 信息,不影响使用。用户也可自行修改相关配置:
[root@c71 yum.repos.d]# sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo# 2.关闭防火墙与selinux
[root@c71 ~]# systemctl disable --now firewalld
[root@c71 ~]# setenforce 0
[root@c71 ~]# sed -ri 's/^(SELINUX=).*/\1disabled/g' /etc/selinux/config# 3.验证CPU是否支持KVM;如果结果中有vmx(Intel)或svm(AMD)字样,就说明CPU的支持的
[root@c71 ~]# egrep -o 'vmx|svm' /proc/cpuinfo
vmx
vmx
vmx
vmx# 4.kvm安装
[root@c71 ~]# yum -y install qemu-kvm qemu-kvm-tools qemu-img virt-manager libvirt libvirt-python libvirt-client virt-install virt-viewer bridge-utils libguestfs-tools因为虚拟机中网络,我们一般都是和公司的其他服务器是同一个网段,所以我们需要把 \
KVM服务器的网卡配置成桥接模式。这样的话KVM的虚拟机就可以通过该桥接网卡和公司内部 \
其他服务器处于同一网段此处我的网卡是ens33,所以用br0来桥接ens33网卡[root@c71 ~]# cd /etc/sysconfig/network-scripts/
[root@c71 network-scripts]# ls
ifcfg-ens33 ifdown-isdn ifup ifup-plip ifup-tunnel
ifcfg-lo ifdown-post ifup-aliases ifup-plusb ifup-wireless
.....省略[root@c71 network-scripts]# cp ifcfg-ens33 ifcfg-br0
[root@c71 network-scripts]# cat ifcfg-br0
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="sta