CentOS 7 部署 KVM 虚拟化

简介: CentOS 7 部署 KVM 虚拟化

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'
目录
相关文章
|
1月前
|
监控 Linux 应用服务中间件
centos7 部署zabbix5 踩坑笔记
centos7 部署zabbix5 踩坑笔记
|
1天前
|
Java Linux
IDEA远程调试Centos部署的jar包
IDEA远程调试Centos部署的jar包
4 0
|
5天前
|
Java Linux
杨校老师课堂之CentOS7部署开发环境Jdk1.8【Linux】
杨校老师课堂之CentOS7部署开发环境Jdk1.8【Linux】
11 0
|
1月前
|
Shell Linux 应用服务中间件
centos系统内容器部署服务访问不到是因为run后面加了bash
centos系统内容器部署服务访问不到是因为run后面加了bash
|
1月前
|
存储 关系型数据库 Linux
CentOS如何使用Docker部署Plik服务并实现公网访问本地设备上传下载文件
CentOS如何使用Docker部署Plik服务并实现公网访问本地设备上传下载文件
46 4
|
1月前
|
存储 安全 网络协议
云服务器 Centos7 部署 Elasticsearch 8.0 + Kibana 8.0 指南
云服务器 Centos7 部署 Elasticsearch 8.0 + Kibana 8.0 指南
50 0
|
1月前
|
存储 分布式计算 资源调度
centos 部署Hadoop-3.0-高性能集群(二)
centos 部署Hadoop-3.0-高性能集群(二)
29 0
centos 部署Hadoop-3.0-高性能集群(二)
|
1月前
|
存储 Linux KVM
虚拟化技术之KVM安装与使用
虚拟化技术之KVM安装与使用
|
1月前
|
Linux 数据库 开发者
Centos7安装docker并部署halo建站
Docker 是一个开源的应用容器引擎,它允许开发者将应用及其依赖打包到可移植的容器中,然后在任何支持 Docker 的平台上运行。Docker 的核心概念包括镜像(Image)、容器(Container)和仓库(Repository)。镜像是创建容器的基础,容器是镜像的运行实例,而仓库是存储和分发镜像的中心仓库。 Docker 的优势在于快速、一致地交付应用,实现响应式部署和扩展,以及更高效地利用硬件资源。它常用于简化配置、代码流水线管理、提
71 0
|
1月前
|
运维 安全 Linux
如何在CentOS部署JumpServer堡垒机并实现无公网ip环境远程访问
如何在CentOS部署JumpServer堡垒机并实现无公网ip环境远程访问

热门文章

最新文章