服务器虚拟化开源技术主流架构之争

http://virtual.51cto.com/art/201812/589084.htm

大部分客户已经是KVM+OpenStack的架构了

我所见到的
工商云 和 中建的财务云 都是使用的KVM+OPENSTACK IaaS 已经一统天下 后面的 就看K8S了 这里不考虑ESXi和HyperV 的闭源市场

在现代IT系统的核心组件中开源技术已经成为不可或缺的力量,比如x86架构操作系统Linux、Unix操作系统BSD、MySQL数据库、Apache Web服务等。

据统计,超过50%的技术开发人员都信奉开源哲学,时至今日,已经完全形成了一套成熟完整的开源软件生态体系。在开源技术欣欣向荣的现象背后,真正推动其迅速发展的本质往往是因为其蕴含的价值:

开源软件普遍价格实惠,用户能够将更多的资金投入到核心业务上;

开源软件使得厂商甚至客户有权利自由的修改软件,产生不同形态的产品,用户能有更多选择产品的空间,防止被某一厂商绑定;

开源软件在定制化开发方面有天然优势,可以根据用户业务系统特点定制化,为业务系统的高效稳定运行提供良好的支撑。

主流服务器虚拟化技术的开源门派有两个——KVM和Xen。

广义上的KVM架构由KVM内核模块(狭义的KVM)和QEMU-KVM模拟模块组成。KVM内核模块是在Linux内核的基础上增加的虚拟机管理模块,通过重用Linux内核中已经完善的进程调度、内存管理、I/O管理等模块。QEMU-KVM模拟模块负责为虚拟机提供一个互相隔离的虚拟化资源环境,包括vCPU、vRAM、vDisk、vNIC等,每一个虚拟机都是QEMU-KVM的一个进程,由Hypervisor中的进程调度模块统一管理调度。

广义上的Xen架构由Xen Hypervisor和虚拟域(Domain)两大部分组成。Xen Hypervisor负责将CPU和RAM两大硬件资源虚拟出互相隔离的资源,供虚拟域使用,同时管理和监控虚拟域的资源和系统运行情况;每个虚拟域就是一个虚拟机环境,其中虚拟域又分为特权虚拟域(Dom0)和非特权虚拟域(DomU),Dom0先于DomU启动,DomU访问I/O资源必须要经过Dom0,Dom0负责I/O资源的虚拟化,可以直接访问I/O物理资源。如果将Xen架构比作完整的汽车,Xen Hypervisor就是其中的发动机,安装了一系列域管理和控制工具的Dom0就是其他零部件,两者合一才能使虚拟化系统正常运转起来。

相比于Xen架构,KVM架构有三大的优势:

  1. 同等硬件资源环境下,KVM的性能表现更优;
  2. KVM架构天然的继承Linux内核更新迭代带来的系统优化,几乎不费力气,就完成了一次功能升级,但对于Xen架构来说,每一次Xen Hypervisor内核或者Linux内核版本升级,Xen架构需要同步优化联调Xen Hypervisor内核和特权域基于Linux的内核,才能实现整个虚拟化内核的升级;
  3. KVM架构与Openstack云平台架构衔接地最好,Openstack架构对KVM架构的支持最好,目前,OpenStack云平台95%以上的虚拟化计算资源池使用了KVM架构。

[51CTO]服务器虚拟化开源技术主流架构之争的更多相关文章

  1. 华为云计算IE面试笔记-Fusionsphere架构及组件介绍(服务器虚拟化解决方案)

    eDSK   最上层则是eDSK是我们FusionSphere服务器虚拟化解决方案中的虚拟化北向统一API接口,其他的第三方系统或者是其他运营平台(FC.VMware等)可以通过eDSK轻松完成无缝对 ...

  2. 主流服务器虚拟化技术简单使用——KVM(二)

    通过Linux工具管理KVM 主流服务器虚拟化技术简单使用——KVM(一)部署了一台KVM主机,提到KVM可以通过命令行工具(virt-install.virsh)和GUI工具(virt-manage ...

  3. 主流服务器虚拟化技术简单使用——Hyper-V(二)

    当在多台Windows Server上部署了hyper-v的时候,需要采用合适的方法管理这些hyper-v节点. 远程桌面 最简单的方法就是逐台远程桌面登陆Windows Server,再使用每台本地 ...

  4. Java开源生鲜电商平台-性能优化以及服务器优化的设计与架构(源码可下载)

    Java开源生鲜电商平台-性能优化以及服务器优化的设计与架构(源码可下载) 说明:Java开源生鲜电商平台-性能优化以及服务器优化的设计与架构,我采用以下三种维度来讲解 1.  代码层面. 2.  数 ...

  5. Citrix 服务器虚拟化之一 网络部署Xenserver 6.2

    Citrix 服务器虚拟化之一  网络部署Xenserver 6.2 思杰的XenServer®是完整的服务器虚拟化平台. XenServer软件包中包含所有你需要创建和管理部署的虚拟x86计算机上运 ...

  6. 大会聚焦 | 开源技术盛会LinuxCon首次来到中国,大咖齐聚关注业界动态

    2017年6月19-20日,开源技术盛会LinuxCon + ContainerCon + CloudOpen(LC3)首次在中国举行.两天议程满满,包括 17 个主旨演讲.8 个分会场的 88 场技 ...

  7. HTML5中的SSE(服务器推送技术)

    本文原链接:https://cloud.tencent.com/developer/article/1194063 SSE技术详解:一种全新的HTML5服务器推送事件技术 前言 概述 基本介绍 与We ...

  8. XenServer(服务器虚拟化平台)

    Citrix Xenserver,思杰基于Xen的虚拟化服务器.Citrix XenServer是一种全面而易于管理的服务器虚拟化平台,基于强大的 Xen Hypervisor 程序之上.Xen技术被 ...

  9. 感知开源的力量-APICloud Studio开源技术分享会

    2014.9.15 中国领先的“云端一体”移动应用云服务提供商APICloud正式发布2015.9.15,APICloud上线一周年,迎来第一个生日这一天,APICloud 举办APICloud St ...

随机推荐

  1. <数据结构与算法分析>读书笔记--函数对象

    关于函数对象,百度百科对它是这样定义的: 重载函数调用操作符的类,其对象常称为函数对象(function object),即它们是行为类似函数的对象.又称仿函数. 听起来确实很难懂,通过搜索我找到一篇 ...

  2. OpenCV——KAZE、AKAZE特征检测、匹配与对象查找

      AKAZE是KAZE的加速版 特征点查找和绘制:把surf中的surf改成KAZE或AKAZE即可 #include <opencv2/opencv.hpp> #include < ...

  3. (转载)c++引用

    引用,顾名思义是某一个变量或对象的别名,对引用的操作与对其所绑定的变量或对象的操作完全等价 语法:类型 &引用名=目标变量名: 特别注意: 1.&不是求地址运算符,而是起标志作用 2. ...

  4. 包学会之浅入浅出 Vue.js:开学篇

    2016年,乃至接下来整个2017年,如果你要问前端技术框架什么最火,那无疑就是前端三巨头:React.Angular.Vue.没错,什么jQuery,seaJs,gulp等都逐渐脱离了热点.面试的时 ...

  5. 初识 ServiceWorker

    初识ServiceWorker 初识ServiceWorker 在8月份的时候.W3C更新了一个叫Service Workers的API. 了解过HTML5中的Web Worker的人可能会对这个AP ...

  6. 使用clipboard插件实现div、textarea、input里面的内容复制到粘贴板

    一.引用clipboard的js文件 二.编写代码.data-clipboard-action=“copy”,代表要执行的动作是复制.data-clipboard-target里面要是要选择复制的元素 ...

  7. 20155306白皎 《网络对抗》 Exp9 Web安全基础实践

    20155306白皎 <网络对抗> Exp9 Web安全基础实践 一.基本问题回答 SQL注入攻击原理,如何防御 原理是: 就是通过把SQL命令插入到"Web表单递交" ...

  8. 搭建django虚拟环境完整步骤

    一.建立虚拟环境 pip install virtualenv 要使用Django,首先要建立一个虚拟工作环境.我们先为项目建立一个文件夹learn,在文件夹中打开命令行(shift+右击),来建立另 ...

  9. Windows10没有修改hosts文件权限的解决方案(亲测有效)

    当遇到有hosts文件不会编辑或者,修改了没办法保存”,以及需要权限等问题如图: 或者这样: 我学了一招,现在教给你: 1.win+R 2.进入hosts的文件所在目录: 3.我们开始如何操作才能不出 ...

  10. TimelineJS JSON 数据格式 - 译文 [原创]

    TimelineJS 是用于绘制时间轴的 Javascript 开源脚本,目前是 TimelineJS3 版.参阅 https://github.com/NUKnightLab/TimelineJS3 ...