Hyper-V 网络虚拟化技术细节

Hyper-V 网络虚拟化技术细节

 

适用对象:Windows Server 2012 R2

服务器虚拟化能让多个服务器实例在同一台物理主机上同步运行,但各个服务器实例都是相互独立的。 每台虚拟机的运作本质上就像是只有这一台服务器在该物理计算机上运行。 网络虚拟化也有类似的功能,即多个虚拟网络基础结构在同一个物理网络上运行(可能有重叠的 IP 地址),而且每个虚拟网络基础结构的运作就好像只有这一个虚拟网络在此共享的网络基础结构上运行。 图 1 显示了此关系。

图 1:服务器虚拟化与网络虚拟化对比

图 1:服务器虚拟化与网络虚拟化对比

 

在 Hyper-V 网络虚拟化 (HNV) 中,客户被定义为一组部署在数据中心的虚拟机的“拥有者”。 客户可以是多租户公共数据中心的一家公司或企业,或者是私有数据中心的一个部门或业务单位。 每个客户可以在该数据中心有一个或多个 VM 网络,而每个 VM 网络由一个或多个虚拟子网组成。

VM 网络

  • 每个 VM 网络由一个或多个虚拟子网组成。 一个 VM 网络构成一个独立边界,VM 网络中的虚拟机可相互通信。 因此,同一个 VM 网络中的虚拟子网不得使用重叠的 IP 地址前缀。

  • 每个 VM 网络包含一个用于标识 VM 网络的路由域。 标识 VM 网络的路由域 ID (RDID) 由数据中心管理员或者数据中心管理软件(如 System Center 2012 R2 虚拟机管理器 (VMM))分配。 RDID 是一个 Windows GUID - 例如“{11111111-2222-3333-4444-000000000000}”。

虚拟子网

  • 虚拟子网为同一个虚拟子网中的虚拟机实行第三层 IP 子网语义。 虚拟子网是一个广播域(与 VLAN 相类似)。 同一虚拟子网中的虚拟机必须使用相同的 IP 前缀。

  • 每个虚拟子网都属于一个 VM 网络 (RDID),并分配有唯一的虚拟子网 ID (VSID)。 VSID 在数据中心内部必须是唯一的,可在 4096 到 2^24-2 的范围内。

VM 网络和路由域的主要优点是能让客户将网络拓扑带到云中。 在图 2 的示例中,Contoso 公司有两个不同的网络:研发网络和销售网络。 由于这些网络有不同的路由域 ID,因此彼此之间不能进行交互。 也就是说,Contoso 研发网络与 Contoso 销售网络相互独立,尽管它们都属于 Contoso 公司。Contoso 研发网络包含三个虚拟子网。 注意:一个数据中心内的 RDID 和 VSID 都是唯一的。

图 6:Hyper-V 网络虚拟化堆栈

图 2:客户网络和虚拟子网

在图 2 中,VSID 为 5001 的虚拟机能通过 HNV 将其数据包路由或转发到 VSID 为 5002 或 5003 的虚拟机中。 在将数据包送往 Hyper-V 交换机之前,HNV 将把传入数据包的 VSID 更新为目标虚拟机的 VSID。 这只有在两个 VSID 都属于一个 RDID 的情况下才能实现。 如果数据包上的 VSID 与目标虚拟机的 VSID 不匹配,数据包会被丢弃。 因此,带有 RDID1 的虚拟网络适配器不能将数据包发送到带有 RDID2 的虚拟网络适配器。

System_CAPS_note注意

在上述的数据包流描述中,“虚拟机”实际上指的是虚拟机上的“虚拟网路适配器”。 通常一台虚拟机只有一个虚拟网络适配器。 在这种情况下,虚拟机和虚拟网络适配器具有相同的含义。 由于一台虚拟机可以有多台虚拟网络适配器,这些虚拟网络适配器可以有不同的虚拟子网 ID (VSID) 或路由域 ID (RDID),HNV 专门侧重虚拟网络适配器之间发送和接收的数据包。

每个虚拟子网定义一个第三层 IP 子网以及一个类似于 VLAN 的第二层 (L2) 广播域边界。 当虚拟机广播数据包时,广播只限于与 VSID 相同的交换机端口相连接的虚拟机。 每个 VSID 可与 PA 的多播地址相关联。 VSID 的所有广播流量均通过此多播地址进行发送。

System_CAPS_note注意

HNV 不依赖于广播或多播。 对于 VM 网络中的广播或多播数据包,将使用 PA 多播 IP 地址(如果已配置)。 但是,许多数据中心运营商都不会在其环境中启用多播。 因此,如果 PA 多播地址不可用,将使用智能 PA 单播复制。 这意味着,数据包只会单播到针对数据包所在的特定虚拟子网配置的 PA 地址。 此外,不管主机上存在多少个相关虚拟机,都只为每个主机发送一个单播数据包。

除作为一个广播域外,VSID 也能提供隔离。 HNV 中的一个虚拟网络适配器与具有一个 VSID ACL 的 Hyper-V 交换机端口相连接。 如果数据包到达这个具有不同 VSID 的 Hyper-V 交换机端口,该数据包会被丢弃。 只有数据包的 VSID 与交换机端口的 VSID 相匹配,数据包才能被送到 Hyper-V 交换机端口。 正因为如此,在上述图 2 的示例中,该数据包从 VSID5001 向 VSID5003 虚拟机传送时,在送达目标虚拟机之前,必须更改数据包的 VSID。

如果 Hyper-V 交换机端口没有 VSID ACL,那么附加在该交换机端口的虚拟网络适配器就不在 HNV 虚拟子网之内。 从虚拟网络适配器发出的数据包如果没有 VSID ACL,就会通过 Hyper-V 交换机而不会发生更改。

虚拟机发送数据包时,Hyper-V 交换机端口的 VSID 与这个数据包相关联。 在接收端,HNV 将 OOB 中的 VSID 以及解封的数据包发送到 Hyper-V 交换机。 在接收端,HNV 执行策略寻找,并在数据包送达 Hyper-V 交换机之前,将 VSID 添加到 OOB 数据中。

System_CAPS_note注意

Hyper-V 交换机扩展可以在提供程序地址 (PA) 空间和客户地址 (CA) 空间中工作。 这意味着,VSID 适用于交换机扩展。 这可使交换机扩展能感知多租户。例如,防火墙交换机扩展可将带有 VSID 为 5001的 OOB 的 CA IP 地址 10.1.1.5 和 VSID 为 6001 的相同 CA IP 地址区分开来。

与在物理网络中一样,路由是 HNV 的重要组成部分。 需要了解两个重要的方面:如何在虚拟子网之间路由数据包,以及如何在虚拟网络外部路由数据包。

在物理网络中,子网是第 2 层 (L2) 域,其中的计算机(虚拟计算机和物理计算机)无需路由就能直接相互通信。 在 Windows 中,如果以静态方式配置了网络适配器,则你可以设置一个充当 IP 地址的“默认网关”,用于发送特定子网传出的所有流量,以便能够适当地路由这些流量。 通常,此网关就是物理网络的路由器。 HNV 使用属于每台主机的内置路由器来构造虚拟网络的分布式路由器。 这意味着,每台主机(具体而言,为 Hyper-V 虚拟交换机)将充当默认网关,用于路由属于同一 VM 网络的虚拟子网之间传递的所有流量。 在 Windows Server 2012 和 Windows Server 2012 R2 中,用作默认网关的地址是子网的最低入口(例如,对于 /24 子网前缀,它是“.1”地址)。 此地址将在默认网关的每个虚拟子网中保留,并且不能由虚拟子网中的虚拟机使用。

借助充当分布式路由器的 HNV,你可以通过极其有效的方式适当地路由 VM 网络中的所有流量,因为每台主机无需中介,就能将流量直接路由到相应的主机。当 VM 网络相同但虚拟子网不同的两台虚拟机位于同一台物理主机上时,尤其能够看到这种优势。 本节稍后你将会看到,数据包永远不用离开物理主机。

大多数客户部署将需要 HNV 环境与不属于 HNV 环境的资源进行通信。 这就需要网络虚拟化网关来实现两种环境之间的通信。 需要 HNV 网关的方案包括私有云以及混合云。 一般而言,VPN 和路由都需要 HNV 网关。

网关可以有不同的实体构成元素。 网关可基于 Windows Server 2012 R2 而构建,可整合至顶架 (TOR) 交换机、负载平衡器中,或放入其他现有的网络设备中,或构成一个新的独立网络设备。

System_CAPS_note注意

有关网关的详细信息,请参阅 Hyper-V 网络虚拟化网关体系结构指南网关简单演示脚本

大型公司可能不愿意,或者出于合规原因不能将其一些服务和数据转移给一个公有云托管商。 但是,公司仍然想要通过将数据中心资源整合到一个私有云中,来享受由 HNV 提供的云所带来的好处。 在私有云部署中,可能不需要重叠的 IP 地址,因为公司一般有足够的不可路由的内部地址(如 10.x.x.x 或 192.x.x.x)空间。 思考图 3 中的示例。

私有云部署

 

图 3:私有云部署

注意,在此示例中,虚拟子网的客户地址为 157.x 地址,而网络中非网络虚拟部分 (Corp Net) 的 IP 地址也为 157.x 地址。 在此示例中,数据中心的虚拟子网的 PA 地址为 10.x IP 地址。 这一部署能让公司利用 HNV 的一项功能,使数据中心结构中的虚拟机位置和跨子网动态迁移有一定的灵活性。 这就提高了数据中心的效率,从而减少了操作支出 (OpEx) 和资本支出 (CapEx)。 在这种情况下,HNV 网关提供 10.x 和 157.1 IP 地址之间的路由。

HNV 的主要优点是,能将本地数据中心无缝地延伸到基于 Windows Server 2012 的云数据中心。 这就是混合云模式,如图 4 所示。

混合云部署

图 4:混合云部署

在这种情况下,内部子网(如含有 web 服务器的子网),将从公司网络转移到云托管商的数据中心。 由于托管商承诺“带上自己的 IP 地址”,公司无需改变 Web 服务器虚拟机或者任何其他引用该 Web 服务器的网络端点的网络配置。 托管商通过 HNV 网关设备提供一个安全的链接。 公司管理员只需配置带有合适 IP 地址的本地 VPN。 Web 服务器虚拟机不会察觉其已经被移至云中。 它仍然保持域与活动目录 (AD) 相结合的状态,并且使用公司的 DNS 服务器。 Web 服务器虚拟机还继续与公司其他的服务器(如 SQL Server)进行交互。

HNV 网关可支持多个站对站 (S2S) VPN 隧道,如图 5 所示。 注意,VMM 虽没有显示在图中,但却是 HNV 部署所必需的。

Hyper-V 网络虚拟化网关

图 5:HNV 网关

在 HNV 中的每个虚拟网络适配器都与两个 IP 地址相关:

  • 客户地址 (CA)   由客户基于其内部网络基础结构所指定的 IP 地址。 通过这一地址,客户可与虚拟机交流网络流量,如同未移到一个公有或私有云中一般。 CA 对虚拟机是可见的,并且可由客户访问。

  • 提供程序地址 (PA)   由托管商或数据中心管理员基于其物理网络基础结构所指定的 IP 地址。 PA 出现在网络上的数据包中,这些数据包可与托管虚拟机的、运行 Hyper-V 的服务器进行交换。 PA 在物理网络上是可见的,但在虚拟机上不可见。

CA 维护着客户的网络拓扑,该网络拓扑经过虚拟化,可采用 PA 的实施方式,从实际的基础物理网络拓扑中脱离出来。 下图展示了因网络虚拟化而在虚拟机 CA 与网络基础设施 PA 之间所建立的概念关系。

图 2

图 6:物理基础结构的网络虚拟化概念图

在该图中,客户虚拟机在 CA 空间中发送数据包,并通过自身的虚拟网络或“隧道”遍布物理网络基础结构。 在以上示例中,通道被想象成带有绿色发货标签(PA 地址)的 Contoso 和 Fabrikam 数据包的“封套”,从左边的源主机发送到右边的目标主机。 关键在于主机如何确定与 Contoso 和 Fabrikam CA 相对应的“发货地址”(PA 地址)、“封套”如何套在数据包上、目标主机如何打开数据包并将数据包正确发送到 Contoso 和 Fabrikam 目标虚拟机上。

这一简单的类比突显出网络虚拟化的重要方面:

  • 将每台虚拟机的 CA 映射到物理主机的 PA。 同一个 PA 可能有多个关联的 CA。

  • 根据映射,将虚拟机在 CA 空间中发送的数据包放置在一个含有 PA 源和目标对的“封套”中。

  • CA-PA 映射必须允许主机为不同的客户虚拟机区分数据包。

因此,网络虚拟化机制旨在将虚拟机使用的网络地址虚拟化。 下一部分将描述地址虚拟化的实际机制。

HNV 支持基本路由封装实现网络虚拟化 (NVGRE) 作为一种机制来虚拟化 IP 地址:

基本路由封装 此网络虚拟化机制将基本路由封装 (NVGRE) 用作通道报头的一部分。 在 NVGRE 中,虚拟机的数据包被封装在另一个数据包中。 如图 7 所示,新的数据包报头含有合适的源和目标 PA IP 地址,另外还有存储在 GRE 报头密钥字段中的虚拟子网 ID。

图 3:IP 地址重写

图 7:网络虚拟化 - NVGRE 封装

虚拟子网 ID 可让主机为任何指定的数据包确定客户虚拟机,尽管数据包上的 PA 和 CA 可能出现重叠。 这可让同一台主机上的所有虚拟机分享一个 PA(如图 7 所示)。

共享 PA 对网络可扩展性产生很大的影响。 网络基础设施必须知悉的 IP 和 MAC 地址数量得以大幅减少。 例如,如果每台终端主机平均有 30 台虚拟机,网络基础设施需要知悉的 IP 和 MAC 地址数量将减少到三十分之一,数据包中嵌入式虚拟子网 ID 还能轻易地将数据包与实际客户联系起来。

使用 Windows Server 2012 和更高版本,HNV 完全支持即开即用的 NVGRE;不需要升级或购买新的网络硬件,如 NIC(网络适配器)、交换机或路由器。 这是因为,在线 NVGRE 包是 PA 空间中的常规 IP 包,可与当前的网络基础结构相兼容。

Windows Server 2012 优先考虑兼容标准。 在与主要的产业合作伙伴(Arista、BroadcomArista、Dell、Emulex、Hewlett Packard 和 Intel)的共同努力下,Microsoft 发行了一份介绍基本路由封装 (GRE) 使用情况的 RFC 草案,它是现有的 IETF 标准并且是网络虚拟化封装协议的一部分。 有关详细信息,请参阅以下 Internet 草案:使用通用路由封装的网络虚拟化 随着人们意识到 NVGRE 能运用到商业中,NVGRE 将带来更多益处。

下图展示了一个两名客户在云数据中心交互的部署案例,其中 CA-PA 关系由 HNV 策略所定义。

图 5

图8:多租户部署案例

思考图 8 中的示例。 在转到托管提供商的共享 IaaS 服务之前:

  • Contoso 公司运行的是一台 SQL Server(名为 SQL),IP 地址为 10.1.1.11,以及一台 Web 服务器(名为 Web)IP 地址为 10.1.1.12,并用其 SQL Server 处理数据库事务。

  • Fabrikam 公司运行的是一台 SQL Server(也名为 SQL),IP 地址为 10.1.1.11,以及一台 Web 服务器(也名为 Web),IP 地址为 10.1.1.12,并用其 SQL Server 处理数据库事务。

Contoso 公司和 Fabrikam 公司将其各自的 SQL Server 和 Web 服务器移至同一托管提供商的共享 IaaS 服务,而巧合的是,这些服务器在 Hyper-V 主机 1 中运行 SQL 虚拟机,在 Hyper-V 主机 2 中运行 Web (IIS7) 虚拟机。 所有虚拟机都保持其原有的内部网 IP 地址(其 CA)。

配置虚拟机时,托管提供商为两家公司都指定了以下虚拟子网 ID (VSID) 以及 PA:

  • Contoso 公司虚拟机的 PA:VSID 为 5001,SQL 为 192.168.1.10,WEB 为 192.168.2.20

  • Fabrikam 公司虚拟机的 PA:VSID 为 6001,SQL 为 192.168.1.10,WEB 为 192.168.2.20

托管提供商创建策略设置,这些设置包括 Fabrikam 公司的客户虚拟子网(将 Fabrikam 公司虚拟机的 CA 映射到其分配的 PA 和 VSID)和 Contoso 公司的独立客户虚拟子网(将 Contoso 公司虚拟机的 CA 映射到其分配的 PA 和 VSID)。 提供商将这些策略设置应用于 Hyper-V 主机 1 和 Hyper-V 主机 2。

当 Hyper-V 主机 2 上的 Contoso 公司 Web 虚拟机查询位于 10.1.1.11 的 SQL Server 时,会发生以下情况:

Hyper-V 主机 2,基于其策略设置,转化以下位置数据包中的地址:

  • 源:10.1.1.12(Contoso 公司 Web 的 CA)

  • 目标:10.1.1.11(Contoso 公司 SQL 的 CA)

封装的数据包含有:

  • GRE 报头中的 VSID 为:5001

  • 外部源:192.168.2.20(Contoso 公司 Web 的 PA)

  • 外部目标:192.168.1.10(Contoso 公司 SQL 的 PA)

当在 Hyper-V 主机 1 上接收数据包时,基于其策略设置,它会解封以下 NVGRE 数据包:

  • 外部源:192.168.2.20(Contoso 公司 Web 的 PA)

  • 外部目标:192.168.1.10(Contoso 公司 SQL 的 PA)

  • GRE 报头中的 VSID 为:5001

解封的数据包(原始数据包来自于 Contoso 公司 Web 虚拟机)被传送到 Contoso 公司 SQL 虚拟机:

  • 源:10.1.1.12(Contoso 公司 Web 的 CA)

  • 目标:10.1.1.11(Contoso 公司 SQL 的 CA)

当 Hyper-V 主机 1 上的 Contoso 公司 SQL 虚拟机响应查询时,会发生以下情况:

Hyper-V 主机 1,基于其策略设置,转化以下位置数据包中的地址:

  • 源:10.1.1.11(Contoso 公司 SQL 的 CA)

  • 目标:10.1.1.12(Contoso 公司 Web 的 CA)

数据包封装地址:

  • GRE 报头中的 VSID 为:5001

  • 外部源:192.168.1.10(Contoso 公司 SQL 的 PA)

  • 外部目标:192.168.2.20(Contoso 公司 Web 的 PA)

当在 Hyper-V 主机 2 处收到数据包时,它将基于策略设置,解封以下数据包:

  • 源:192.168.1.10(Contoso 公司 SQL 的 PA)

  • 目标:192.168.2.20(Contoso 公司 Web 的 PA)

  • GRE 报头中的 VSID 为:5001

将解封的数据包发送到以下 Contoso 公司 Web 虚拟机:

  • 源:10.1.1.11(Contoso 公司 SQL 的 CA)

  • 目标:10.1.1.12(Contoso 公司 Web 的 CA)

Fabrikam 公司 Web 与 SQL 虚拟机之间用于通信的类似进程针对 Fabrikam 公司使用 HNV 策略设置。因此,在使用 HNV 时,Fabrikam 公司和 Contoso 公司虚拟机的交互就像在其原有的 Intranet 中进行一样。 尽管两家公司虚拟机使用的是相同的 IP 地址,也不会互相影响。

不同地址(CA 和 PA)、Hyper-V 主机的策略设置以及用于入站和出站虚拟机通讯的 CA 与 PA 之间的地址转换,将两组服务器互相隔离。 同时,虚拟化映射以及转化将虚拟网络构架从物理网络基础结构中脱离出来。 尽管 Contoso SQL 和 Web 以及 Fabrikam SQL 和Web 位于其自己的 CA IP 子网 (10.1.1/24),两者的物理部署在两台有着不同的 PA 子网(分别为 192.168.1/24 和 192.168.2/24)的主机上进行。 这意味着通过 HNV,可以进行跨子网虚拟机配置和实时迁移。

System_CAPS_note注意

有关数据包流的详细信息,请下载 Hyper-V 网络虚拟化数据包流,PowerPoint 演示地址:http://www.microsoft.com/en-us/download/details.aspx?id=34782。

在 Windows Server 2012 中,HNV 策略实施以及 IP 虚拟化都由名为 Windows 网络虚拟化 (WNV) 的网络驱动程序接口规格 (NDIS) 轻型筛选器 (LWF) 执行。如图 9 所示,WNV 筛选器位于 Hyper-V 交换机下面。 这种体系结构的负面影响之一是,交换机扩展可能只能看到 CA 地址空间流量,而看不到 PA 空间的流量。

在 Windows Server 2012 R2 中,HNV 现已成为虚拟交换机的一部分,它使扩展能够同时洞察 CA 和 PA 空间地址。

 

图 7:数据中心 orchestrator (VMM)

图 9:HNV 体系结构

 

每台虚拟机网络适配器都配有一个 IPv4 和/或一个 IPv6 地址。 这些是虚拟机用来相互交流的 CA,并置于虚拟机的 IP 包中。 基于网络虚拟化策略,HNV 将 CA 虚拟化成 PA。

虚拟机发出一个源地址为 CA1 的数据包,该数据包已根据 Hyper-V 交换机中的 HNV 策略虚拟化。 基于 VSID 的特殊网络虚拟化访问控制列表能将虚拟机从其他不属于同一虚拟子网或同一路由域的虚拟机独立出来。

Windows 平台可为数据中心管理软件提供公共 API 来管理 HNV。Virtual Machine Manager 就是这样一种数据中心管理产品。 该管理软件包含所有 HNV 策略。 由于 Virtual Machine Manager 必须能感知虚拟机,最重要的是,它能在数据中心配置虚拟机以及整个客户虚拟网络,并且必须能感知多租户,因此,管理 HNV 策略是基于策略网络的自然延伸。

摘要
 
 

基于云的数据中心能带来许多好处,如改善可扩展性和资源使用情况。 为了实现这些潜在的好处,需要能基本解决动态环境中多租户可扩展性问题的技术。 HNV 旨在通过分离物理网络拓扑的虚拟网络拓拟来解决这些问题,并提高数据中心的运营效率。 HNV 构建在现有标准的基础之上,能在当前的数据中心运行,同时,随着 NVGRE 感知硬件的推出,其优势将会日益提高。 借助 HNV,客户现在可将其数据中心整合到私有云中,或者将其数据中心无缝延伸到拥有混合云的托管商环境中。

另请参阅
 
 

转载于:https://www.cnblogs.com/liangwang/p/5175288.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值