介绍
Segment Routing Traffic Engineering:利用SR实现的流量工程
什么是流量工程:不按照网络缺省的最短路径进行转发,而按照某些特定的条件进行转发,(包括时延、拥塞情况、不相交性,带宽等)都统一到SR policy中定义,由SID List在网络中实现。
SR policy = SID List(S1,S2,S3...,Z)
都是去往Z的流量,<Z>就是最短路径,<...,Z>就是流量工程。
SR MPLS中,SID List = Segment(lable)List
SRv6中,SID List = SRv6 SID List in SRH. (其实就是在数据报文头里)
SR-BE,Segment Routing Best Effort(在IGP中基于前缀的最短路径,尽力而为服务)
传统的RSVP TE
基于RSVP资源预留协议的流量工程主要是在基于常用的IGP流量协议的状态消息的扩展,比如IS-IS/OSPF进行链路信息的广播,并且对路径信息的一些计算算法的改进,链路之间邻居之间进行逐跳的维护拓扑的关系,通过Tunnel:[head-end]-->[mid-point]-->[tail-end]
RSVP-TE和SR-TE之间的区别
RSVP-TE:
1、每条链路端到端的节点都需要维护状态信息,重度状态协议
2、最短路径算法不支持等价路径开销,不支持链路的负载均衡
3、只能进行逐跳的标签栈,这样就导致路径比较长
4、存在PE之间全连接问题,随着PE增加,通道会有N的2次方问题,比较难扩展,对于核心节点,需要大量维护PE之间的通道信息
SR-TE:
1、中间的节点是无状态的,整个网络状态都包含在标签信息当中,也就是数据包的包头当中,中间节点只需要按照标签信息进行转发即可
2、面向ip协议做的一个优化,天生支持ECMP
3、可以进行指定要交换的路径,可以进行在路径中进行设置
4、SR-TE是无状态的网络协议,方便扩展。按需建立标签信息,建立在数据发送的源,直接压栈所有途径点路径信息即可,中间其他的网络设备无需进行维护路径和隧道的网络状态。
根据什么进行计算路径
首先我们知道IGP是根据metric来进行算路的,得到最少开销路径
SR-TE支持IGP最短路径之外的多种计算·条件的输入:
- 时延
- 带宽
- 不相交性:disjointness
- 资源属性:affinity/avoidance
- ...
计算方式有哪些
首先计算可以分为分布式计算和集中式计算,
- 分布式计算就是各个头端/PE根据自身收集的全网拓扑按照约束条件进行计算,将计算结果加载到自身数据路径,生成一个拓扑数据库,头端通过IGP和BGP-LS等协议建立SRTE DB
- 集中式计算就是通过SDN进行路径信息的收集,所有路由器会上报他们的物理网络、链路状态的一些信息,SDN会进行维护整个网络的拓扑数据库,并且基于流量工程的策略,计算转发路径,通过PCEP、SR Policy、netconf等方式下发给头端
相同点:收集的信息都是一致的,都是物理网络和链路状态信息,SRTE DB是同步的,
不同点:不同头端或者路由器发起的SRTE路径,如果要求不相交性,分布式计算是不支持的,此外分布式计算不支持跨域的SRTE,因为头端只有本域的信息,集中式的可以收集不同域的拓扑信息,从而支持跨域。实际的链路负载,IP+Optical多层协同等功能只有集中式才能实现。
集中计算与不相交性
- 只有集中式的控制器,PCE才可以满足不同头端发起的disjointness路径请求
- 分布式无法支持
SRTE计算结果
sr policy 就是SID List
SID List包含Prefix SID,Adj SID和Service SID组成,通常Service SID在栈底,SID List也可以只有Prexfix SID,每一个SID都代表去往这个SID的等价路径的最短路径