1 TRILL概述

TRILL的全称就是Transparent Interconnection of Lots of Links,顾名思义,其本质就是将非常多条链路透明地组织在一起,以致于上层IP应用感觉这仅仅是一条链路似的。它本质上是一个2.5层的技术,使用最短路径、多路径等三层路由技术来讲多条链路组织成为一个大二层网络,并支持VLAN、自配置、多播等二层功能。

它既有以太网的易配置特性,又有第三层路由的技术优势。

2 TRILL的背景

(1) 为什么以太网使用范围小有6字节地址,而IP在整个Internet中使用却有4个字节?

出于自配置的考虑。以太网设备的MAC地址是不须要配置的,也绝对不会冲突,由于不同以太网厂商购买不同地址块。

(2) 为什么须要TRILL,为什么不能仅用第二层或者第三层的技术来解决?

二层无法扩展到非常大,由于基于CSMA/CD的以太网支持的网络半径是有限的;假设引入网桥,那么就要使用STP生成树协议来防止环路;可是STP堵塞将造成了一半的网络带宽浪费和次优路由。

单纯使用三层的核心问题在于主机在移动的过程中,IP地址是必需要改变的,由于IP地址本质上是分给链路而不是节点的。

3 TRILL技术

RBridge:实现了TRILL协议的设备叫做Routing Bridge,简称RBridge.

TRILL头部非常easy:

ingress RBridge nickname (16 bits), egress RBridge nickname (16 bits), hop count (6
bits), and a multidestination flag bit (1 bit).

所以查表速度肯定要快于以太网MAC地址(6字节)和IP(4字节而且最长匹配)。



对以下几个关键问题的解答,应该是理解TRILL核心技术的关键。

问题一:从源MAC S到目的MAC D,入RBridge怎样知道出RBridge就是R2呢?

这个问题本质上是怎样学习端节点End Node的位置,这是进行TRILL核心网转发的前提。
尽管眼下有多种机制,可是宏观效果是:仅仅有Ingress/Egress RBridge须要使能传统的MAC地址学习(MAC表中区分从本地port学到的MAC地址,以及从远端Egress RBridge上学到的MAC地址),而TRILL网络上的核心RBridge无需维护与主机相关的MAC表。
默认机制是自学习加洪泛。即全部RBridge不断学习(ingress RBridge, source MAC address) 映射关系,假设仍然不知道,则封装multidestination标志被洪泛到全部RBridge。(插一句,怎样进行洪泛是通过TRILL底层执行的IS-IS协议来生成的最短路径树进行,而且全网有一个同样的SPF树。)
一个可选机制是ESADIEnd-Station Address Distribution Information ,即RBridge宣告下联的端节点。
此外另一种机制是建立一个独立的字典或者文件夹,存储RBridge nickname与下联端节点的关系。

问题 二:TRILL为什么选择IS-IS作为底层路由协议,而不选择相同是链路状态协议的OSPF?

主要两个原因,1 IS-IS能够直接执行在第二层数据链路层上,进而实现自配置,而OSPF执行在IP层上,须要每一个路由器都先配置好IP地址才行;2 IS-IS以TLV为报文的基本格式,方便支持各种可扩展属性。

问题三:RBridge怎样获取nickname?

RBridge随机选择nickname,并与链路状态宣告报文一起洪泛通知给其它RBridge。

问题:TRILL是否支持增量部署?

当然能够,全然能够把现有以太网中的bridge替换成为RBridge,让两种设备并存于网络中。那么,RBridge之间由普通网桥bridge连接的网络仍然使用生成树STP,而且被RBridge视为一个单一的链路就可以。

问题:TRILL是怎样支持不同类型底层链路的?

在TRILL网络中,RBridge之间可能是多种链路层技术,比方以太网、PPP串行链路、IP或者IPSec或者MPLS。那么TRILL是怎样支持这些不同类型的底层链路呢?这是由于TRILL网络中传输的报文是三层封装的:

第一层头,也叫做hop-by-hop头,是由详细的底层链路决定。假设是以太网,那就是MAC头;假设是MPLS,就是MPLS头等,这个外层头的源/目的地址是每跳都换的;

第二层头,也就是前面所说的TRILL头。这个头里,源是前述ingress RBridge;目的是egress RBridge;

第三层头,真正进行大二层通信的端节点的二层地址。

问题:VLAN对于TRILL有什么影响吗?

如前述,TRILL网络的数据包有三个头:外头+TRILL头+内头。首先,在内头中的VLAN tag非常明显体现的是终端所属的通信广播域;而在外头中的VALN tag则是用于在普通以太网中连接不同的RBridge。在TRILL中使用的是指定RBridge,即DRB的方式。详细说,DRB选择一个VLAN号,比方VALN A,然后通知在同样以太链路上的全部其它RBridge,用于Hello和LSP的通信。此外,

1) DRB也用于决定哪个RBridge来封装和解封装哪个VLAN的数据包。

2) RBridge会在其LSP中宣告它所连接的是哪个VLAN的终端,以便仅仅接收相应VLAN的。

问题:多路径与TRILL是什么关系?

从技术渊源来看,多路径是第三层的技术,而不是第二层的。详细来说,在三层,路由器通过路由协议能够计算出多条等价路由路径,实现负载均衡,如ECMP;在二层,除了多播表项外,MAC表中的单播表项仅仅可能相应于一个出口。

那么,TRILL与多路径的关系就是,TRILL技术的出现,通过隧道封装,将三层IP多路径转发技术应用到以太帧转发上,进而实现将原本的二层MAC转发转换成一个类IP的三层路由转发。

4 TRILL实现

TRILL设备中肯定是有两个表的,一个是MAC表,用于学习源MAC地址,而且查找目的MAC地址所相应的RBridge nickname;还有一个是TRILL转发表,在TRILL域转发时用,即从ingreee RBridge怎样到达egress RBridge。

TRILL浅析的更多相关文章

  1. SQL Server on Linux 理由浅析

    SQL Server on Linux 理由浅析 今天的爆炸性新闻<SQL Server on Linux>基本上在各大科技媒体上刷屏了 大家看到这个新闻都觉得非常震精,而美股,今天微软开 ...

  2. 【深入浅出jQuery】源码浅析--整体架构

    最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐 ...

  3. 高性能IO模型浅析

    高性能IO模型浅析 服务器端编程经常需要构造高性能的IO模型,常见的IO模型有四种: (1)同步阻塞IO(Blocking IO):即传统的IO模型. (2)同步非阻塞IO(Non-blocking  ...

  4. netty5 HTTP协议栈浅析与实践

      一.说在前面的话 前段时间,工作上需要做一个针对视频质量的统计分析系统,各端(PC端.移动端和 WEB端)将视频质量数据放在一个 HTTP 请求中上报到服务器,服务器对数据进行解析.分拣后从不同的 ...

  5. Jvm 内存浅析 及 GC个人学习总结

    从诞生至今,20多年过去,Java至今仍是使用最为广泛的语言.这仰赖于Java提供的各种技术和特性,让开发人员能优雅的编写高效的程序.今天我们就来说说Java的一项基本但非常重要的技术内存管理 了解C ...

  6. 从源码浅析MVC的MvcRouteHandler、MvcHandler和MvcHttpHandler

    熟悉WebForm开发的朋友一定都知道,Page类必须实现一个接口,就是IHttpHandler.HttpHandler是一个HTTP请求的真正处理中心,在HttpHandler容器中,ASP.NET ...

  7. 【深入浅出jQuery】源码浅析2--奇技淫巧

    最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐 ...

  8. 浅析匿名函数、lambda表达式、闭包(closure)区别与作用

    浅析匿名函数.lambda表达式.闭包(closure)区别与作用 所有的主流编程语言都对函数式编程有支持,比如c++11.python和java中有lambda表达式.lua和JavaScript中 ...

  9. word-break|overflow-wrap|word-wrap——CSS英文断句浅析

    ---恢复内容开始--- word-break|overflow-wrap|word-wrap--CSS英文断句浅析 一 问题引入 今天在再次学习 overflow 属性的时候,查看效果时,看到如下结 ...

随机推荐

  1. 【转】c#实现字符串倒序的n种写法

    其中LINQ写法最为简洁 //string concatenation with for loop public string ReverseA(string text) {     char[] c ...

  2. 综合第一篇文章(带钩Quora)

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxNDc4MzAyNw==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...

  3. 了解HTML5和“她”的 API (三)

    Web Workers(后台线程) JavaScript是单线程的,较长的javascript运算会阻塞UI线程. web worker 是运行在后台的 JavaScript,不会影响页面的性能. 在 ...

  4. C# 读取IE缓存文件(1)

    using System; using System.Runtime.InteropServices; namespace Common { public class IECache { [DllIm ...

  5. std::list.pop_back() 弹空了列表导致的崩溃

    core文件输出: (gdb) bt # # ) at xxxxx/sql/signal_handler.cc: # <signal handler called> # # # # # 0 ...

  6. centos6.5 64位 openvpn安装配置(转)

    查看系统版本cat /etc/redhat-releaseCentOS release 6.5 (Final) 查看内核和cpu架构uname -rm2.6.32-431.el6.x86_64 x86 ...

  7. SQL Server 连接问题-TCP/IP

    原文:SQL Server 连接问题-TCP/IP 出自:http://blogs.msdn.com/b/apgcdsd/archive/2012/02/24/ms-sql-server-tcp-ip ...

  8. Cordova WP8 插件开发

    原文:Cordova WP8 插件开发 前面博客中介绍了Cordova WP8平台上的安装部署,Cordova扩展可以利用WP8本地代码扩展WebApp的功能,调用本地能力需要开发相应的插件,下面以闪 ...

  9. Java Web整合开发(14) -- Struts 1.x 概述

    整合Spring与Struts1的三种方法总结 无论用那种方法来整合,第一步就是要装载spring的应用环境,有三种方式: #1. struts-config.xml <?xml version ...

  10. 由Java代码运行shell命令/脚本

    JDK有两种方法自带通Runtime.getRuntime().exec()和ProcessBuilder课上做, 后者是JDK1.5引进后,,政府还提出要放弃使用Runtime顺便做.现的时候就是採 ...