https://songxwn.com/VMware-vSwitch-uplink/
RSS: https://songxwn.com/atom.xml
我在使用 VMware ESXi 的时候发现 vSwitch 两个以上的上联端口,连接同一个交换机,或者同一个二层广播域。
且没有配置 LACP 或 STP 等协议,但并没有造成二层环路。这是因为 vSwitch 特殊的上联接口的水平分割。(和 iBGP 的水平分割很像)
即从一个上联端口发过来的报文,不会转发到其他上联端口。( vSwitch 的上联端口是强定义的)
(包括虚拟标准交换机 VSS 和 虚拟分布式交换机 VDS )
如上图所示,vSwitch0 有四个上联接口连接到物理交换机,且没有 LACP 或 STP 。
流量会根据每台虚拟机进行负载分担到每个上联接口,当感知到物理故障的时候,则会自动切换。
也就是说无需任何物理交换机的网络协议参与,即可实现防环、端口流量负载分担、故障感知。
在传统的以太网交换机中,所有端口都使用相同的转发规则。虚拟交换机对虚拟下联接口和上联接口使用不同的转发规则。
(强定义的上联接口,下联接口连接虚拟机的虚拟网卡)
虚拟机监控程序知道 ESXi 服务器中运行的所有虚拟机的 MAC 地址;无需执行 MAC 地址学习。
虚拟交换机未运行生成树协议 ( STP ),并且不发送 STP 网桥协议数据单元 ( BPDU )。虚拟交换机接收的 STP BPDU 将被忽略。上行链路永远不会根据 STP 信息被阻塞。
PS:连接 ESXI 服务器的交换机接口,应该配置 BPDU 保护 ,以防止由于接线错误而导致转发环路。由于 ESXi 不运行 STP ,因此还应该在这些端口上配置 STP 边缘接口。
通过其中一个上联接收的数据包永远不会转发到其他上联接口。此规则可防止通过虚拟交换机导致二层转发环路。
由虚拟机发起的广播或多播数据包将发送到同一_端口组_中的所有其他虚拟机( VLAN 的 VMware 术语)。它们也像常规单播数据包一样通过其中一个上行链路发送(它们不会通过所有上行链路泛洪)。这可确保外部网络接收广播的单个副本。
通过上行链路端口接收的广播/组播将发送到端口组中的所有虚拟机(由 VLAN 标记标识),但不会发送到其他上行链路(请参阅-水平分割转发)。
从虚拟机发送到未知 MAC 地址的单播数据包通过其中一个上行链路(根据负载平衡模式选择)发送。它们没有被淹没。
通过上行链路端口接收并寻址到未知 MAC 地址的单播数据包将被丢弃。
虚拟交换机向外部网络发送广播/组播/未知单播数据包的单个副本(请参阅上面的无泛洪规则),但物理交换机始终执行完全_泛洪_,并通过所有其他上行链路将数据包的副本发送回虚拟交换机。因此,VMware 必须检查通过上行链路接收的数据包的源 MAC 地址。通过其中一个上行链路接收且源 MAC 地址属于其中一个虚拟机的数据包将被静默丢弃。
https://blog.ipspace.net/2010/11/vmware-virtual-switch-no-need-for-stp.html