设为首页 收藏本站
查看: 1119|回复: 0

[经验分享] CentOS 7部署KVM之一架构介绍

[复制链接]

尚未签到

发表于 2017-6-21 19:24:08 | 显示全部楼层 |阅读模式
  ----本文修改整理自网络,非本人原创。
虚拟化介绍
  虚拟化(Virtualization)是一种资源管理技术,将计算机的各种试题资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来。打破实体结构间的不可切割的障碍,使的用户可以比原本的组态更好的方式来应用这些资源。这些资源的新虚拟部份是不受现有资源的架设方式,地域或物理组态所限制。一般所指的虚拟化资源包括计算能力和资料存储。
  虚拟化技术中大多数人接触的最早且最多的应该就是虚拟机(Virtual Machine),它是通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统。所谓完整的计算机系统简单点解释就是一台含有CPU、内存、硬盘、显卡、网卡、光驱等设备的电脑,只是对于虚拟机来说这些设备都是通过软件模拟出来的。
全虚拟化和半虚拟化
  全虚拟化(Full Virtualization)模拟出来的虚拟机中的操作系统是跟底层的硬件完全隔离的,虚拟机中的所有的硬件资源都是通过虚拟化软件基于硬件来模拟的,代表产品有VMware ESXI和KVM。
  这样的好处就是每台虚拟机有一个完全独立和安全的运行环境,虚拟机中的操作系统也不需要做任何修改,并且易于迁移。在操作全虚拟化的虚拟机的时候,使用者并不知道这是一台虚拟机。
  缺点就是由于虚拟机的资源全部都需要通过虚拟化软件来模拟,会损失一部分的性能。
  半虚拟化(Para Virtualization)的架构跟全虚拟化基本一样,但是为了提高性能和效率,需要修改虚拟机中的操作系统来集成一些虚拟化方面的代码,通过这种方法来减小虚拟化软件的负载。代表作有Microsoft的Hyper-V和XEN。
  这样的好处就是虚拟化整体的性能会更好,因为修改后的虚拟机操作系统承载了部分虚拟化软件的工作,缺点就是由于要修改虚拟机的操作系统,用户是知道使用的环境是虚拟化环境,而且兼容性比较差,用户体验也比较麻烦(得去找集成过虚拟化代码的操作系统)。
Hypervisor介绍
  Hypervisor是一种运行在物理服务器和操作系统之间的中间软件层,可允许多个操作系统和应用共享一套基础物理硬件,因此也可以看作是虚拟环境中的“元”操作系统,它可以协调访问服务器上的所有物理设备和虚拟机,也叫虚拟机监视器(Virtual Machine Monitor)。Hypervisor是所有虚拟化技术的核心。非中断地支持多工作负载迁移的能力是Hypervisor的基本功能。当服务器启动并执行Hypervisor时,它会给每一台虚拟机分配适量的内存、CPU、网络和磁盘,并加载所有虚拟机的客户操作系统。
Hypervisor分类
  原生型(Native or Bare-metal)又称裸机型,Hypervisor作为一个很薄的操作系统(操作系统也是软件,只不过它是一个比较特殊的软件)直接运行在硬件之上来控制硬件资源并管理虚拟机。比较熟知的有VMware的ESXi和Microsoft的Hyper-V等。


  宿主型(Hosted)又称托管型,Hypervisor运行在传统的操作系统上,同样可模拟出一整套虚拟硬件平台。比较熟知的为VMware的Workstation和Oracle的Virtual Box等。


  从性能角度来看,不论原生型还是宿主型都会有性能损耗,但宿主型比原生型的损耗更大,所以企业生产环境中基本都使用的是原生型Hypervisor,宿主型的Hypervisor一般都用到实验或测试环境中。
KVM介绍
  KVM(Kernel-based Virtual Machine)是一种基于Linux x86硬件平台的开源全虚拟化解决方案。KVM需要CPU的虚拟化指令集支持,如Intel的Intel VT(vmx指令集)或AMD的AMD-V(svm指令集)。
  KVM作为Hypervisor,主要涵盖有两个重要组成部分,一个是Linux内核的KVM模块,另外一个是提供硬件仿真的QEMU(Quick Emulator)。 另外为了KVM整个虚拟化环境能够易于管理,还需要Libvirtd服务和基于Libvirt开发出来的管理工具。
KVM虚拟化体系结构
  KVM作为Hypervisor,主要涵盖有两个重要组成部分,一个是Linux内核的KVM模块,另外一个是提供硬件仿真的QEMU(Quick Emulator)。 另外为了KVM整个虚拟化环境能够易于管理,还需要Libvirtd服务和基于Libvirt开发出来的管理工具。
DSC0000.png

KVM模块
  严格意义上讲,KVM仅仅只是一个Linux模块,他的主要功能在提供物理CPU到虚拟CPU的一个映射,提供虚拟机的硬件加速来提升虚拟机的性能。
  KVM模块本身没办法作为一个Hypervisor模拟出一个完整的虚拟机,并且我们也没办法直接对Linux内核进行操作,所以需要借助其他的软件来进行,QEMU就扮演着一个这样的角色。
QEMU
  QEMU本身就是一个宿主型的Hypervisor,就算是没有KVM他一样也可以通过模拟来创建和管理虚拟机。但是上面也提到过宿主型的Hypervisor在性能上损耗很大,所以QEMU又借助了KVM的模块来提升虚拟化的整体性能。
Libvirt
  Libvirt是管理虚拟机和其他虚拟化功能,比如存储管理,网络管理的软件集合。它包括一个API库,一个守护程序(libvirtd)和一个命令行工具(virsh);libvirt本身构建于一种抽象的概念之上。它为受支持的虚拟机监控程序实现的常用功能提供通用的API。libvirt的主要目标是为各种虚拟化工具提供一套方便、可靠的编程接口,用一种单一的方式管理多种不同的虚拟化提供方式。Libvirt也支持多种虚拟化平台如KVM, Xen, ESX和QEMU等
Libvirtd
  Libvirtd是运行的在KVM主机上的一个服务端守护进程,为KVM以及它的虚拟机提供本地和远程的管理功能,基于Libvirt开发出来的管理工具可通过Libvirtd服务来管理整个KVM环境。Libvirt就是一堆标准的库文件,给多种虚拟化平台提供一个统一的编程接口,相当于管理工具需要基于Libvirt的标准接口来进行开发,在开发完成后的工具可支持多种虚拟化平台。而Libvirtd是一个在Host主机上运行着的守护进程,在管理工具和KVM之间起到一个桥梁的作用,管理工具可通过Libvirtd服务来管理整个虚拟化环境。
Virsh
  virsh就是基于Libvirt开发的一个命令行的KVM管理工具,可以使用直接模式(Direct Mode)或交互模式(Interactive Mode)来实现虚拟机的管理,如创建、删除、启动、关闭等。
Virsh-Manager
  Virt-Manager同样也是一个KVM管理工具,不过它是基于图形界面的。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-386470-1-1.html 上篇帖子: 理解HTTP和HTTPS的区别 下篇帖子: Windows Server2008各版本区别
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表