简介:
1) 3种类型的VMware网络都支持NIC Teaming ,详细请参考《VMWare ESX Server中的网络设置》(VMkernel, Service Console和VM port group)
2) uplink链接到那些物理交换机的端口都必须在同一个广播域中。(也就是必须在同一个VLAN中,不能跨路由)
3) 若是uplink要配置VLAN,则每一个uplink必须都配置成VLAN Trunk而且具备相同的VLAN配置。
4) VMware的负载均衡(Load Balancing)只是出站(Outbound)的负载均衡,所以要作到Inbound的负载均衡,必须在物理交换机上作一样IP Hash方式的配置。
5)NIC Teaming的Load Balancing和一些高级路由算法的Load Balancing不一样,它不是按照Teaming中网卡上经过的数据流量来负载均衡,而是根据网卡上的链接(connection)来进行负载均衡。
VMware的3种负载均衡
VMware的NIC Teaming Load Balancing策略有3种。
(1) 基于端口的负载均衡(默认)
(2) 基于源MAC的负载均衡
(3) 基于IP hash的负载均衡 php
1. 基于端口的负载均衡 (Route based on theoriginating virtual port ID)
这种方式下,负载均衡是基于vPort ID的。一个vPort和Host上的一个pNIC(从vSwitch角度看就是某个uplink)捆绑在一块儿,只有当这个pNIC失效的时候,才切到另外的pNIC链路上。这种方式的负载均衡只有在vPort数量大于pNIC的数量时才生效。
什么是vport?一个VM上的vNIC或者某一个VMKernel或者Service Console的某个vswif。用一个图来直观的表述,vPort在下图中显示为vSwitch上左侧的那些绿点。而pNIC在图中显示为右边的vmnicX。html
对于VM来讲,由于某台VM的vNIC是捆绑在某一个pNIC上的,也就是说这台VM(若是只有一个vNIC的话)对外的数据流量将固定在某一个pNIC上。这种负载均衡是在VM之间的均衡,对于某一台VM而言,其uplink的速率不可能大于单个pNIC的速率。此外,只有当VM的数量足够多,而且这些VM之间的数据流量基本一致的状况下,Host上的NIC Teaming的Load Balancing才较为有效。对于如下这些极端状况,基于端口方式的负载均衡根本不起做用或者效果不好,充其量只能说是一种端口冗余。
(1)Host上只有一台只具备单vNIC的VM (此时彻底没有Load balancing)
(2)Host上的VM数量比pNIC少(好比有4台VM可是Teaming中有5块pNIC,此时有一块pNIC彻底没用上,其余每一个vNIC各自使用一块pNIC,此时也没有任何负载均衡实现)
(3)Host上虽然有多台VM,可是99%的网络流量都是某一台VM产生的
这里还能够参考VMware ESXi5负载均衡分析:
最近对ESXi5负载均衡策略中的默认“基于源虚拟端口ID的路由”作了一些分析,很是有意思分享给你们。
先描述一下场景:
一台ESXi5服务器有6台VM(姑且用VM1、VM2、VM3、VM4、VM5、VM6来称呼),两块物理网卡作负载均衡(依次显示vmnic0和vmnic1)—默认的作法,两网卡分别依次对应到对端Cisco 2950上的fa0/1和fa0/2口上,经过分析cisco2950上MAC表来分析vmnic0或vmnic1承载VM的数量。
1:依次启动VM虚拟机,VM1走vmnic0,VM2走vmnic1,VM3走vmnic1,VM4走vmnic0,VM5走vmnic0,VM6走vmnic1。
VM1、VM4、VM5走的是vmnic0网口
VM2、VM3、VM6走的是vmnic1网口
2:shutdown vmnic1对应的网口后,VM2、VM3、VM6自动转移到vmnic0上承载。后从新开启vmnic1后,VM2、VM3、VM6自动又转移回vmnic1上
3:人为关闭VM2、VM3、VM6虚拟机,VM1、VM4、VM5并无自动转移到vmnic1上,哪怕是一个VM,关闭VM1后又重启,发现VM1走到了vmnic1上了。
总结:
1:在默认的“基于源虚拟端口ID的路由”策略下,每个VM的数据流(上下行)实际上跑的是一个网口(vmnic1或vmnic0),也就是说任何一个VM虚拟机的数据流并无被这两个网口分担。
2:初始开启的VM虚拟机使用哪个网口来负载的判断原则是网口上承载VM的数量,而不是网口自身资源的负载压力,这样的判断原则有可能会出现有的网口压力很是大,而有的网口很是闲置。
3:系统正常运行中(上述1),添加网口vmnic2,则虚拟机会从新分配负载平衡,数量是2—2—2模式(三网卡模式下)。
4:添加和删除网口,对极个别VM会形成一个包的丢失。
5:建议你们根据VM的要承载数据量的大小,使用vmnetwork端口组中负载均衡设置,人为的指定承载网口和待定网口,最优化使用网口资源。
其实这个基于端口和mac地址准确的说应该不是叫负载均衡,理解为冗余更好点,这个均衡应该理解为按端口或者mac平均哼配,测试过就算一张卡的吞吐率到达50%,也不会切换的,因此准确地说这前两个应该理解为链接数平均,最后个IP Hash才是真的负载均衡,这个时候交换机设置为两层的EthernetChannel,配置负载模式为Src xor des ip。
2. 基于源MAC地址的负载均衡 Route based on source MAC hash
这种方式下,负载均衡的实现是基于源MAC地址的。由于每一个vNIC老是具备一个固定的MAC地址,所以这种方式的负载均衡同基于端口的负载均衡具备一样的缺点。一样是要求vPort数量大于pNIC的时候才会有效。一样是vNIC的速率不会大于单个pNIC的速率。
3. 基于IP Hash的负载均衡 Route based on IP hash
这种方式下,负载均衡的实现是根据源IP地址和目的IP地址的。所以同一台VM(源IP地址老是固定的)到不一样目的的数据流,就会由于目的IP的不一样,走不一样的pNIC。只有这种方式下,VM对外的流量的负载均衡才能真正实现。
不要忘记,VMware是不关心对端物理交换机的配置的,VMware的负载均衡只负责从Host出站的流量(outbound),所以要作到Inbound的负载均衡,必须在物理交换机上作一样IP Hash方式的配置。此时,pNIC必须链接到同一个物理交换机上。
须要注意的是,VMware不支持动态链路聚合协议(例如802.3ad LACP或者Cisco的PAgP),所以只能实现静态的链路聚合。(相似于HP的SLB)。不只如此,对端的交换机设置静态链路聚合的时候也要设置成IP Hash的算法。不然这种方式的负载均衡将没法实现。
这种方式的缺点是,由于pNIC是链接到同一台物理交换机的,所以存在交换机的单点失败问题。此外,在点对点的链路中(好比VMotion),2端地址老是固定的,因此基于IP Hash的链路选择算法就失去了意义。
4. 总结
无论采用以上哪种方法的Load Balancing,它会增长总聚合带宽,但不会提高某单个链接所获的带宽。为啥会这样?同一个Session中的数据包为啥不能作到Load Balancing?这是由于网络的7层模型中,一个Session在传输过程当中会被拆分红多个数据包,而且到目的以后再重组,他们必须具备必定的顺序,若是这个顺序弄乱了,那么到达目的重组出来的信息就是一堆无心义的乱码。这就要求同一个session的数据包必须在同一个物理链路中按照顺序传输过去。因此,10条1Gb链路组成的10Gb的聚合链路,必定不如单条10Gb链路来的高速和有效。
【选择】
那么应该选择哪一种NIC Teaming方式呢?大拿Scott Lowe建议:
若是使用链路聚合,必须设为“Route based on IP hash”
若是不是使用链路聚合,能够设为任何其它设置。大多数状况下,接受默认设置“Route based onoriginating virtual port ID”是最好的。ios
------------------------------------------------------------------------------------------------------------------------------------------------sass
In the ESX case, the vSwitch fully supports VLAN tagging. How doesthis help you? Instead of having to provide a separate network card for everyVLAN you’re connecting into your ESX server, you can trunk them all onto thesame physical NIC. Doing so can signi? cantly reduce TCO for yourinfrastructure from day one and in the long run. Providing redundancy for thevSwitch is also extremely simple. There are four options:安全
Route based on the originating virtual port ID服务器
Route based on an IP hash网络
Route based on the source MAC hashsession
Explicit failover order负载均衡
The most commonly used option is the ? rst (it’s the default for allvSwitches). A number of VMs are connected to a vSwitch that uses two or morephysical NICs (pNICs). You use all of these pNICs in an active-activecon? guration. If you lose a pNIC, traf? c automatically travelsover one of the other pNICs in the vSwitch. Each time a VM is powered on, it’sassigned to a pNIC and continues to operate from that NIC until it’spower-cycled or until the pNIC fails and network traf? c is passed to theother pNICs in the vSwitch. This setup doesn’t provide ef? cient loadbalancing over all the pNICs in the vSwitch and can become unbalanced incertain cases; but in the majority of scenarios, it’s suitable because it’s thedefault con? guration of an ESX host.
1. ESX网络基础
ESX server总共有三种形式的网络:
– Service console port: ESX Server 的管理网络,如:vSphere Client和vCenter就是使用此网络管理ESX。
– VMkernel port: ESX Server内核接口,用来 VMotion, iSCSI 和 NFS/NASnetworks
– Virtual machine port group: 虚拟机网络链接。
ESX 界面:
2. ESX的vSwitch
VMWare的官方解释是这样的:
A virtualswitch, vSwitch, works much like a physical Ethernetswitch. It detects which virtual machines are logically connected to each ofits virtual ports and uses that information to forward traffic to the correctvirtual machines. A vSwitch can be connected to physical switches usingphysical Ethernet adapters, also referred to as uplink adapters, to joinvirtual networks with physical networks. This type of connection is similar toconnecting physical switches together to create a larger network. Even though avSwitch works much like a physical switch, it does not have some of theadvanced functionality of a physical switch. For more information on vSwitches,see Virtual Switches.
其实vSwitch就是上图左边端口的组合,默认端口数为56(最大能够到1016),咱们能够为一个ESX server建立最多248个vSwitch。在VM不断增多的状况下,出于冗余和流量或安全考虑,能够增长多个vSwitch,并设置相应规则。
3. 增长vSwitch
1)列出系统的网卡
[root@VM1 ~]# esxcfg-nics-l
Name PCI Driver LinkSpeed Duplex MACAddress MTU Description
vmnic0 01:00.00bnx2 Up 1000Mbps Full a4:ba:db:45:c8:b2 1500 Broadcom CorporationBroadcom NetXtreme II BCM5709 1000Base-T
vmnic1 01:00.01bnx2 Up 1000Mbps Full a4:ba:db:45:c8:b4 1500 Broadcom CorporationBroadcom NetXtreme II BCM5709 1000Base-T
vmnic2 02:00.00bnx2 Down0Mbps Half a4:ba:db:45:c8:b61500 Broadcom Corporation Broadcom NetXtreme II BCM5709 1000Base-T
vmnic3 02:00.01bnx2 Down0Mbps Half a4:ba:db:45:c8:b81500 Broadcom Corporation Broadcom NetXtreme II BCM5709 1000Base-T
2)列出你当前的虚拟交换机
[root@VM1 ~]#esxcfg-vswitch -l
SwitchName Num Ports Used Ports ConfiguredPorts MTU Uplinks
vSwitch0 32 10 32 1500 vmnic0,vmnic1
PortGroupName VLAN ID Used Ports Uplinks
VMNetwork 0 5 vmnic0,vmnic1
ServiceConsole 0 1 vmnic0,vmnic1
VMkernel 0 1 vmnic0,vmnic1
3)添加一个虚拟交换机,名字叫(vswitch_test)链接到两块不用的物理网卡(目前没有插网卡)
[root@VM1 ~]#esxcfg-vswitch -a vswitch_test
[root@VM1 ~]#esxcfg-vswitch -A VM_test vswitch_test
[root@VM1 ~]#esxcfg-vswitch -L vmnic2 vswitch_test
[root@VM1 ~]#esxcfg-vswitch -L vmnic3 vswitch_test
而后就能够在GUI里修改相应配置(修改Port Group或其余)。
4. vSwitch流量分隔及冗余切换
VMware建议ESX中的三种网络类型最好配置不一样的Vlan,使用不一样的上行链路以分隔流量,而且为了保证故障冗余,每一个网络类型至少关联2块网卡,我这里用vSwitch_test为例:
配置:
VMotion使用vmnic2做为活动适配器,vmnic3做为待机适配器,VLAN ID=201;
虚拟机网络VM_test使用vmnic2做为活动适配器,vmnic3做为待机适配器,VLAN ID=200;
虚拟机网络VM_test2使用vmnic3做为活动适配器,vmnic2做为待机适配器,VLAN ID=202。
5. vSwitch网络负载均衡
时间: 2011-02-14 分类: VMware
标签: ESX, VMware, vSwitch / 3,687 次浏览 2 评论
简介:
1) 3种类型的VMware网络都支持NIC Teaming ,详细请参考《VMWare ESX Server中的网络设置》(VMkernel, Service Console和VM port group)
2) uplink链接到那些物理交换机的端口都必须在同一个广播域中。(也就是必须在同一个VLAN中,不能跨路由)
3) 若是uplink要配置VLAN,则每一个uplink必须都配置成VLAN Trunk而且具备相同的VLAN配置。
4) VMware的负载均衡(LoadBalancing)只是出站(Outbound)的负载均衡,所以要作到Inbound的负载均衡,必须在物理交换机上作一样IP Hash方式的配置。
5)NIC Teaming的Load Balancing和一些高级路由算法的Load Balancing不一样,它不是按照Teaming中网卡上经过的数据流量来负载均衡,而是根据网卡上的链接(connection)来进行负载均衡。
VMware的3种负载均衡
VMware的NIC Teaming Load Balancing策略有3种。
(1) 基于端口的负载均衡(默认)
(2) 基于源MAC的负载均衡
(3) 基于IP hash的负载均衡
1. 基于端口的负载均衡 (Route based on theoriginating virtual port ID)
这种方式下,负载均衡是基于vPort ID的。一个vPort和Host上的一个pNIC(从vSwitch角度看就是某个uplink)捆绑在一块儿,只有当这个pNIC失效的时候,才切到另外的pNIC链路上。这种方式的负载均衡只有在vPort数量大于pNIC的数量时才生效。
什么是vport?一个VM上的vNIC或者某一个VMKernel或者Service Console的某个vswif。用一个图来直观的表述,vPort在下图中显示为vSwitch上左侧的那些绿点。而pNIC在图中显示为右边的vmnicX。
对于VM来讲,由于某台VM的vNIC是捆绑在某一个pNIC上的,也就是说这台VM(若是只有一个vNIC的话)对外的数据流量将固定在某一个pNIC上。这种负载均衡是在VM之间的均衡,对于某一台VM而言,其uplink的速率不可能大于单个pNIC的速率。此外,只有当VM的数量足够多,而且这些VM之间的数据流量基本一致的状况下,Host上的NIC Teaming的Load Balancing才较为有效。对于如下这些极端状况,基于端口方式的负载均衡根本不起做用或者效果不好,充其量只能说是一种端口冗余。
(1)Host上只有一台只具备单vNIC的VM (此时彻底没有Load balancing)
(2)Host上的VM数量比pNIC少(好比有4台VM可是Teaming中有5块pNIC,此时有一块pNIC彻底没用上,其余每一个vNIC各自使用一块pNIC,此时也没有任何负载均衡实现)
(3)Host上虽然有多台VM,可是99%的网络流量都是某一台VM产生的
2. 基于源MAC地址的负载均衡 Route based on source MAC hash
这种方式下,负载均衡的实现是基于源MAC地址的。由于每一个vNIC老是具备一个固定的MAC地址,所以这种方式的负载均衡同基于端口的负载均衡具备一样的缺点。一样是要求vPort数量大于pNIC的时候才会有效。一样是vNIC的速率不会大于单个pNIC的速率。
3. 基于IP Hash的负载均衡 Route based on IP hash
这种方式下,负载均衡的实现是根据源IP地址和目的IP地址的。所以同一台VM(源IP地址老是固定的)到不一样目的的数据流,就会由于目的IP的不一样,走不一样的pNIC。只有这种方式下,VM对外的流量的负载均衡才能真正实现。
不要忘记,VMware是不关心对端物理交换机的配置的,VMware的负载均衡只负责从Host出站的流量(outbound),所以要作到Inbound的负载均衡,必须在物理交换机上作一样IP Hash方式的配置。此时,pNIC必须链接到同一个物理交换机上。
须要注意的是,VMware不支持动态链路聚合协议(例如802.3ad LACP或者Cisco的PAgP),所以只能实现静态的链路聚合。(相似于HP的SLB)。不只如此,对端的交换机设置静态链路聚合的时候也要设置成IP Hash的算法。不然这种方式的负载均衡将没法实现。
这种方式的缺点是,由于pNIC是链接到同一台物理交换机的,所以存在交换机的单点失败问题。此外,在点对点的链路中(好比VMotion),2端地址老是固定的,因此基于IP Hash的链路选择算法就失去了意义。
4. 总结
无论采用以上哪种方法的Load Balancing,它会增长总聚合带宽,但不会提高某单个链接所获的带宽。为啥会这样?同一个Session中的数据包为啥不能作到Load Balancing?这是由于网络的7层模型中,一个Session在传输过程当中会被拆分红多个数据包,而且到目的以后再重组,他们必须具备必定的顺序,若是这个顺序弄乱了,那么到达目的重组出来的信息就是一堆无心义的乱码。这就要求同一个session的数据包必须在同一个物理链路中按照顺序传输过去。因此,10条1Gb链路组成的10Gb的聚合链路,必定不如单条10Gb链路来的高速和有效。
转载自:
原文连接:http://kuku789123.blog.163.com/blog/static/13616735120130171401594/