深入看ECMP(详解其实现机制)

本文转载自https://www.sdnlab.com/20605.html

个人总结:我低估了ECMP,虽然这玩意不算难,但是我依然对它有一些错误理解,为此,把它的实现机制转过来,深入地看一看到底什么是ECMP。

特别是基于数据流的转发,对某一个结点运用ECMP时的前提是,这些数据流的目标地址相同,源地址不同。比如来自源地址A的数据流和来自源地址B的数据流都要经过R到达目标地址D,而R到D有两条路径,那么R可能会把来自A的数据流转发到路径1上,把来自B的数据流转发到路径2上。

感觉ECMP是用在MPLS网络上。

ECMP(Equal-cost multi-path)

ECMP是一个逐跳的基于流的负载均衡策略,当路由器发现同一目的地址出现多个最优路径时,会更新路由表,为此目的地址添加多条规则,对应于多个下一跳。可同时利用这些路径转发数据,增加带宽。ECMP算法被多种路由协议支持,例如:OSPF、ISIS、EIGRP、BGP等。在数据中心架构VL2中也提到使用ECMP作为负载均衡算法。

对于未开启ECMP的网络来说,无法充分利用路径资源。如图1所示,假设从S0到Server的为S0-S1-S2-S4即图中橘色路径,那么即便存在另一条等价路径,蓝色路径,路由器仍然会每次选择第一条橘色路径转发数据。除非此条路径发生拥塞,才会重新选择路径。

当开启ECMP功能时,便可同时利用两条路径,进行基于流的负载均衡,例如主机A到Server的数据流选择橘色路径,主机B到Server的数据流选择蓝色路径。

ECMP的路径选择策略有多种方法:

  • 哈希,例如根据源IP地址的哈希为流选择路径。
  • 轮询,各个流在多条路径之间轮询传输。
  • 基于路径权重,根据路径的权重分配流,权重大的路径分配的流数量更多。

                                         图1.使用ECMP进行负载均衡

ECMP面临的问题

然而ECMP是一种较为简单的负载均衡策略,其在实际使用中面临的问题也不容忽视。

1.可能增加链路的拥塞
ECMP并没有拥塞感知的机制,只是将流分散到不同的路径上转发。对于已经产生拥塞的路径来说,很可能加剧路径的拥塞。而使用哈希的方法,产生哈希碰撞也会增加链路的拥塞可能。

2.非对称网络使用效果不好
例如图2中,A与h3之间的通信,ECMP只是均匀的将流通过B,D两条路径分别转发,但实际上,在B处可以承担更多的流量。因为B后面还有两条路径可以到达h3。

                                             图2. 非对称网络

3.基于流的负载均衡效果不好
ECMP对于流大小相差不多的情况效果更好,而对于流大小差异较大,例如大象流和老鼠流并存的情况下,效果不好。如图2,主机h1到A的流量为15,h2到A的流量为5。那么无论为h1的流量选择哪条路径都会发生拥塞。但若将h1的流拆分成两部分传输,可以避免拥塞的情况。

以上,为使用ECMP算法进行负载均衡的分析,在数据中心这种突发性流量多,大象流与老鼠流并存的环境中,需要慎重考虑选择的负载均衡策略,ECMP简单易部署但也存在较多问题需要注意。

  • 26
    点赞
  • 112
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: ECMP (Equal Cost Multi-Path) 是一种路由算法,它可以在有多条等价路径的情况下均衡数据流量。Round-robin 是一种负载均衡策略,它会依次将流量发送到不同的路径上。在 Linux 中,可以通过设置路由表来实现 ECMP + round-robin 模式。 ### 回答2: ECMP(等价多路径路由)是一种路由选择算法,在Linux中,ECMP支持多条等价的路径通过不同的出口进行负载均衡和流量分配。而ECMP Round-Robin模式是ECMP的一种具体实现,其工作原理是按照循环轮询的方式将流量依次分发到不同的路径上。 ECMP Round-Robin模式的步骤如下: 1. 首先,根据数据包头部的目的IP地址进行筛选,将符合条件的数据包匹配到多条等价路径中。 2. 在选中的等价路径中,通过循环轮询的方式,将数据包依次转发到每条路径上。每条路径都承担着一定的负载量,以实现流量的均衡分布。 3. 当数据包到达目的地时,ECMP Round-Robin模式会将对应路径的计数器加一,以记录该路径的流量量。 4. 下一次有数据包来临时,ECMP Round-Robin会根据路径的计数器值来选择下一条转发路径,从而保证每条路径都能得到相同的流量。 ECMP Round-Robin模式的优点是能够有效地利用多条等价路径,实现流量的负载均衡。此外,ECMP Round-Robin模式的实现较为简单,在多个路径之间切换时,不需要复杂的计算和决策过程。 需要注意的是,ECMP Round-Robin模式并不能保证路径之间的负载量完全相同,因为在实际网络中,不同的路径可能会遇到不同的拥塞程度或延迟情况。另外,ECMP Round-Robin模式只适用于无连接的IP数据包转发,而对于有连接的协议(如TCP),可能需要其他机制来保证连接的连续性。 综上所述,ECMP Round-Robin模式是一种简单有效的负载均衡算法,适用于Linux系统中多条等价路径的流量分配和均衡。 ### 回答3: ECMP(Equal Cost Multipath)是一种路由选择算法,用于在网络中选择多个等价路径中的一个进行数据传输。在Linux中,ECMP支持轮询(round-robin)模式,将传入的数据流量均匀地分配到具有相同的最佳路由的多个路径上。 ECMP的轮询模式通过在每个数据包上设置不同的路由标识符来实现。当数据包到达Linux系统时,内核根据路由表中的目标地址和路由标识符来确定正确的路径。在轮询模式下,内核会按照预先定义的顺序将不同的标识符分配给不同的路径。这样,每个路径都会负责处理一部分数据包,实现了负载均衡的效果。 ECMP的轮询模式具有以下优点: 1. 增加带宽利用率:通过将流量分散到多个路径上,可以更好地利用可用带宽,提高网络的整体吞吐量。 2. 提高可靠性:因为数据流量被分散到多条路径上,即使某条路径出现故障,其他路径仍可继续传输数据,从而提高了网络的可用性。 3. 平衡负载:轮询模式可以使数据包均匀地分布在不同的路径上,避免单个路径负载过重,从而提高系统的性能。 ECMP轮询模式的实现可以采用多种方法,如源地址、目标地址、源端口、目标端口等来确定路由标识符。根据具体的应用需求,可以选择不同的标识符分配方法来实现定制化的负载均衡策略。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值