kvm虚拟化完整教程
linux云计算--KVM虚拟化技术(cpu内存)制作lvm镜像kwm上安装centos7系统
linux云计算--KVM虚拟化技术(cpu内存)制作lvm镜像kwm上安装centos7系统KVM虚拟化技术(cpu内存) 制作lvm镜像 kwm上安装centos7系统1.CPU 虚拟化1.KVM中VCPU与ThreadKVM中每⼀个Guest OS都是⼀个标准的Linux进程(qemu-kvm进程)Guest OS中的 vCPU 是qemu-kvm 进程派⽣的线程Guest OS中的内存是qemu-kvm 进程的地址空间的⼀部分KVM 虚拟机包括虚拟内存、虚拟CPU和虚拟机I/O设备,其中内存和 CPU 的虚拟化由 KVM 内核模块负责实现,I/O 设备的虚拟化由 qemu 负责实现。
2.KVM中VCPU与Thread 查看进程和线程 KVM设备状态⼀个 KVM 虚拟机即⼀个 Linux qemu-kvm 进程,与其他 Linux 进程⼀样被Linux 进程调度器调度。
如上例:pstree命令查看,⼀个计算节点中有2个qemu-kvm进程,即2台虚拟机,或者ps aux|grep 虚机名字查看到qemu-kvm进程⼀个虚拟cpu对应⼀个线程virsh list --allps -TP 2951查看线程ps aux| grep qemu查看进程ps aux| grep qemu-kvmpstree查看进程3.KVM中VCPU与Thread虚机中的每⼀个虚拟 vCPU 则对应 qemu-kvm 进程中的⼀个线程。
宿主机有两个物理 CPU,上⾯起了两个虚机 VM1 和 VM2。
VM1 有两个 vCPU,VM2有 4 个 vCPU。
可以看到 VM1 和 VM2 分别有两个和 4 个线程在两个物理 CPU 上调度。
4.资源 over-commit (资源过载)2.内存虚拟化原理实现⽅式技术内存过载1.内存虚拟化基本原理KVM 为了在⼀台机器上运⾏多个虚拟机,需要增加⼀个新的内存虚拟化层也就是说,必须虚拟 MMU(内存管理单元 )来⽀持客户操作系统,来实现 VA -> PA -> MA 的翻译。
Linux KVM虚拟机PVE使用指南
Linux KVM虚拟机PVE使用指南1引言KVM (全称是 Kernel-based Virtual Machine) 是 Linux 下 x86 硬件平台上的全功能虚拟化解决方案,包含一个可加载的内核模块 kvm.ko 提供和虚拟化核心架构和处理器规范模块。
使用 KVM 可允许多个包括 Linux 和 Windows 每个虚拟机有私有的硬件,包括网卡、磁盘以及图形适配卡等PVE使用图形化安装方式,支持裸机安装,管理界面是WEB方式,易于操作,浏览器(fireox,chrome等)支持JAVA即可以进行guest OS的图形管理,无须安装客户端,方便快捷。
本文将详细介绍PVE的安装,使用,部署优化等各方面的内容。
2KVM/QEMU体系架构2.1总体架构QEMU作为一个开源的硬件模拟器项目,除了支持x86体系架构之外,还支持ARM、MIPS、PowerPC、IA64等多种硬件架构。
QEMU采用模块化设计的方法,因此,还能支持多种多样的外设硬件,并且能够方便地进行扩充。
除了支持KVM之外,QEMU还支持全模拟化和kqemu加速模块等方式,这三种方式的架构区别如图5-6所示。
第一种模式是通过kqemu模块实现内核态的加速。
通过在内核中加入kqemu 的相关模块,在用户态的QEMU则通过访问/dev/kqemu设备文件接口调用改进型加速。
在这种模式中,主要针对虚拟机和宿主机运行于统一架构的情况下进行虚拟化。
第二种模式是在用户态直接运行QEMU,由QEMU对目标机的所有指令进行翻译后执行,相当于全虚拟化。
在这种模式下,可以运行各种不同形态的体系结构,如Android开发环境中即使用了QEMU来为其模拟ARM运行环境,但是在这种模拟环境下,每一条目标机的执行指令都需要耗费少则数个,多则成千上万个宿主机的指令周期来模拟实现,速度方面不太理想。
第三种模式则是KVM官方提供的kvm-qemu加速模式。
运行在内核态的KVM 模块通过/dev/kvm字符设备文件向外提供操作接口。
KVM虚拟化(Vlan部分)
KVM安装部署实验环境:一台IBM服务器作为KVM服务器系统:Red Hat Enterprise Linux Server release 6.1 (Santiago)一台本地虚拟机作为KVM管理端系统:Red Hat Enterprise Linux Server release 6.1 (Santiago)网络拓扑:eth0 作为管理接口不做其他配置eth1 作为桥接端口br10 vlan10的桥接接口br3 vlan3的桥接接口br30 为了测试添加的vlaneth1在交换机上的对联接口已经设置成了trunk接口,并且在交换机上已经做了vlan间路由(没有加上vlan30)vlan3的IP地址为192.168.211.1vlan10的IP地址为192.168.212.1vlan30在交换机上没有配置Virt-manager服务器:192.168.211.175实验目的:添加四台虚拟机:vlan10:VirHost1 #192.168.212.10VirHost2 #192.168.212.20vlan3:VirHost3 #192.168.211.30VirHost4 #192.168.211.40vlan30:VirHost5 #192.168.212.30通过在KVM服务器上划分vlan3、vlan10、vlan30来实现和交换机vlan的对接的效果一.安装配置KVM服务器略…二.部署VlanKvm服务器上进行操作:1.添加和配置vlan[root@localhost libvirt]# lsmod | grep 802[root@localhost libvirt]#貌似不支持,加载模块[root@localhost libvirt]# modprobe 8021q[root@localhost libvirt]# lsmod | grep 8028021q 24413 0garp 7310 1 8021q添加vlan3、vlan10、vlan30[root@localhost network-scripts]# vconfig add eth1 3Added VLAN with VID == 3 to IF -:eth1:-[root@localhost network-scripts]# vconfig add eth1 10Added VLAN with VID == 10 to IF -:eth1:-[root@localhost network-scripts]# vconfig add eth1 30Added VLAN with VID == 30 to IF -:eth1:-相应的网络配置文件列表:ifcfg-br3ifcfg-br10ifcfg-br30ifcfg-eth1.3ifcfg-eth1.10ifcfg-eth1.30配置内容以br3和eth1.3为例----vi ifcfg-br3----DEVICE="br3"TYPE=BridgeHWADDR="5C:F3:FC:0C:2B:C6"ONBOOT="yes"----vi ifcfg-eth1.3----DEVICE="eth1.3"BRIDGE=br3HWADDR="5C:F3:FC:0C:2B:C6"ONBOOT="yes"其他配置文件类似重启网络服务:#/etc/init.d/newrork restart添加对应关系默认新添加的虚拟机都是属于br0的,这里要先删除掉br0之后再建立对应关系,删除的步骤如下:1.ifdown br02.brctl delbr br03.删除配置文件ifcfg-br0(如果有)注:1.每次添加一个虚拟机在KVM服务器上都会出现相应的虚拟网卡(vnet0、vnet1…)与之对应,2.默认新添加的虚拟机都是属于br0,所以为了彻底更改新建立的虚拟机使用的桥接端口,需要修改每个虚拟机对应的配置文件(/etc/libvirt/qemu/VirHost1.xml,VirHost2.xml等)中的<source bridge='br0'/>,修改之后要在KVM服务器端重新定义一下客户端,“virsh define /etc/libvirt/qemu/VirHost5.xml”,之后重启虚拟机客户端每一个虚拟网卡的MAC地址和新添加的虚拟机的MAC是一样的在不更改配置文件的情况下临时添加对应关系的命令如下#brctl addbr br3 b10 br30 #添加桥接端口#brctl addif br10 vnet0 vnet1 #对应的是VirHost1 VirHost1#brctl addif br10 vnet2 vnet3 #对应的是VirHost3 VirHost4#brctl show分别设置五台虚拟机的IP地址VirHost1:IP:192.168.212.10 GW:192.168.212.1 VirHost2:IP:192.168.212.20 GW:192.168.212.1VirHost3:IP:192.168.211.30 GW:192.168.211.1 VirHost4:IP:192.168.211.40 GW:192.168.211.1 切换到Virhost5:在KVM服务器上将VirHost5加入到br10切换到VirHost5:将VirHost1,VirHost5加入到br30切换到VirHost1:因为VirHost1在vlan30所以平vlan10的地址不通VirHost1和VirHost5现在同一个vlan30中所以互通。
KVM虚拟机创建功能详细讲解
一.KVM虚拟机创建的用户操作对于用户或者管理员来说,虚拟机的创建有着很多的方法,例如:kvm自带命令行工具、使用virsh命令来创建、使用具有图形界面的virt-manager等等。
但是它们底层实现的原理都是一样的,而且它们基本上都是通过开源的虚拟化库Libvirt来开发的。
下面就讲一讲三种用户可以创建虚拟机的方式。
利用kvm自带命令行工具进行创建kvm常用命令如下:参数示例说明-hda-hda /data/指定作为硬盘镜像-cdrom-cdrom /data/指定作为光盘镜像-boot-boot c从硬盘启动-boot d从光盘启动-m-m 512分配512M内存给虚拟系统-vnc-vnc :0作为vnc服务器-cpu-cpu 列出支持的CPU-cpu core2duo指定CPU为core2duo-smp-smp 2指定虚拟机有2个CPU-net-net nic为虚拟机网卡(默认为tap0)-net tap系统分配tap设备(默认为tap0)1-net nic -net tap 将虚拟机的网卡eth0连接真机里的tap0具体创建一个虚拟机的步骤如下:(1)生成硬盘镜像文件root@host:kvm-img create -f 10G其中“-f raw”指定镜像文件的格式为“raw”,“10G”指定镜像文件大小。
(2)从光盘启动虚拟机来安装操作系统root@host:kvm -boot d -hda -m 512其中“-boot d”指定虚拟机从光盘启动,“-hda ”指定硬盘镜像的位置,“-cdrom ”指定光盘镜像的位置,“-m 512”指定虚拟机的内存为512M。
(3)安装操作系统后便可直接从硬盘启动虚拟机root@host:kvm -boot c -hda 512利用virsh命令行工具进行创建virsh工具简介Virsh是由一个名叫libvirt的软件提供的管理工具,提供管理虚拟机比较高级的能力。
kvm虚拟化技术实战与原理解析
kvm虚拟化技术实战与原理解析KVM(Kernel-based Virtual Machine)是一种基于Linux内核的开源虚拟化技术。
它允许在一台物理服务器上同时运行多个虚拟机,每个虚拟机拥有自己的操作系统和资源配置。
本文将从实战和原理两个方面对KVM虚拟化技术进行解析。
一、KVM虚拟化技术的实战应用1. 环境准备在进行KVM虚拟化技术实战之前,我们需要满足以下环境准备要求:- 一台支持虚拟化扩展的物理服务器;- 安装有支持KVM的Linux操作系统,例如Ubuntu、CentOS等;- 确保硬件资源充足,并开启虚拟化扩展功能。
2. 安装和配置KVM步骤一:安装KVM软件包通过在终端中执行相应的命令,我们可以轻松安装KVM软件包,例如在Ubuntu系统下,可以使用如下命令进行安装:```sudo apt-get install qemu-kvm libvirt-daemon-system libvirt-clients bridge-utils```步骤二:创建虚拟网络我们需要通过桥接方式创建一个虚拟网络,将虚拟机与物理网络连接起来。
可以使用以下命令创建一个名为br0的虚拟网络:```sudo brctl addbr br0sudo brctl addif br0 eth0```步骤三:创建和管理虚拟机可以使用命令行工具(virsh)或者图形化工具(virt-manager)来创建和管理虚拟机。
通过设置虚拟机的硬件资源和网络配置,我们可以满足各种不同的应用需求。
3. 实战应用案例KVM虚拟化技术在实际应用中具有广泛的用途,以下是一些实战应用案例:- 服务器虚拟化:将一台物理服务器划分为多个虚拟机,每个虚拟机运行一个独立的应用程序,提高服务器资源的利用率。
- 开发和测试环境:通过创建虚拟机,开发团队可以在不同的环境中进行应用程序的开发和测试,提高开发效率和应用程序的可靠性。
- 云计算平台:KVM虚拟化技术是很多云计算平台的基础,通过在物理服务器上运行多个虚拟机,实现多租户的资源共享和隔离。
Linux虚拟化——KVM安装步骤
Linux虚拟化——KVM安装步骤1、先查看cpu是否支持kvmKVM 需要有 CPU 的支持(Intel vmx 或 AMD svm),在安装 KVM 之前检查一下 CPU 是否提供了虚拟技术的支持:egrep '(vmx|svm)' --color=always /proc/cpuinfo如果输出的结果包含VMX,它是Intel处理器虚拟机技术标志:如果包含SVM,它是AMD 处理器虚拟机技术的标志,如果你什么都没有得到,那应你的系统并没有支持虚拟化的处理,不能使用KVM,另处linux发行版本必须在64bit环境中才能使用KVM。
2、BIOS中开启Virtual Technolege在主板BIOS中开启CPU的Virtual Technolege(VT,虚化技术),不同主板所在菜单不同例如:华硕主板开启虚拟化Intel主板开启虚拟化3、安装KVM服务器安装KVM 虚拟机和安装其他服务器一样,在选择操作系统类型是选择“Virtual Host”即可,其它步骤可参考“AiSchool平台安装指导”中操作系统安装部分。
如果使用此服务器管理其他KVM 主机,需要额外安装openssh-askpass 软件包。
注:(已安装好的操作系统,里面有重要资料无法重新安装的可以在已有的系统上安装如下软件包yum install kvm kmod-kvm qemu kvm-qemu-img virt-viewer virt-manager libvirt libvirt-python python-virtinst openssh-askpass或者如下图,安装需要的组4、检查kvm模块是否安装使用以下命令显示两个模块则表示安装完成[root@vm76 ~]# lsmod | grep kvmkvm_intel 54285 0kvm 333172 1 kvm_intel以上表明安装完成5、配置宿主机1、关闭防火墙(如不用)chkconfig iptables offservice iptables stop2、执行如下命令打开文件selinux配置文件。
KVM虚拟化安装部署及管理教程
KVM虚拟化安装部署及管理教程⽬录1.kvm部署1.1 kvm安装1.2 kvm web管理界⾯安装1.3 kvm web界⾯管理1.3.1 kvm连接管理1.3.2 kvm存储管理1.3.3 kvm⽹络管理1.3.4 实例管理故障1.kvm部署1.1 kvm安装//关闭防⽕墙和selinux[root@kvm ~]# systemctl disable --now firewalld.serviceRemoved /etc/systemd/system/multi-user.target.wants/firewalld.service.Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.[root@kvm ~]# sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config[root@kvm ~]# reboot//下载epel源和⼯具包[root@kvm ~]# yum -y install epel-release vim wget net-tools unzip zip gcc gcc-c++//验证CPU是否⽀持KVM;如果结果中有vmx(Intel)或svm(AMD)字样,就说明CPU的⽀持的[root@kvm ~]# egrep -o 'vmx|svm' /proc/cpuinfo//安装kvm[root@kvm ~]# 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//桥接⽹卡,⽤br0来桥接ens160⽹卡[root@kvm ~]# cd /etc/sysconfig/network-scripts/[root@kvm network-scripts]# cp ifcfg-ens33 ifcfg-br0[root@kvm network-scripts]# cat ifcfg-br0TYPE=BridgeDEVICE=br0NM_CONTROLLED=noBOOTPROTO=staticNAME=br0ONBOOT=yesIPADDR=192.168.237.131NETMASK=255.255.255.0GATEWAY=192.168.237.2DNS1=114.114.114.114DNS2=8.8.8.8[root@kvm network-scripts]# cat ifcfg-ens33TYPE=EthernetBOOTPROTO=staticNAME=ens33DEVICE=ens33ONBOOT=yesBRIDGE=br0NM_CONTROLLED=no//重启⽹络[root@kvm ~]# systemctl restart network[root@kvm ~]# ip a1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::1/128 scope hostvalid_lft forever preferred_lft forever2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master br0 state UP group default qlen 1000link/ether 00:0c:29:7b:10:a5 brd ff:ff:ff:ff:ff:ffinet6 fe80::20c:29ff:fe7b:10a5/64 scope linkvalid_lft forever preferred_lft forever3: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000link/ether 00:0c:29:7b:10:a5 brd ff:ff:ff:ff:ff:ffinet 192.168.237.131/24 brd 192.168.237.255 scope global br0valid_lft forever preferred_lft foreverinet6 fe80::20c:29ff:fe7b:10a5/64 scope linkvalid_lft forever preferred_lft forever4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 52:54:00:1c:33:d6 brd ff:ff:ff:ff:ff:ffinet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0valid_lft forever preferred_lft forever5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast master virbr0 state DOWN group default qlen 1000link/ether 52:54:00:1c:33:d6 brd ff:ff:ff:ff:ff:ff//启动服务[root@kvm ~]# systemctl enable --now libvirtd//验证安装结果[root@kvm ~]# lsmod|grep kvmkvm_intel 188740 0kvm 637289 1 kvm_intelirqbypass 13503 1 kvm//测试[root@kvm ~]# virsh -c qemu:///system listId 名称状态----------------------------------------------------[root@kvm ~]# virsh --version4.5.0[root@kvm ~]# virt-install --version1.5.0[root@kvm ~]# ln -s /usr/libexec/qemu-kvm /usr/bin/qemu-kvm[root@kvm ~]# ll /usr/bin/qemu-kvmlrwxrwxrwx 1 root root 21 10⽉ 20 23:14 /usr/bin/qemu-kvm -> /usr/libexec/qemu-kvm//查看⽹桥信息[root@kvm ~]# brctl showbridge name bridge id STP enabled interfacesbr0 8000.000c297b10a5 no ens33virbr0 8000.5254001c33d6 yes virbr0-nic1.2 kvm web管理界⾯安装kvm 的 web 管理界⾯是由 webvirtmgr 程序提供的。
精品课件-KVM虚拟化技术基础与实践-第一章
第1章 虚拟化与云计算
XEN与VMware等基本类似,主要不同之处是需要改动内核, 但都是通过软件模拟硬件层,然后在模拟出来的硬件层上 安装完整的操作系统,然后在操作系统上跑应用。其核心 思想可以用“模拟”两个字来概括,即用软的模拟硬的, 并能实现异构操作系统的互操作。 第四个阶段:是近几年开始出现或者被人注意的虚拟化技 术,主要有芯片级的虚拟化、操作系统的虚拟化和应用层 的虚拟化。
第1章 虚拟化与云计算
CPU虚拟化: VMware通过CPU虚拟化技术解决的难题是如何在一个操作 系统实例中运行多个应用。实现这一任务的困难之处在于 每一个应用都与操作系统之间有着密切的依赖关系。一个 应用通常只能运行于特定版本的操作系统和中间件之上, 这就是Windows用户常常提到的“DLL地狱”。因此,大多 数用户只能在一个Windows操作系统实例上运行一种应用, 操作系统实例独占一台物理服务器。
虚拟化与云计算
虚拟化概述 虚拟化概念分类 主流虚拟化产品概述
第1章 虚拟化与云计算
1.1 虚拟化概述
1.1.1 云计算概念及其体系结构 1、云计算的概念
狭义的云计算是指IT基础设施的交付和使用模式,指 通过网络以按需、易扩展的方式获得所需的IT基础设施。 云计算厂商通过分布式计算和虚拟化技术搭建数据中心或 超级计算机,以免费或按需租用的方式向技术开发者或者 企业用户提供数据存储、分析以及科学计算等服务。
第1章 虚拟化与云计算
1.1.4 虚拟化与云计算的关系 云计算其实是包含了许多核心技术的概念,比如
虚拟化、并行计算、分布式数据库、分布式存储等。其中 虚拟化技术是云计算的基石,是云计算服务得以实现的最 关键的技术。通过虚拟化技术可以将各种硬件、软件、操 作系统、存储、网络以及其他IT资源进行虚拟化,并纳入 到云计算管理平台进行管理。这样一来,IT能力都可以转 变为可管理的逻辑资源,通过互联网可以把这些资源像水、 电和天然气一样提供给最终用户,以实现云计算的最终目 标。
Ubuntu服务器应用KVM实现虚拟化速成手册
Ubuntu服务器应用KVM实现虚拟化速成手册本文教大家如何让KVM在Ubuntu服务器上顺畅运行、安装多个访客操作系统、管理存储,以及将访客操作系统迁移到新主机上。
作为Linux内核虚拟机管理程序,KVM称得上是企业级虚拟化领域的后起之秀。
它有诸多优点:非常精简,因而占用资源少,运行起来速度快,可以轻松自如地运行没有经过改动的访客操作系统。
在这堂速成课中,我们会迅速让KVM在Ubuntu服务器上运行起来、安装多个访客操作系统、管理存储,以及将访客操作系统迁移到新主机上。
KVM与Ubuntu服务器KVM的全称是“基于内核的虚拟机”,最先由Qumranet公司开发而成。
2008年,红帽公司收购了Qumranet,将KVM作为服务器版红帽企业级虚拟化(RHEV)的核心部分。
KVM采用了GPL许可证模式,是主线内核(mainline Kernel)的一部分,因而任何Linux发行版都能支持它。
KVM是一种类型2虚拟机管理程序,这意味着它在操作系统里面运行。
一些流行的类型2虚拟机管理程序包括Xen和VirtualBox。
类型1虚拟机管理程序(如IBM的z/VM和VMware ESXi)则可以直接在裸机上运行,不需要什么操作系统。
KVM几乎支持任何访客操作系统:Linux、Mac OS X、Unix、Windows以及你所采用的其他任何操作系统。
与KVM一样,Ubuntu服务器也发展成为一款面向企业的重量级服务器。
Ubuntu 支持x86和x86 64位平台上的KVM。
与红帽和Novell这两大企业级Linux开发商不一样,你没必要进行注册或者理睬销售噱头,就可以下载和测试Ubuntu。
如果你想要获得培训、商业支持或者在线服务(比如Landscape系统管理器或Ubuntu云服务),你想要的时候,就能随时获取。
系统要求就这堂速成课而言,你需要配备英特尔VT或AMD-V处理器的Ubuntu计算机,因为这些处理器包含特殊的扩展功能,可以原生支持虚拟机。
KVM虚拟化(一)——介绍与简单使用
KVM虚拟化(⼀)——介绍与简单使⽤⼀、架构及介绍 KVM(Kernel-based Virtual Machine)它由 Quramnet 开发,该公司于 2008年被 Red Hat 收购; ⾃Linux 2.6.20后整合到内核,该内核模块使得 Linux 变成了⼀个 Hypervisor层; 它依托于CPU虚拟化指令集,性能、安全性、兼容性、稳定性表现很好,每个虚拟化操作系统表现为单个系统进程,与Linux安全模块selinux安全模块很好结合; 官⽅⽹站为⼆、KVM的安装(1)安装之前要查看CPU是否⽀持虚拟化,以下命令有输出就代表⽀持虚拟化;如果确定cpu可以⽀持虚拟化,但以上命令没有输出结果,就进⼊bash加载虚拟化1 Intel CPU:2 [root@localhost ~ ]#cat /proc/cpuinfo | grep vmx3 AMD CPU:4 [root@localhost ~ ]#cat /proc/cpuinfo | grep smv5 [root@localhost ~ ]# modprobe kvm #加载kvm模块(2)安装⽅法⽅法⼀:在安装系统的时候,选择桌⾯安装,然后选择虚拟化选项⽅法⼆:在已有系统基础上,安装KVM所需软件。
必安包:qemu-kvm.x86_64 //KVM模块qemu-img.x86_64 //qemu组件,创建磁盘、启动虚拟机等可选⼯具包:yum -y groupinstall "Desktop" //安装GNOME桌⾯环境virt-manager //图形界⾯管理虚拟机⼯具libvirt //图形化虚拟机管理⼯具python-virtinst.noarch //python组件,记录创建VM时的xml⽂件bridge-util.x86.64 //⽹络⽀持⼯具,桥接功能模块libguestfs-tools //⽂件管理⼯具acpid //virsh命令依赖的服务,需要开机启动的,他是⼀个服务,不是⼯具包(3)验证安装结果[root@localhost ~ ]# lsmod | grep kvmkvm_intel 54285 0kvm 333172 1 kvm_intel三、KVM⽹络1、KVM虚拟机⽹络介绍 在libvirt中运⾏KVM⽹络有两种⽅法:NAT和Bridge,默认是NAT(1)NAT模式:即⽤户模式,可以访问外⽹,但是⽆法从外部访问虚拟机⽹络。
KVM(系统虚拟化模块)安装
KVM(系统虚拟化模块)安装Kernel-based Virtual Machine的简称,是⼀个开源的系统虚拟化模块,⾃Linux 2.6.20之后集成在Linux的各个主要发⾏版本中。
它使⽤Linux⾃⾝的调度器进⾏管理,所以相对于Xen,其核⼼源码很少。
KVM⽬前已成为学术界的主流VMM之⼀。
KVM的虚拟化需要硬件⽀持(如Intel VT技术或者AMD V技术) 。
是基于硬件的完全虚拟化。
⽽Xen早期则是基于软件模拟的Para-Virtualization,新版本则是基于硬件⽀持的完全虚拟化yum install -y qemu-kvm qemu-kvm-tools virt-manager libvirt virt-install python-virtinst⼀、 KVM虚拟机克隆⽅法1、克隆KVM虚拟机的语法和注意事项语法:virt-clone –o 原虚拟机 –n 新虚拟机 –f 新虚拟机存放的路径注:需要克隆的虚拟机必须是关机状态,不然没办法克隆。
2、克隆KVM虚拟机(centos7.0)1)关闭centos7.0虚拟机[root@xuegod110 ~]# virsh shutdown centos7.0————————————————virsh snapshot-create-as 虚拟机名称 ##创建快照virsh snapshot-list 虚拟机名称 ##查看快照virsh snapshot-revert 虚拟机名称快照名 ##利⽤快照恢复数据[root@room9pc01 ~]# clone-vm7.4请输⼊虚拟机号码:100正在创建镜像........[ok]正在创建虚拟机.......[ok][root@room9pc01 ~]# virsh start host100 ##开虚拟机域 host100 已开始[root@room9pc01 ~]# virsh snapshot-create host100 ##创建快照已⽣成域快照 1522667947[root@room9pc01 ~]# virsh snapshot-list host100 ##查看快照名称⽣成时间状态1522667947 2018-04-02 19:19:07 +0800 running[root@room9pc01 ~]# virsh snapshot-revert host100 1522667947 ##恢复数据1.安装要⽤的软件;安装软件的时,关闭selinux安装kvm模块#yum install qemu-kvm.x86_64安装kvm调试⼯具(可以不安装)#yum install qemu-kvm-tools.x86_64安装python组件,主要⽤来记录创建vm时的xml⽂件#yum install python-virtinst.noarch安装qemu组件,使⽤qemu命令来创建磁盘,启动虚拟机等(这个可能在安装时qemu-kvm.x86_64已安装)#yum install qemu-img.x86_64安装⽹络⽀持⼯具#yum install bridge-utils.x86_64安装虚拟机管理⼯具,使⽤virsh来管理虚拟机#yum install libvirt⼆.汇总:安装软件:yum -y install qemu-kvm kvm qemu-kvm qemu-img python-virtinst libvirt bridge-utils qemu-kvm-tools virt-viewer virt-v2v tunctl virt-manager libvirt-python kmod-kvm qemu三.重新启动libvirtd#/etc/init.d/libvirtd start#ps -e| grep libvirtd30706 ? 00:00:01 libvirtd四.检查kvm模块是否安装完成#lsmod | grep kvm会显⽰两个模块kvm_intel/ kvm_amdkvm五.配置⽹卡桥接[ network-scripts]# cat ifcfg-eth0 |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'DEVICE=eth0TYPE=EthernetONBOOT=yesBOOTPROTO=noneBRIDGE=br0IPV6INIT=noHWADDR=F8:BC:12:60:99:86[ network-scripts]# cat ifcfg-br0 |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'DEVICE=br0TYPE=BridgeONBOOT=yesBOOTPROTO=staticIPADDR=192.168.10.103GATEWAY=192.168.10.1NETMASK=255.255.255.0DNS1=192.168.10.1IPV6INIT=noDELAY=0#service network restart重启⽹络报错:弹出界⾯ br0:错误:激活连接失败:Failed to determine connection's virtual interface name解决的⽅法:#service NetworkManager stop //这个关闭掉就⾏如果以下内容就说明配置成功了:[ network-scripts]# ifconfigbr0 Link encap:Ethernet HWaddr 5E:0E:C2:8E:CC:E6inet addr:192.168.23.89 Bcast:192.168.23.255 Mask:255.255.255.0inet6 addr: fe80::5c0e:c2ff:fe8e:cce6/64 Scope:LinkUP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1RX packets:0 errors:0 dropped:0 overruns:0 frame:0TX packets:10 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:0RX bytes:0 (0.0 b) TX bytes:636 (636.0 b)eth0 Link encap:Ethernet HWaddr 00:0C:29:EA:5F:9Ainet addr:10.10.21.13 Bcast:10.10.255.255 Mask:255.255.0.0inet6 addr: fe80::20c:29ff:feea:5f9a/64 Scope:LinkUP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1RX packets:2995655 errors:0 dropped:0 overruns:0 frame:0TX packets:40564 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:1000RX bytes:302081352 (288.0 MiB) TX bytes:3884529 (3.7 MiB)Interrupt:19 Base address:0x2000lo Link encap:Local Loopbackinet addr:127.0.0.1 Mask:255.0.0.0inet6 addr: ::1/128 Scope:HostUP LOOPBACK RUNNING MTU:16436 Metric:1RX packets:80537 errors:0 dropped:0 overruns:0 frame:0TX packets:80537 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:0RX bytes:8967119 (8.5 MiB) TX bytes:8967119 (8.5 MiB)virbr0 Link encap:Ethernet HWaddr 52:54:00:B2:93:53inet addr:192.168.122.1 Bcast:192.168.122.255 Mask:255.255.255.0UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1RX packets:0 errors:0 dropped:0 overruns:0 frame:0TX packets:0 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:0RX bytes:0 (0.0 b) TX bytes:0 (0.0 b)[ network-scripts]# brctl showbridge name bridge id STP enabled interfacesbr0 8000.000c29ea5f9a no eth0 //显⽰这个okvirbr0 8000.525400b29353 yes virbr0-nic六、可以⽤virt-install ⽣成.img⽂件;来新建虚拟机了,但是启动后没办法看到所以要安装客户端来管理,也可以⽤virsh来管理但还要加VNC来连接虚拟机①安装VNC#yum install tigervnc-server.x86_64改防⽕墙:还要改⼀下iptables #vi /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --dport 6900 -j ACCEPT#service iptables restart②开始新建虚拟机[ ~]# virt-install --name vmxp1 --ram 1024 --vcpus=1 --disk path=/home/kvm/img/xp1.img,size=20 --network bridge=br0 --os-variant=winxp --cdrom /home/kvm/soft/XP.iso --vnclisten=192.168.1.12 --vncport=6900 --vnc[ network-scripts]# virt-install --name=ubuntu1 --ram 1024 --vcpus=1 --disk path=/root/ubuntu1.img,size=10 --accelerate --cdrom/root/ubuntu-14.04-desktop-amd64.iso --graphics vnc,port=5920 --network bridge=br0报错:could not open disk image : Permission denied解决⽅法:[ ~]# cat /etc/libvirt/qemu.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'vnc_listen = "0.0.0.0"user = "root" //去掉注释group = "root" //去掉注释dynamic_ownership = 0 //去掉注释,把1改为0这⼀步做完,系统⽂件就好了七.启动虚拟机如果报错:[ ~]# virsh start ubuntu1错误:域已经活跃解决⽅法:[ ~]# pkill qemu-kvm[ ~]# virsh start ubuntu1域 ubuntu1 已开始[ ~]# virt-viewer ubuntu1 //进⼊图形界⾯或者进⼊系统;应⽤程序中;找到虚拟系统管理器==>配置新系统#qemu-img snapshot #创建虚拟快照#使⽤ virsh snapshot-create-as 命令进⾏⽣成快照关闭虚拟机并转换磁盘#virsh shutdown oeltest01查看虚拟状态#virsh list --allraw格式的不具备快照功能,需要raw镜像转换为qcow2格式,#qemu-img convert -f raw -O qcow2 100.img 111.img# qemu-img snapshot -l test.qcow2 #列出某个镜像的所有快照#qemu-img snapshot -a snapshot01 test.qcow2#使⽤快照附:'snapshot' is the name of the snapshot to create, apply or delete'-a' applies a snapshot (revert disk to saved state)'-c' creates a snapshot'-d' deletes a snapshot'-l' lists all snapshots in the given image3 查看虚拟机testsnp已有的快照[root@nc1 boss]# virsh snapshot-list testsnp4 可以通过snapshot-dumpxml命令查询该虚拟机某个快照的详细配置[root@nc1 boss]# virsh snapshot-dumpxml testsnp 13153850655 查看最新的快照信息[root@nc1 boss]# virsh snapshot-current testsnp6 使⽤快照,指定使⽤哪⼀个快照恢复虚拟机[root@nc1 boss]# virsh snapshot-revert testsnp snapshot027 删除指定快照[root@nc1 boss]# virsh snapshot-delete testsnp snapshot02。
kvm虚拟化
kvm虚拟化KVM(Kernel-Based Virtual Machines)是⼀个基于Linux内核的虚拟化技术, 可以直接将Linux内核转换为Hypervisor(系统管理程序)从⽽使得Linux内核能够直接管理虚拟机, 直接调⽤Linux内核中的内存管理、进程管理⼦系统来管理虚拟机。
⼀虚拟机配置1.修改虚拟机内存,⾄少设置成2 GB在“硬件”选项卡中单击“处理器”,在虚拟化引擎中勾选如红框内所⽰选项,如下图:(千万别忘了)再添加⼀个磁盘⼤⼩为50的硬盘上图为虚拟机的设置然后启动虚拟机进⾏配置2. 检查 CPU 参数启动虚拟机,查看以下,内存是否更改成功:[root@kvm ~]# freetotal used free shared buff/cache availableMem: 1868688 125360 158**** **** 160956 1584208Swap: 097148 0 2097148检查 CPU 是否开启虚拟化⽀持:[root@kvm ~]# grep -Ei 'vmx|svm' /proc/cpuinfo//vmx为英特尔的cpu;svm为AMD的cpu。
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ss syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc eagerfpu pni pclmulqdq flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ss syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc eagerfpu pni pclmulqdq 如果显⽰为空,就要检查虚拟化设置,是否打 “√3.挂载新磁盘使⽤ lsblk 命令,检查虚拟机是否新增⼀块50的磁盘;[root@kvm ~]# lsblkNAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINTsda 8:0 0 20G 0 disk├─sda1 8:1 0 500M 0 part /boot└─sda2 8:2 0 19.5G 0 part├─centos-root 253:0 0 17.5G 0 lvm /└─centos-swap 253:1 0 2G 0 lvm [SWAP]sdb 8:16 0 50G 0 disksr0 11:0 1 4G 0 romsdb为新增的磁盘然后格式化这块磁盘,格式化成ext4格式:[root@kvm ~]# mkfs.ext4 /dev/sdbmke2fs 1.42.9 (28-Dec-2013)/dev/sdb is entire device, not just one partition!Proceed anyway? (y,n) yFilesystem label=OS type: LinuxBlock size=4096 (log=2)Fragment size=4096 (log=2)Stride=0 blocks, Stripe width=0 blocks3276800 inodes, 13107200 blocks655360 blocks (5.00%) reserved for the super userFirst data block=0Maximum filesystem blocks=2162163712400 block groups32768 blocks per group, 32768 fragments per group8192 inodes per groupSuperblock backups stored on blocks:32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,4096000, 7962624, 11239424Allocating group tables: doneWriting inode tables: doneCreating journal (32768 blocks): doneWriting superblocks and filesystem accounting information: done[root@kvm ~]# blkid /dev/sdb//blkid+磁盘:查看磁盘信息/dev/sdb: UUID="dab6d659-e334-41ed-a15a-96ce05b48c1a" TYPE="ext4"格式化完成后,挂载磁盘,先创建挂载⽬录 /kvm_data ,然后进⾏挂载:[root@kvm ~]# mkdir /kvm_data[root@kvm ~]# mount /dev/sdb /kvm_data/为了⽅便开机可以⾃动挂载,编写 /etc/fstab ⽂件,添加⽂件最末⼀⾏:[root@kvm ~]# vi /etc/fstab[root@kvm ~]# cat /etc/fstab## /etc/fstab# Created by anaconda on Thu Aug 22 22:51:46 2019## Accessible filesystems, by reference, are maintained under '/dev/disk'# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info#/dev/mapper/centos-root / xfs defaults 0 0UUID=34f3cd91-b7f0-44dd-9334-2bb66e939898 /boot xfs defaults 0 0/dev/mapper/centos-swap swap swap defaults 0 0/dev/sdb /kvm_data ext4 defaults 0 04. 关闭防⽕墙和selinux关闭防⽕墙设置开机不⾃启:[root@kvm ~]# systemctl stop firewalld[root@kvm ~]# systemctl disable firewalldRemoved symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.Removed symlink /etc/systemd/system/basic.target.wants/firewalld.service.关闭SELinux,编辑 /etc/selinux/config,将 enforcing 修改为 disabled :[root@kvm ~]# vi /etc/selinux/config[root@kvm ~]# cat /etc/selinux/config# This file controls the state of SELinux on the system.# SELINUX= can take one of these three values:# enforcing - SELinux security policy is enforced.# permissive - SELinux prints warnings instead of enforcing.# disabled - No SELinux policy is loaded.SELINUX=disabled//修改这⼀位置的内容# SELINUXTYPE= can take one of three two values:# targeted - Targeted processes are protected,# minimum - Modification of targeted policy. Only selected processes are protected.# mls - Multi Level Security protection.SELINUXTYPE=targeted修改完后,重启虚拟机,使其⽣效,使⽤getenforce查看:[root@kvm ~]# getenforceDisabled5.安装 KVM使⽤Yum 安装KVM:[root@kvm ~]# yum install -y virt-* libvirt bridge-utils qemu-img…………Complete!⼆启动KVM1.配置⽹卡增加桥接⽹卡 ifcfg-br0[root@kvm ~]# cd /etc/sysconfig/network-scripts/[root@kvm network-scripts]# cp ifcfg-eno16777736 ifcfg-br0//ifcfg-eno16777736为配置IP的⽹卡,你的⽹卡可能与我的不同修改桥接⽹卡 ifcfg-br0的内容[root@kvm network-scripts]# vi ifcfg-br0[root@kvm network-scripts]# cat ifcfg-br0TYPE=BridgeBOOTPROTO=noneNAME=br0DEVICE=br0ONBOOT=yesIPADDR=192.168.16.5NETMASK=255.255.255.0GATEWAY=192.168.16.2DNS1=114.114.114.114DNS2=8.8.8.8修改NATA⽹卡 ifcfg-eno16777736[root@kvm network-scripts]# vi ifcfg-eno16777736[root@kvm network-scripts]# cat ifcfg-eno16777736TYPE=EthernetBOOTPROTO=noneNAME=eno16777736DEVICE=eno16777736ONBOOT=yesBRIDGE=br0修改完⽹卡内容后,重新启动⽹卡服务并查看⽹卡信息[root@kvm network-scripts]# service network restartRestarting network (via systemctl): [ OK ][root@kvm network-scripts]# ifconfigbr0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500inet 192.168.16.5 netmask 255.255.255.0 broadcast192.168.16.255inet6 fe80::20c:29ff:fe8d:1f90 prefixlen 64 scopeid 0x20<link>ether 00:0c:29:8d:1f:90 txqueuelen 0 (Ethernet)RX packets 90 bytes 7092 (6.9 KiB)RX errors 0 dropped 0 overruns 0 frame 0TX packets 38 bytes 3604 (3.5 KiB)TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0eno16777736: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>mtu 1500ether 00:0c:29:8d:1f:90 txqueuelen 1000 (Ethernet)RX packets 126287 bytes 182444678 (173.9 MiB)RX errors 0 dropped 0 overruns 0 frame 0TX packets 32532 bytes 2953477 (2.8 MiB)TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536inet 127.0.0.1 netmask 255.0.0.0inet6 ::1 prefixlen 128 scopeid 0x10<host>loop txqueuelen 0 (Local Loopback)RX packets 0 bytes 0 (0.0 B)RX errors 0 dropped 0 overruns 0 frame 0TX packets 0 bytes 0 (0.0 B)TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0可以清楚的看到br0⽹卡出现并且带有IP,⽽以前的eno16777736⽹卡则没有IP。
kvm虚拟化平台工作流程
kvm虚拟化平台工作流程下载温馨提示:该文档是我店铺精心编制而成,希望大家下载以后,能够帮助大家解决实际的问题。
文档下载后可定制随意修改,请根据实际需要进行相应的调整和使用,谢谢!并且,本店铺为大家提供各种各样类型的实用资料,如教育随笔、日记赏析、句子摘抄、古诗大全、经典美文、话题作文、工作总结、词语解析、文案摘录、其他资料等等,如想了解不同资料格式和写法,敬请关注!Download tips: This document is carefully compiled by theeditor. I hope that after you download them,they can help yousolve practical problems. The document can be customized andmodified after downloading,please adjust and use it according toactual needs, thank you!In addition, our shop provides you with various types ofpractical materials,such as educational essays, diaryappreciation,sentence excerpts,ancient poems,classic articles,topic composition,work summary,word parsing,copy excerpts,other materials and so on,want to know different data formats andwriting methods,please pay attention!KVM 虚拟化平台工作流程一、准备工作阶段1. 确定需求:明确需要搭建 KVM 虚拟化平台的目的和应用场景,例如运行虚拟机、进行开发测试等。
红帽企业版KVM虚拟化实战攻略
红帽企业版KVM虚拟化实战攻略在2010年4月发布的RHEL 6.0 Beta版中,去掉了Xen,这也许是第一个不包含Xen Hypervisor的知名Linux发行版,之前有报道过Red Hat有可能会在RHEL 6.0中用KVM 完全代替Xen,现在看来以前的消息一点不假。
KVM 是指基于Linux 内核的虚拟机(Kernel-based Virtual Machine)。
增加KVM 到Linux 内核是Linux 发展的一个重要里程碑,这也是第一个整合到Linux 主线内核的虚拟化技术。
在KVM 模型中,每一个虚拟机都是一个由Linux 调度程序管理的标准进程,你可以在用户空间启动客户机操作系统。
一个普通的Linux 进程有两种运行模式:内核和用户。
KVM 增加了第三种模式:客户模式(有自己的内核和用户模式)。
KVM 所使用的方法是通过简单地加载内核模块而将Linux 内核转换为一个系统管理程序。
这个内核模块导出了一个名为/dev/kvm 的设备,它可以启用内核的客户模式(除了传统的内核模式和用户模式)。
有了/dev/kvm 设备,VM 使自己的地址空间独立于内核或运行着的任何其他VM 的地址空间。
设备树(/dev)中的设备对于所有用户空间进程来说都是通用的。
但是每个打开/dev/kvm 的进程看到的是不同的映射(为了支持VM 间的隔离)。
KVM安装KVM 之后,您可以在用户空间启动客户操作系统。
每个客户操作系统都是主机操作系统(或系统管理程序)的一个单个进程。
图1 提供了一个使用KVM 进行虚拟化的视图。
图1 KVM 原理图一、KVM 虚拟机的管理工具准确来说,KVM 仅仅是Linux 内核的一个模块。
管理和创建完整的KVM 虚拟机,需要更多的辅助工具。
QEMU-KVM:在Linux 系统中,首先我们可以用modprobe 命令加载KVM 模块,如果用RPM 安装KVM 软件包,系统会在启动时自动加载模块。
kvm虚拟化接口创建流程
kvm虚拟化接口创建流程KVM 虚拟化接口创建流程概述KVM (Kernel-based Virtual Machine) 虚拟化接口是一种内核模块,允许在主机操作系统上创建和运行虚拟机 (VM)。
创建 KVM 虚拟化接口涉及多个步骤,包括内核配置、模块加载、设备设置和VM 配置。
内核配置启用 KVM 支持:在内核配置中启用 KVM 选项,通常称为CONFIG_KVM。
编译和安装内核:编译并安装带有启用 KVM 支持的新内核。
模块加载加载 KVM 模块:使用 `modprobe kvm` 命令加载 KVM 内核模块。
加载用户空间组件:加载 KVM 用户空间组件,例如 `kvm-intel` 或 `kvm-amd`,具体取决于 CPU 架构。
设备设置创建虚拟网桥:创建虚拟网桥以连接虚拟机到主机网络。
使用`brctl` 或 `ovs-vsctl` 工具。
分配虚拟磁盘:为虚拟机分配一块虚拟磁盘,可以使用`qemu-img` 工具。
虚拟机配置创建虚拟机配置文件:创建 XML 配置文件,指定虚拟机的资源配置,例如 CPU、内存和存储。
启动虚拟机:使用 `virsh` 工具启动虚拟机。
详细步骤1. 内核配置以 Ubuntu 系统为例,可以通过修改 `/boot/config-`\<version\>`/config` 文件启用 KVM 支持,然后运行以下命令编译和安装内核:```make olddefconfigmake -j 8make install```2. 模块加载加载 KVM 内核模块:```sudo modprobe kvm```加载用户空间组件:```sudo modprobe kvm-intel # 英特尔 CPU sudo modprobe kvm-amd # AMD CPU```3. 设备设置创建虚拟网桥:```sudo brctl addbr br0sudo ip link set br0 up```分配虚拟磁盘:```sudo qemu-img create -f qcow2 mydisk.img 10G ```4. 虚拟机配置创建一个虚拟机配置文件:```xml<domain type='kvm'><name>myvm</name><memory unit='MiB'>1024</memory><vcpu>2</vcpu><os><type arch='x86_64' machine='pc'>hvm</type> </os><devices><disk type='file' device='disk'><driver name='qemu' type='qcow2'/><source file='mydisk.img'/></disk><interface type='bridge'><source bridge='br0'/> <target dev='vnet0'/> <model type='virtio'/> </interface></devices></domain>```5. 启动虚拟机使用 `virsh` 工具启动虚拟机: ```sudo virsh define myvm.xmlsudo virsh start myvm```高级设置自定义网络配置:使用 `virsh` 工具配置虚拟机的网络接口,例如设置静态 IP 地址或启用网络过滤。
KVM虚拟化技术方案
NonRoot
虚拟机
Root-NonRoot切换开销 VMM处理开销
Rootபைடு நூலகம்
第16页
目录
1. 背景介绍 2. KVM简介
UVP中KVM架构 CPU虚拟化 ◼ 内存虚拟化 I/O虚拟化
3. KVM特性功能介绍
第17页
内存虚拟化原理 - 虚拟化问题
⚫ Native操作系统对内存的认识与管理达成以下两点认识:
VMCS
2
Ring 3 Ring 0
VMCS n
第14页
KVM CPU虚拟化
⚫ 三种运行模式
用户态模式
内核态模式
客户模式
客户虚拟机
VM entry
VM exit Lightweight exit
VCPU 创建/初始化
VCPU 运行/退出处理
ioctl返回
ioctl
ioctl
VCPU 创建/初始化
– 2007年2月 Linux2.6.20正式版发布 ◼ 2008年9月 Redhat以1.07亿美元收购Qumranet ◼ 2009年9月 RHEL5.4开始支持KVM(同时支持Xen) ◼ 2010年11月 RHEL6.0之后仅支持KVM
云平台对KVM支持
◼ OpenStack, Eucalyptus, AbiCloud等同时支持KVM和Xen
VM与Hypervisor关系
Libvirt与KVM关系
第7页
libvirt、qemu、kvm部件的关系
第8页
目录
1. 背景介绍 2. KVM简介
UVP中KVM架构 ◼ CPU虚拟化 内存虚拟化 I/O虚拟化
3. KVM特性功能介绍
第9页
kvm虚拟化接口创建流程
kvm虚拟化接口创建流程KVM虚拟化接口的创建流程主要包括以下几个步骤:1. 安装KVM软件包2. 检查硬件支持3. 创建网络桥接口4. 创建虚拟机接下来我们将逐一介绍这些步骤的具体操作。
1. 安装KVM软件包KVM是基于Linux内核的虚拟化技术,因此在创建KVM虚拟化接口之前,首先需要安装KVM软件包。
在大多数Linux发行版中,可以使用包管理工具来安装KVM软件包。
例如,在Ubuntu中,可以使用apt命令来安装KVM软件包:```sudo apt-get install qemu-kvm libvirt-bin virtinst```在CentOS中,可以使用yum命令来安装KVM软件包:```sudo yum install qemu-kvm libvirt virt-install```安装完KVM软件包之后,需要启动libvirt服务:```sudo systemctl start libvirtd```2. 检查硬件支持在安装KVM软件包之后,需要检查硬件是否支持虚拟化。
大多数现代的CPU都支持虚拟化技术,但是有一些旧的CPU可能不支持。
可以使用以下命令来检查CPU是否支持虚拟化:```egrep -c '(vmx|svm)' /proc/cpuinfo```如果输出的数字大于0,则表示CPU支持虚拟化技术。
3. 创建网络桥接口在KVM虚拟化中,网络桥接口是用来连接虚拟机和物理网络的重要工具。
创建网络桥接口的步骤可能会有一点不同,根据不同的Linux发行版本。
下面以Ubuntu为例来介绍创建网络桥接口的具体步骤。
首先需要安装bridge-utils软件包:```sudo apt-get install bridge-utils```然后编辑网络配置文件,添加网络桥接口的配置信息:```sudo vi /etc/network/interfaces```在文件中添加以下配置信息:```auto br0iface br0 inet staticaddress 192.168.1.100netmask 255.255.255.0gateway 192.168.1.1bridge_ports eth0bridge_stp offbridge_fd 0bridge_maxwait 0```保存文件并退出编辑器,然后重启网络服务:```sudo systemctl restart networking```通过以上步骤,我们成功创建了网络桥接口。
KVM虚拟化技术之virt-manager使用及KVM虚拟化平台网络模型介绍
KVM虚拟化技术之virt-manager使⽤及KVM虚拟化平台⽹络模型介绍⼀.使⽤virt-manager创建和管理虚拟机1.使⽤VNC Viewer连接进⼊虚拟化平台主机2.打开终端输⼊virt-manager命令启动virt-manager虚拟机管理界⾯#virt-manager3.通过virt-manager安装CentOS 6.6的虚拟机点击如图所⽰图标新建虚拟机:选择PXE引导,我的⽹络内存在⼀个系统⾃动化部署服务器:选择操作系统类型和版本:设置内存和CPU个数:设置硬盘⼤⼩,这⾥采⽤动态扩展磁盘空间⽅式:忽略这个错误,由于是虚拟磁盘,不⽤担⼼空间,只需要保证系统空间不会超过物理磁盘实际空间:勾选选项是可以查看配置在安装前:我们可以在这个界⾯进⾏设置,我这⾥就不设置了,直接点击Begin Installation:我们选择安装个基本的系统:进⼊安装了:可以观察安装时Virt-manager界⾯的情况:可以知晓虚拟机正在运⾏,可以查看CPU的使⽤情况:安装完成后如图;关闭虚拟机,在虚拟机输⼊关机指令即可将虚拟机关闭;基于virt-manager创建管理虚拟机就完成了,很简单的。
下⾯的实验我们还是使⽤cirros轻量级的linux系统。
⼆.KVM虚拟化平台的⽹络模型1.⽹络模型介绍⼀般虚拟机虚拟⽹络的设置主要包括三种⽅式。
主要如下:NAT模式也有⼈称此种模式为host模式。
在这种模式下虚拟机可以理解成没有⾃⼰的独⽴⽹卡。
所有访问虚拟机的请求其实是直接发送给宿主机,然后通过访问宿主机转发到虚拟机上的。
相应的虚拟机访问其他⽹络,也是先转发到宿主机然后在转发出去。
对于宿主机之外的⽹络,是不知道该虚拟机存在的。
Bridge模式桥接模式是使⽤⽐较多的模式,它是虚拟机拥有⾃⼰的独⽴⽹卡和IP,然后通过借⽤宿主机的⽹卡对外连接⽹络。
它把宿主机的⽹卡当作了⼀种桥,通过这个桥连接外⽹的世界。
在这种模式下,可以简单的理解成虚拟机和宿主机是两个不同的机器,有独⽴IP可以相互访问。
Linux虚拟化——KVM安装步骤
Linux虚拟化——KVM安装步骤1、先查看cpu是否支持kvmKVM 需要有CPU 的支持(Intel vmx 或AMD svm),在安装KVM 之前检查一下CPU 是否提供了虚拟技术的支持:egrep '(vmx|svm)' --color=always /proc/cpuinfo如果输出的结果包含VMX,它是Intel处理器虚拟机技术标志:如果包含SVM,它是AMD 处理器虚拟机技术的标志,如果你什么都没有得到,那应你的系统并没有支持虚拟化的处理,不能使用KVM,另处linux发行版本必须在64bit环境中才能使用KVM。
2、BIOS中开启Virtual Technolege在主板BIOS中开启CPU的Virtual Technolege(VT,虚化技术),不同主板所在菜单不同例如:华硕主板开启虚拟化Intel主板开启虚拟化3、安装KVM服务器安装KVM 虚拟机和安装其他服务器一样,在选择操作系统类型是选择“Virtual Host”即可,其它步骤可参考“AiSchool平台安装指导”中操作系统安装部分。
如果使用此服务器管理其他KVM 主机,需要额外安装openssh-askpass 软件包。
注:(已安装好的操作系统,里面有重要资料无法重新安装的可以在已有的系统上安装如下软件包yum install kvm kmod-kvm qemu kvm-qemu-img virt-viewer virt-manager libvirt libvirt-python python-virtinst openssh-askpass或者如下图,安装需要的组4、检查kvm模块是否安装使用以下命令显示两个模块则表示安装完成[root@vm76 ~]# lsmod | grep kvmkvm_intel 54285 0kvm 333172 1 kvm_intel以上表明安装完成5、配置宿主机1、关闭防火墙(如不用)chkconfig iptables offservice iptables stop2、执行如下命令打开文件selinux配置文件。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Centos7安装kvm虚拟机(centos6也可以)1.本教程以vmware虚拟机为例子,在其中的centos7虚拟机上安装kvm虚拟机首先开启虚拟化模块2.安装qemu-kvm 、libvirtyum install-y qemu-kvm libvirt,其中qemu-kvm用来创建虚拟机硬盘,libvirt 用来管理虚拟机qemu下载地址:https:///(多种版本)3.安装virt-install,yum -y install virt-install(virt-install用来创建虚拟机)4.启动libvirtd并且设置开机自启动,systemctl start libvirtd 、systemctl enable libvirtd5.创建虚拟机硬盘,(使用qemu来创建一个虚拟机硬盘,大小可以自定义),qemu-img create -f raw /opt/CentOS-7-x86_64.raw 10G,硬盘名称为CentOS-7-x86_64.raw,硬盘大小为10G6.也可以用qcow2格式,此格式支持快照但是速度没有raw的快,命令方式类似,qemu-img create -f qcow2 /opt/centos.qcow2 10G7.在根目录下创建一个文件夹iso,将centos7的镜像上传到此目录下8.利用virt-install 创建一个名称为CentOS-7-x86_64的虚拟机,内存为10249.virt-install --virt-type kvm --name=centos --ram 1024 --vcpus=16 --cdrom=/iso/centos.iso --disk path=/data2/centos.raw --network bridge=br0 --graphics vnc,listen=0.0.0.0,port=5988, --force--autostart10.如果启动报错:ERROR internal error: process exited while connecting to monitor: 2019-05-10T17:10:20.075431Z qemu-kvm: -drivefile=/root/window.iso,format=raw,if=none,id=drive-ide0-0-1,readonly=o n: could not open disk image /root/window.iso: Could not open'/root/window.iso': Permission deniedDomain installation does not appear to have been successful.If it was, you can restart your domain by running:virsh --connect qemu:///system start windowsotherwise, please restart your installation.表示权限不足可以编辑配置文件 vi /etc/libvirtd/qemu.conf文件取消#user=”root” #group=”root”注释然后重启libvirtd systemctl restart libvirtd11.其中--name表示名称,ram表示内存为1024M,--vcpus表示cpu核数,cdrom 表示镜像所在目录,disk表示创建的虚拟机硬盘位置,port指定哪个端口安装时通过vnc连接就用哪个端口连接,安装多台机器时可以指定不同的端口然后来分别安装不同的操作系统,--graphics表示指定图形界面工具表示安装成功12.接下来通过vnc来连接虚拟机进行安装,地址为宿主机地址,端口为5988(防火墙提前开放端口)如果报错提示如下:修改成rgb222连接即可13.然后开始正常的系统安装过程,不在赘述14.安装成功后可以通过命令virsh list --all上述表示虚拟机是关闭状态开启kvm虚拟机命令virsh start CentOS-7-x86_64,关闭虚拟机命令为virsh shutdown CentOS-7-x86_64 重启为virsh reboot CentOS-7-x86_64有的时候virsh shutdown 命令不能关闭虚拟机,此时要在虚拟机(不是宿主)内安装acpid软件并设置开机自启动,然后就可以执行shutdown|reboot来关闭和重启了了yum -y install acpidservice acpid startchkconfig acpid on如果想连接此虚拟机还是要通过vnc来连接登陆安装net-tools 安装后才可以执行ifconfig命令ip地址走的是宿主机的虚拟网卡virbr0,宿主机网卡如下:上图中的虚拟机默认的是nat模式,内部的虚拟机可以访问外部网络,但是外部网络无法访问内部的虚拟机(xshell无法连接),可以通过配置成桥接的方式来实现xshell连接内部虚拟机15.配置桥接网络:系统如果安装了桌面环境,网络由NetworkManager来管理,它不支持桥接网络,所以需要先关闭NetworkManager,一定要关闭,否则容易报错,配置完桥接后还要启动NetworkManager要不桌面无法使用,是黑屏状态。
可以执行如下命令关闭:systemctl stop NetworkManager systemctl restart network,如果不关闭它也可以在下面创建网桥后在配置文件中加上参数"NM_CONTROLLED=no"即可创建网桥:virsh iface-bridge e ns33 br0创建完成后可以ifconfig可以看到br0网卡信息编辑虚拟机配置文件,修改如下内容:virsh edit CentOS-7-x86_64上图中的mac地址可以自定义,在这里配置即可,无需再去虚拟机的网卡里配置重启虚拟机virsh shutdown CenoOS-7-x86_64 virsh start CentOS-7-x86_64ip地址已和宿主机相同,可以访问外网并且xshell也可以连接也可以手动配置静态ip,如果还是没有显示eth0网卡信息,可以执行ifup eth0命令开启网卡,配置文件中的onboot一定设置成yes至此,搭建kvm虚拟机完成附加:16.如果要安装多个kvm虚拟机那么步骤同上,安装完操作系统后同样配置网络方式更改为网桥模式,例如又安装了centos6.5系统安装完成后编辑文件,配置网桥信息:然后编辑虚拟机内的网卡配置文件,添加自定义网卡信息:重启网卡service network restart 测试上网情况以及xshell连接可以正常连接17.如果一台机器上安装了多台kvm虚拟机,如果想通过vnc连接只能输入对应的端口号(从5900开始递增),此种方法过于麻烦,可以通过安装图形化管理界面virt-manager来管理所有虚拟机(前提是宿主机已经安装了桌面环境,gnome 或者kde桌面都可以,建议kde桌面,安装简单)在宿主机命令行界面执行yum -y install virt-manager安装即可宿主机安装vnc 通过vnc连接宿主机桌面环境(不是连接内部机器),并打开终端命令行,在其中执行virt-manager,弹出界面如下:点击对应的虚拟机右键既可选择开启/关闭/重启虚拟机如果右键关机键无法实现关机可以从此处关机windows安装安装window的方法和上面一样,创建的磁盘空间要大一些,最好20G以上qemu-img create -f raw /data/window.raw 20G以上也可以用qcow2格式qemu-img create -f qcow2 /data/window.qcow2 20G(建议用qcow2因为支持快照但是速度没有raw快)18.virt-install --virt-type kvm --name window --ram 1024--cdrom=/iso/window.iso --disk path=/data/window.qcow2 --networkbridge=br0 --graphics vnc,listen=0.0.0.0,port=5958, --force --autostart然后通过vnc 端口5958进行连接安装过程中可能重启数次,可能关闭后不能启动需要手动执行命令virsh start windows 启动继续完成安装.创建密码:默认也是nat模式,同理去配置文件中更改成网桥模式,如果ipconfig没有网卡信息就手动配置下自定义的virsh edit windows更改后重启机器如图,已变成桥接模式并且可以本地通过mstsc访问kvm安装的虚拟机默认网卡为rtl8139此网卡在网路负载过重的情况下会出现崩溃的情况导致无法上网,如果出现此种情况可以将默认网卡修改为e1000 命令如下:(先关机)上述命令执行完后启动机器即可同样可以通过virt-manager来管理如果手动安装完虚拟机后在virt-manager里看不到那么可以先断开virt-manager与虚拟机的连接然后在重新连接即可看到Virt-manager来安装虚拟机,此种方法简单,操作如图所示:选择镜像位置设置内存和CPU 创建磁盘空间自定义名称点击finish即可开始安装!!kvm快照管理kvm虚拟机默认使用raw的镜像格式,优点是性能好,速度快,但是缺点是不支持一些新的功能,如镜像、zlib磁盘压缩、AES加密等,要使用镜像功能需要将raw装换为qcow2格式进行快照备份1.查看现有磁盘镜像格式qemu-img info centos.raw2.关闭虚拟机将raw转换成qcow2格式qemu-img convert -f raw -O qcow2 centos.raw centos.qcow2-f表示源镜像格式,-O表示目标镜像格式(不是零是大写的欧)还将原格式的拷贝了一份再次查询当前镜像格式发现已经变成了qcow23.修改虚拟机配置文件,将配置文件中的raw格式修改成qcow2格式4.对虚拟机centos6.9进行创建快照virsh snapshot-create-as centos6.9 centos其中centos属于快照别名,通过as制定的,也可以不加as不加别名得到的就是一个版本号5.查看虚拟机快照版本virsh snapshot-list centos6.9virsh snapshot-current centos6.9可以看到版本号创建的快照默认在/var/lib/libvirt/qemu/snapshot目录下6.恢复虚拟机快照,恢复之前要先关闭虚拟机,virsh domstate centos6.9确认是否为关闭状态7.virsh snapshot-revert centos6.9 centos恢复之前可以通过virsh snapshot-list centos6.9查看当前镜像下有几个快照然后选怎恢复哪个版本的快照8.删除虚拟机快照virsh snapshot-delete centos6.9 centoskvm虚拟机重命名1.查看所有kvm虚拟机virsh list --all2.重命名虚拟机需要先将虚拟机关闭,然后导出其xml文件cd /etc/libvirt/qemu //进入xml文件目录下virsh dumpxml centos6.9 > centos.xmlcentos6为重命名之后的虚拟机名称,编辑centos6.xml文件3.使用virsh undefine命令删除之前的虚拟机,根据新的xml文件定义新的kvm虚拟机4.virsh undefine centos6.9 //删除原来的虚拟机5.virsh define /etc/libvirt/centos6.xml //重新定义新的虚拟机6.再次使用virsh list --all命令查看结果注意:当虚拟机下面存在快照时无法用virsh undefine来删除,需要先将快照删除报错如下:更改虚拟机和内存时可以直接进入文件中修改virsh edit centos6kvm虚拟机克隆克隆可以手动克隆也可以选择通过virt-manager的方式来克隆virt-manager克隆方式简单只需要先关闭虚拟机后然后在图形界面邮件选择clone即可,例如:克隆完成后新的克隆机的mac地址都会自动变更成新的,但是原来安装的机器的vnc端口不会变(如果是通过vnc来安装的).此时我们需要更改原端口然后就可以通过vnc和端口来连接机器连接之后更改ip地址,然后重启网卡或者重启机器后即可正常使用手动克隆:如果虚拟机出现下面这种情况:表示挂起可以使用命令virsh resume k8s来唤醒虚拟机如果要强制关闭虚拟机则使用virsh destroy k8s更改虚拟机磁盘位置当虚拟机所在的磁盘空间满了之后需要将部分虚拟机转移到另一个磁盘中,操作方法如下首先将对应的磁盘文件转移到想要转移的地方,例如原来在/data目录下现在转移到/vnetoo目录下mv /data/ansible.img /vnetoo移动之后然后修改对应的xml文件(修改之前先备份),xml文件在/etc/libvirt/qemu/目录下修改一定要采用virsh edit ansible的方式修改vi /vim方法修改后无法生效修改后完后执行virsh start ansible即可重新启动虚拟机将raw格式的虚拟机装换成qcow2格式也可以起到压缩空间的作用,qcow2属于动态的空间会随着使用量的增加而增加,例如原来设定的空间为20G,那么做成qcow2格式的可能只有几个G,然后随着使用量的增加而增加,最后达到峰值20G禁止kvm虚拟机自启动命令:virsh autostart --disable centos7.0通过xml来恢复虚拟机:kvm虚拟机静态迁移:可以将B物理机器上的虚拟机的磁盘文件以及xml配置文件拷贝到A 机器上然后重新定义机器即可,例如:在A机器上执行:将B机器上的磁盘文件拷贝到A机器的指定目录下scp root@B机器:/home/centos.raw/home/scp root@B机器:/etc/libvirt/qemu/centos.xml/etc/libvirt/qemu/重新定义机器:virsh define /etc/libvirt/qemu/centos.xmlkvm虚拟机动态迁移:1.创建共享存储:(nfs)2.两台机器挂在共享存储3.启动动态迁移4.创建迁移互的配置文件5.重新定义虚拟机将vmware虚拟机导入到kvm中windows安装vmware后在安装目录下会有以vmdk结尾的镜像文件如图:此镜像即为vmware的镜像文件,上图中只有一个镜像文件表示创建时选择的是将磁盘存储为单个文件,如图:(建议创建时选择单个文件,可以提高磁盘性能)如果创建时选择的是多个文件,则需要使用命令将多个文件合并成一个文件,如图表示多个文件合并方法:以管理员身份运行cmd并进入到vmware安装路径下用vmware自带的工具vmware- vdiskmanager.exe来合并多个文件,命令如下vmware-vdiskmanager.exe -r "D:\CentOS7.vmdk" -t 0 "D:\centos7.vmdk"注意:合并的时候要以总文件来作为命令来执行不要以下面的0001、0002等文件作为命令行,执行上述命令后下面的分支自然会和总的文件合并到一起合并之后将磁盘文件拷贝到kvm宿主机目录下,然后将其格式转换成qcow2格式,例如Cen.img磁盘文件的格式即为qcow2装换之后可以通过virt-manager来启动虚拟机(直接本地导入存在的磁盘文件即可)选择刚才转换后的磁盘文件然后下一步即可打开虚拟机至此vmware中虚拟机导入kvm中成功windows虚拟机扩容:关闭Windows机器qemu-img resize win7.img +120G(原有磁盘镜像上添加空间即可)执行完成后进入计算机-管理-磁盘管理-新建简单卷即可linux系统内部kvm虚拟机扩容:内部虚拟机有两种格式raw和qcow2格式,本教程扩容方式采用新增一个磁盘的方式实现扩容(简单方便)1.首先创建磁盘空间文件:qemu-img create -f raw test.raw 10G, 表示新增一块磁盘并且空间大小为10G2.关闭要扩容的虚拟机 virsh shutdown centos63.编辑配置文件,virsh edit centos6如图可以看到,磁盘名称要改成vdb 然后添加cache=’none’即可4.启动虚拟机virsh start centos65.连接虚拟机后执行fdisk -l 查看磁盘信息发现多了/dev/vdb磁盘6.格式化磁盘:mkfs.ext4 /dev/vdb7.执行mount /dev/vdb /test挂载即可virsh autostart 机器名:开启自启动virsh autostart --disable 机器名关闭自启动。