VMware NSX原理与实践----NSX-MH

2023-10-30 10:10
文章标签 实践 原理 vmware nsx mh

本文主要是介绍VMware NSX原理与实践----NSX-MH,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

各位客官,早啊,今日本店为大家准备了可口的早饭,希望各位朋友好好得吃完这顿饭,不然可没有力气赶路😄小二,给各位爷上菜
前序:到前面的讲的内容结束,NSX-V的架构和功能以及各种流量模型均已经介绍完毕了,所以今天咱们来点新东西:NSX-MH 。因为NSX-V是VMware公司针对vSphere定制开发的,只能用于纯粹的vSphere环境。要想支持其他的内核(Hypervisor),就需要NSX-MH软件。那么在我们介绍这个NSX-MH架构之前,首先需要给大家介绍两款重要的开源虚拟化解决方案:Xen和KVM。
一、开源虚拟化平台之Xen
Xen开源软件在虚拟机的工作类型方面分为半虚拟化和全虚拟化两种。其中半虚拟化技术主要是通过修改操作系统的内核来实现的虚拟化技术。Xen的半虚拟化技术主要使用在相同版本的Linux之上,换句话说,如果你想要使用半虚拟化的技术来启动虚拟机,那么就要求你要启动的虚拟机必须都是相同的操作系统,甚至是相同的版本和内核,是不是感觉很严格?
在半虚拟化的Xen架构中,系统是分为多个层级(layer)来执行的,以下图为例举个例子:Linux开机之后,首先载入的是Xen的内核,而第一个在其上启动的虚拟机的操作系统,称之为domain-0.它包含了其他虚拟机启动所需要的指令,简单的说它就是控制其他虚拟机的主控系统。虽然大家都是虚拟机,不过看来还是有高低之分的。所以其他的虚拟机自然也就会被命名为domain-1,domain-2等等,以此类推。
在这里插入图片描述
如果需要安装不同版本的Linux或者其他的操作系统(比如windows),就需要使用全虚拟化技术,但是全虚拟化技术并不是随意使用的,它也是有着一些硬件方面的限制。限制如下:
1)硬件需要支持Intel-VT技术
2)硬件支持AMD-SVM技术
二、开源虚拟化平台之KVM
KVM的全称是基于内核的虚拟机,它是一个开源的系统虚拟化模块,可以用来实现服务器的虚拟化功能。KVM是Linux内核的一部分,它的基本架构有两个组件构成。
两个组件分别是:libvirt和qemu.先说一说libvirt这个组件,libvirt是实现虚拟化数据库的工具包,想要运行KVM,就需要安装这个工具包,它的主要功能是实现KVM与Linux的交互,主要负责虚拟机的创建、虚拟内存的分配以及vCPU的运行等等。再说一说qemu,它是用于模拟虚拟机用户空间的组件,提供I/O设备模型,访问外部设备的途径等。qemu通过libKVM应用程序接口,用fd通过ioctl向设备驱动发送创建、运行虚拟机命令,运行了Linux的设备就会来解析并执行命令。KVM的架构图如下:
在这里插入图片描述
KVM模块使得运行了Linux的主机成了一个虚拟机监视器,并且在原有的两种Linux模式上又添加了客户模式,那么这三种模式的作用是什么呢?接下来看看
客户模式:执行非I/O的客户代码,虚拟机运行在这个模式下;
Linux用户模式:代表用户执行I/O指令,qemu运行在这个模式下;
内核模式:处理因I/O或者其他指令引起的客户模式推出(VM_EXIT)实现客户模块的切换工作。KVM模块工作在这个模式下。
对于上面的图,可以这样给大家去解释:用户的qemu通过libKVM应用程序接口,通过ioctl进入内核模式,而KVM模块为虚拟机创建虚拟内存、虚拟CPU之后执行虚拟机launch命令,进入客户模式,加载并执行Guest OS.如果Guest OS 在执行过程中发生外部中断,就会暂停并且退出客户模式并进行异常处理,处理完毕后会重新进入客户模式进行操作。

各位,天色不早了,小店也要上闸板休息了,祝您好梦。小二,关门。

这篇关于VMware NSX原理与实践----NSX-MH的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/307190

相关文章

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

python实现简易SSL的项目实践

《python实现简易SSL的项目实践》本文主要介绍了python实现简易SSL的项目实践,包括CA.py、server.py和client.py三个模块,文中通过示例代码介绍的非常详细,对大家的学习... 目录运行环境运行前准备程序实现与流程说明运行截图代码CA.pyclient.pyserver.py参

使用C++实现单链表的操作与实践

《使用C++实现单链表的操作与实践》在程序设计中,链表是一种常见的数据结构,特别是在动态数据管理、频繁插入和删除元素的场景中,链表相比于数组,具有更高的灵活性和高效性,尤其是在需要频繁修改数据结构的应... 目录一、单链表的基本概念二、单链表类的设计1. 节点的定义2. 链表的类定义三、单链表的操作实现四、

MySQL中的MVCC底层原理解读

《MySQL中的MVCC底层原理解读》本文详细介绍了MySQL中的多版本并发控制(MVCC)机制,包括版本链、ReadView以及在不同事务隔离级别下MVCC的工作原理,通过一个具体的示例演示了在可重... 目录简介ReadView版本链演示过程总结简介MVCC(Multi-Version Concurr

Spring Boot统一异常拦截实践指南(最新推荐)

《SpringBoot统一异常拦截实践指南(最新推荐)》本文介绍了SpringBoot中统一异常处理的重要性及实现方案,包括使用`@ControllerAdvice`和`@ExceptionHand... 目录Spring Boot统一异常拦截实践指南一、为什么需要统一异常处理二、核心实现方案1. 基础组件

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬