KVM虚拟化环境准备

1. 概述
2. 环境准备
2.1 硬件环境
2.2 软件环境
2.2.1 YUM安装软件包
2.2.2 环境检查
2.2.3 启动libvirtd服务
2.3 网络环境
2.3.1 复制网卡配置文件
2.3.2 修改网卡配置文件
2.3.4 重启网络服务
2.3.5 查看验证

1. 概述

本系列博客是想在VMware workstation创建的虚拟机console中,开启KVM虚拟化,使用kvm虚拟机快速部署测试环境。

注:有关虚拟化的理论部分,参照博客《》,有关KVM的理论部分,参照博客《》

2. 环境准备

2.1 硬件环境

VMware workstation提供了虚拟机的创建平台。同时也提供了为这些虚拟机的CPU和IO管理虚拟化的功能。

如下图,就为虚拟机console的CPU,配置了虚拟化引擎的功能:

虚拟化InterVT-x和AMD-V是两大处理器厂商提供的硬件虚拟化技术

虚拟化IOMMU,相当于在BIOS中实现的IO接口虚拟化技术,提供给KVM的SRV,以后的博客中探讨

如果console勾选了上述【虚拟化引擎】三个选项,那么可以进入到系统内部,查看cpu信息,确认是否启动了该功能。

console中,执行命令:egrep "vmx|svm" /proc/cpuinfo,有字段输出,证明当前系统的处理器已经支持虚拟化了。

2.2 软件环境

2.1内容中,kvm宿主OS(操作系统)的处理器能够支持虚拟化,但是OS中需要kvm虚拟化的软件环境,方可进行虚拟机的部署

本博客中,由于最小化安装,定制软件包时,并没有定制虚拟化的部分,因此需要采用YUM进行KVM环境部署。

首先查看系统中,有没有安装kvm软件包,执行rpm -qa | grep kvm,无输出表示未安装。

2.2.1 YUM安装软件包

1. 安装内核支持:yum -y install qemu-kvm qemu-kvm-tools qemu-img gpxe-roms-qemu qemu-guest-agent
2. 安装用户层图形界面工具:yum -y install virt-manager virt-viewer virt-top virt-what
3. 安装用户层命令行工具:yum -y install python-virtinst
4. 安装API管理工具:yum -y install libvirt libvirt-client libvirt-python libvirt-snmp

建议首次安装时,采用:yum -y install xxx && echo OK >>/var/log/yum.log的方式,观察各个软件包的依赖环境

安装qemu-kvm时,同时安装了gpxe-roms-qemu,qemu-img和其他依赖软件包

安装libvirt时,安装的依赖软件包比较多,包含了libvirt-client;安装libvirt-snmp时,包含了net-snmp-libs依赖包

安装virt-manager时,安装的依赖包也很多,主要是图像库

安装virt-viewer时,安装了openssh-clients库

总结:

yum -y install qemu-kvm qemu-kvm-tools qemu-guest-agent virt-manager virt-viewer virt-top virt-what python-virtinst libvirt libvirt-python libvirt-snmp

上述软件包是在最小化OS下安装,因此在非最小化的OS下安装,可能不需要这么多。将其做出脚本存放在/usr/local/globle/scripts/kvm/install下

具体脚本内容参见包括《虚拟机console全局脚本.md》

涉及到的依赖环境类别主要包括:python,gtk,snmp,ssh,qemu,kvm等

2.2.2 环境检查

此时通过rpm来检查kvm环境,rpm -qa | egrep "kvm|qemu"

执行命令:ls -lrt /dev/kvm 查看到内核接口设备

执行命令:service libvirtd status,看到libvirtd服务是未运行的

2.2.3 启动libvirtd服务

执行命令:service libvirtd start,会存在报错

warning : virGetHostname:2294 : getaddrinfo failed for ‘console‘: 未知的名称或服务

这是因为libvirtd不能在/etc/hosts中找到和console对应的地址。

执行命令:echo "127.0.0.0 console" >> /etc/hosts,然后service libvirtd restart,发现提示已经没有了

上述过程已经说明,kvm宿主机console已经具备了初步的部署kvm虚拟机的环境。

2.3 网络环境

kvm虚拟机当然是可以像VMware workstation一样使用的,作为一款应用级别的软件,来创建多种虚拟化的操作系统。但是KVM更多地是应用在一种生产环境中,作为拥有足够计算资源的物理机的替代,实现安全隔离或者更加快捷的管理。因此这样的应用场景,就需要KVM虚拟机能够桥接在物理网络中,和物理机处于同一个网络级别,来屏蔽网络差异性。所以,需要在宿主机配置桥接网络。console的桥接网络配置过程,可参考如下。

2.3.1 复制网卡配置文件

console在配置时,分配了两块NIC,一块是配置了MAC地址00:00:00:80:00:08接入NAT网络的NIC,一块是配置了MAC为00:00:00:10:00:08接入仅主机模式网络的NIC。

在console的OS中,接入NAT网络的网卡eth0的配置名称为:/etc/sysconfig/network-scripts/ifcfg-eth0,另外一块则为/etc/sysconfig/network-scripts/ifcfg-eth1。

很显然,要对这两块网卡操作。

进入目录,cd /etc/sysconfig/network-scripts/

复制配置文件:cp ifcfg-eth0 ifcfg-br0 && cp ifcfg-eth1 ifcfg-br1

桥接网卡的配置很简单,只需要保持ethx的物理信息,保持brx的网络信息即可

所谓的物理信息,即UUID,HWADDR这些;而网络信息,即IPADDR,PREFIX,NEWMASK,GATEWAY,DNS这些

2.3.2 修改网卡配置文件

【ifcfg-eth0】内容如下:

DEVICE=eth0
TYPE=Ethernet
UUID=20fa03bd-212f-4554-bf24-0ae23c1f8661
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=static
HWADDR=00:00:00:80:00:08
NAME=eth0
BRIDGE=br0

上述内容中,删掉的内容

IPADDR=192.168.80.8
PREFIX=24
GATEWAY=192.168.80.2
DNS1=192.168.80.2
DEFROUTE=yes
IPV4_FAILURE_FATAL=yes
IPV6INIT=no

修改的内容为:BOOTPROTO=none。实际上这个参数可以不用修改,保持为none。

【ifcfg-br0】配置内容如下:

DEVICE=br0
TYPE=Bridge
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=static
IPADDR=192.168.80.8
PREFIX=24
GATEWAY=192.168.80.2
DNS1=192.168.80.2
DEFROUTE=yes
IPV4_FAILURE_FATAL=yes
IPV6INIT=no
NAME=br0

上述内容中,删掉的内容:

UUID=20fa03bd-212f-4554-bf24-0ae23c1f8661
HWADDR=00:00:00:80:00:08

修改的内容为:BOOTPROTO=static,TYPE=Bridge,NAME=br0

依照上述操作,对第二块网卡,做同样的操作。

【ifcfg-eth1】配置内容如下:

DEVICE=eth1
TYPE=Ethernet
UUID=ae99988a-c675-4ca5-93e5-2080b72c64be
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=static
HWADDR=00:00:00:10:00:08
BRIDGE=br1
NAME=eth1

【ifcfg-br1]配置内容如下:

DEVICE=br1
TYPE=Bridge
ONBOOT=yes
NM_CONTROLLED=yes
BOOTPROTO=static
IPADDR=192.168.10.8
PREFIX=24
DEFROUTE=yes
IPV4_FAILURE_FATAL=yes
IPV6INIT=no
NAME=br1

配置文件对比图:

2.3.4 重启网络服务

注意:一定要确认系统已经安装桥接网络环境,执行命令rpm -qa | grep bridge-utils检查。

如果没有安装,执行命令yum -y install bridge-utils && echo "yum bridge-utils OK >> /var/log/yum.log"

上述过程配置完成之后,执行命令service network restart重启网络配置

注:本博客在执行上述命令之后,网络断开连接。原因是最小化安装的OS里,没有安装网络桥接的环境,YUM安装bridge-utils即可。具体修复见博客《Error【0003】:配置桥接网络报错.md

2.3.5 查看验证

通过上述的部署之后,可以执行命令:brctl show ,查看当前环境中桥接网络。

bridge name                bridge id            STP enabled        interfaces
br0                        8000.000000800008    no                eth0
br1                        8000.000000100008    no                eth1
virbr0                    8000.525400df5102    yes                virbr0-nic

virbr0,为libvirtd提供的NAT网络,这个在实际的生产环境中不使用,可以删除。具体删除方式参见博客《》

原文地址:https://www.cnblogs.com/liwanliangblog/p/9193907.html

时间: 2024-11-11 20:52:30

KVM虚拟化环境准备的相关文章

ESXi5.1嵌套KVM虚拟化环境支持配置

VMware ESXi5.x默认不支持嵌套虚拟化,需要修改相关配置才能支持,VMware故意的,这里仅记录VMware ESXi5.1嵌套安装KVM虚拟化环境.   该方式开通后KVM/Hyper-V/ESXi都支持. 本文出自:http://koumm.blog.51cto.com 1.ESXi5.1主机开通ssh,修改VMware ESXi配置文件使之嵌套虚拟化. 开通SSH,默认是不开通. 在配置文件后面加入如下配置:vhv.enable = "TRUE" 然后重启ESXi, 这

[原创]KVM虚拟化环境安装

宿主机系统:Centos6.8 下面是安装过程记录: 1.操作系统环境安装 (1)修改内核模式为兼容内核启动 [[email protected] ~]# uname -aLinux openstack 2.6.32-431.el6.x86_64 #1 SMP Fri Nov 22 03:15:09 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux [[email protected] ~]#vim /boot/grub/grub.conf ...... defau

Linux -- 构建KVM虚拟化环境

硬件系统的配置 硬件和BIOS中虚拟化技术的支持是KVM运行的先决条件. 在x86-64架构的处理器中,KVM必需的硬件虚拟化扩展分别为:Intel的虚拟化技术(Intel VT)和AMD的AMD-V技术. 一般在BIOS中,VT的选项通过"Advanced →Processor Configuration"来查看和设置,它的标识通常为"Intel(R) Virtualization Technology"或"Intel VT"等类似的文字说明.

KVM虚拟化笔记(一)------kvm虚拟化环境安装

在安装虚拟化环境的时候,首先查看下该服务器的硬件配置和环境,具体操作如下: (一)检查硬件的相关情况: 1,查看cpu型号,物理cpu颗数, [[email protected] ~]#  cat /proc/cpuinfo | grep name | cut -d: -f2 | uniq -c       2  Intel(R) Core(TM) i3-4150 CPU @ 3.50GHz [[email protected] ~]# cat /proc/cpuinfo | grep phys

CentOS 7部署KVM虚拟化环境之一架构介绍

----本文修改整理自网络,非本人原创. 虚拟化介绍 虚拟化(Virtualization)是一种资源管理技术,将计算机的各种试题资源,如服务器.网络.内存及存储等,予以抽象.转换后呈现出来.打破实体结构间的不可切割的障碍,使的用户可以比原本的组态更好的方式来应用这些资源.这些资源的新虚拟部份是不受现有资源的架设方式,地域或物理组态所限制.一般所指的虚拟化资源包括计算能力和资料存储. 虚拟化技术中大多数人接触的最早且最多的应该就是虚拟机(Virtual Machine),它是通过软件模拟的具有完

kvm虚拟化环境中的时区设置

guest OS时间保持 kvm技术是全虚拟化,guest OS并不需要做修改就可以直接运行,然而在计时方面却存在问题,guest OS计时的一种方式是通过时钟中断计数,进而换算得到,但host产生的时钟中断不能及时到达所有guest OS,因为guest OS中的中断并不是真正的硬件中断,它是由host注入的中断 许多网络应用,web中的sessions验证等,都会调用系统时间,guest OS中若时间有误,则会引起程序出错,为此,kvm给guest vms提供了一个半虚拟化时钟(kvm-cl

2、kvm虚拟化管理平台WebVirtMgr部署

场景:当KVM宿主机越来越多,需要对宿主机的状态进行调控.这里我采用WebVirtMgr作为kvm虚拟化的web管理工具,图形化的WEB,让人能更方便的查看kvm 宿主机的情况和操作 介绍:官网 https://www.webvirtmgr.net/ : WebVirtMgr是近两年来发展较快,比较活跃,非常清新的一个KVM管理平台,提供对宿主机和虚机的统一管理,它有别于kvm自带的图形管理工具(virtual machine manager),让kvm管理变得更为可视化 WebVirtMgr特

KVM虚拟化知识的一些笔记

一.KVM介绍 KVM:运行在内核空间,提供CPU 和内存的虚级化,以及客户机的 I/O 拦截.Guest 的 I/O 被 KVM 拦截后,交给 QEMU 处理. QEMU:修改过的为 KVM 虚机使用的 QEMU 代码,运行在用户空间,提供硬件 I/O 虚拟化,通过 ioctl /dev/kvm 设备和 KVM 交互. KVM所实现的拦截虚拟机I/O请求的原理 现代CPU本身实现了对特殊指令的截获和重定向的支持. 以x86平台为例,支持虚拟化技术的CPU带有特别优化过的指令集来控制虚拟化过程.

<Mastering KVM Virtualization>:第三章 搭建独立的KVM虚拟化

在第二章,你了解了KVM的内部结构:在本章中,您将了解如何将Linux服务器设置为虚拟化主机.我们正在讨论将KVM用于虚拟化并将libvirt作为虚拟化管理引擎. KVM开启了虚拟化并利用你的服务器或工作站来运行虚拟机.从技术术语来说,KVM是一组针对具备虚拟化扩展的x86架构硬件的内核模块:被加载后,它可以将Linux服务器转化为虚拟化hypervisor.可加载模块包括kvm.ko,它提供了核心虚拟化功能,以及一个处理器相关的模块,如kvm-intel.ko或者kvm-amd.ko. NOT