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

相关文章

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行