TRIP--IP电话路由的新技术和应用(中)
包斌 2002/08/09
3 TRIP的实现
3.1 TRIB的构成
TRIP协议交换的路由信息由外部路由(External routes)、内部路由(Internal routes)和本地路由(Local routes)三种类型组成,为了直观的描述TRIB的构成关系,TRIP协议从路由选择的角度把LS中的TRIB分成以下四个构成部分,这四个部分实际上是由以上三种类型的路由内容构成:
- Adj-TRIBs-In:称为临近可选TRIB,其内容是从UPDATE消息中获取的域内、域外LS上的路由信息,这些路由信息是当前路由选择中的可以使用的输入路由信息,
- Ext-TRIB:称为外部TRIB,其内容是LS根据一定的路由选择运算法则,从外部路由(存储在外部LS的Adj-TRIBs-In中)和本地路由(存储在本地LS的Adj-TRIBs-In中),为一个给定目的地址选择的最佳的路由,每个LS只有一个Ext-TRIB。
- Loc-TRIB:称为本地TRIB,其内容是LS运用其内部策略从内部LS的Adj-TRIBs-In和Ext-TRIB中选择出来的TRIP路由信息。
- Adj-TRIBs-Out:称为临近输出TRIB,其内容是LS准备广播给外部LS的路由信息,它的内容将携带在UPDATE消息中对外广播。
这几部分的关系如下图7:

虽然TRIB由以上的四个部分构成,但这并不意味也并不要求一个路由选择过程的完成必须要保留这四个每一个的单独备份,其选择并不拘泥于协议的划分,有些路由选择过程可能要用到一个TRIB,有时可能要用到多个,甚至在TRIP-MIB库设计中大家并不一定能意识其的单独存在,这根据具体需要而定。
关于TRIB标准定义的RFC至今还没有出台,只有讨论性的草案,因此TRIB内容的具体表示只能暂时参考这些草案(draft-ietf-iptel-trip-mib-01.txt)。
3.2 路由消息的格式
TRIP的消息必须建立在可靠传输协议的连接上,即只能是TCP/IP连接,且使用的TCP连接端口为6069,一个消息必须而且只能在全部接收结束后才能开始进行处理,TRIP消息的最大长度是4K(4096)个字节,最短长度是只包含消息头部分的3个字节,大于4K个字节和小于3个字节长度的消息都属于无效的TRIP消息。
3.2.1 消息头格式
TRIP消息有固定的头格式(共3个字节长),它决定了TRIP消息的类型,如图8:

前两个字节标明了这个TRIP消息的总长度,这个长度也包括消息头的长度,最大值为4096,最小值为3;消息类别标明了本次TRIP消息的类型,取值范围是1~4,表示的意义如下:
1 - 当前消息是OPEN消息,用于建立LS之间的对等连接关系。
2 - 当前消息是UPDATE消息,用于传输LS之间的网关路由信息。
3 - 当前消息是 NOTIFICATION消息,用于通知运行中出现的错误、故障状态。
4 - 当前消息是KEEPALIVE消息,用于维护对等LS之间的连接关系处于活动状态。
下面分别介绍OPEN、UPDATE、NOTIFICATION、KEEPALIVE四种TRIP消息和其所完成的TRIP、操作功能。
3.2.2 OPEN(打开)消息
对等的LS之间的TCP连接建立起来后,双方发送的第一个消息就是OPEN消息,双方在收到对方的OPEN消息后就返回一个KEEPALIVE消息,以确认OPEN消息发送和对等的LS之间TRIP会话建立成功,然后UPDATE、NOTIFICATION消息才可以进行发送。
OPEN消息的最短长度为17个字节(包括消息头的三个字节),除去固定的消息头外,OPEN消息格式和域内容如图9:

其中:
Version:表示当前消息所支持的TRIP版本,现在的版本是V1。
Reserved:保留字。
Hold Time:表示所建立会话的最长寿命,单位为秒,其值要么为0,表示永远存在,要么就取最小值为3秒。
My ITAD:当前发送者所在的ITAD的编号,这是由IANA组织分配的一个唯一值,1~255是协议的私有值,一般取值为从256 到 (2**32)-1中的一个,如SNMP中企业代码一样,不能随便乱取。
TRIP Identifier:发送者在所在ITAD域中的唯一TRIP标识(序号),可以理解为在ITAD中每个LS的编号,其一旦确定就不能再修改,除非整个系统重新启动。
Optional Parameters Len:表示了Optional Parameters (variable)List域的长度,单位为字节,如果为0,则表示本消息无操作参数。
Optional Parameters (variable) List:是OPEN消息要发送数据或变量值的详细列表,包括参数类型、参数长度、参数的值。
在当前的TRIP协议中,OPEN消息主要用来告诉对方LS自己所具备的TRIP操作能力,这种能力包括两个方面:
- 所支持的路由类型(Parameter Type=1),双方LS只能处理都支持的路由类型,如果收到了不能支持的路由类型,则立即丢弃不做进一步处理。
- 发送接收的能力(Parameter Type=2),这都是针对UPDATE消息而言的,包括只发送模式(Send Only mode)、只接收(Receive
Only mode)和发送接收模式( Send Receive mode),一个LS任何时候对所有的对等LS只能处于一种模式,默认的是发送接收模式。在只发送模式下,一个LS只向其对等的LS发送UPDATE消息,对等的LS不必返回UPDATE消息,即使收到了返回的UPDATE消息,它也必须无条件丢弃;在只接收模式下,LS只能作为消极的UPDATE消息监听和接收者,不能向发送者返回和发送任何UPDATE消息;在发送接收模式中,一个LS具备接收和发送UPDATE消息的全双工功能。
3.2.3 UPDATE(更新)消息
UPDATE消息包中的数据勾勒出了多个ITAD之间的关系连接图,它不仅用来广播新增路由信息,也用来删除、修改已经广播出去的一些路由信息,而且这两种操作可以同时进行。
除了TRIP消息固定的消息头外,UPDATE消息体实际上是一个路由属性列表,在属性和属性之间无其它的中间数据,其最短长度为三个字节,它的列表中属性的数量可以为0,其消息的格式如图10:

- Attribute Flags
路由属性标志是在不断被扩展的,其目前的取值与TRIP协议的路由选择、路由分发、路由聚合和路由的封装等操作有着密切的关系,这个域共一个字节(8位),目前只用到了前5位,每位有不同的功能:
Bit 0, Well-Known Flag,是路由属性是否可知标志。
Bit 1, Transitive Flag,是路由属性不可知时是否传送标志。
Bit 2, Dependent Flag,是路由属性不可知时传送依赖标志。
Bit 3, Partial Flag,是Transitive Flag标志信息是否代表局部标志。
Bit 4, Link-state Encapsulated Flag,连接状态是否封装标志。
- Attribute Type Code
发送的路由属性类型码也是由IANA控制的,属性类型码的值决定了当前消息中所发送的路由信息的操作类型,属性码、属性表示和其意义如下:
1:WithdrawnRoutes,给出要从当前服务中取消的路由。
2:ReachableRoutes,给出向当前服务中增加新的可用路由。
3:NextHopServer,给出消息发送所要经过的实体标识。
4:AdvertisementPath,给出了路由消息在不同的ITAD域间广播的先后顺序。
5:RoutedPath,给出了路由消息在不同的ITAD域间广播的路径。
6:AtomicAggregate,给出了实际存在但没包括在RoutedPath中的广播路由。
7:LocalPreference,向其它的LS告诉本地LS对给定路由的首选项。
8:MultiExitDisc,相邻的域间的LS有多个对等LS的情况下,LS用这个属性来表示其在域间的首选连接。
9:Communities,在把目的地址分组成团体名来简化路由信息控制中用到的团体名称。
10:ITAD Topology,向域内的其它LS给出本域的Topology结构。
12:ConvertedRoute,指出中间的LS通过改变路由应用协议的方式所改变的路由信息。
以上每一种的路由属性在UPDATE消息中都有单独的消息格式和数据结构特点,在此不再一一称述。
- Attribute Length和Attribute Value (variable)
为以上标志和属性下路由数据的值长度和值。
UPDATE消息的处理、控制是一个很复杂的综合过程,是TRIP的四种消息中的核心,也是路由信息广播、同步操作的核心,这些过程主要包括路由信息的域内通知过程、路由选择过程、域间路由信息广播过程和各种策略的选择、确定和运用过程等。
3.2.4 NOTIFICATION(通知)消息
当LS检测到有某种故障、错误时,NOTIFICATION消息就产生和发送了,同时出现故障、错误的LS之间的TRIP会话就立即关闭。
除去TRIP固定的消息头外,NOTIFICATION消息的格式如图11,其最小的长度为5个字节。

在此消息格式中Error Code和Error Subcode的取值范围为:
Error Code 错误类别和错误内容
1 Message Header Error(TRIP消息头错误) ,对应的具体故障为:
Error Subcode=1 :Bad Message Length(错误的消息长度)
Error Subcode=2 :Bad Message Type(错误的消息类型)
2 OPEN Message Error(OPEN 消息错误),对应的具体故障为:
Error Subcode=1 :Unsupported Version Number.(错误的版本号)
Error Subcode=2 :Bad Peer ITAD(错误的ITAD编号)
Error Subcode=3 :Bad TRIP Identifier(错误TRIP标识)
Error Subcode=4 :Unsupported Optional Parameterr(错误TRIP标识)
Error Subcode=5 :Unacceptable Hold Time(消息有效时间不合适)
Error Subcode=6 :Unsupported Capability(无法支持的能力属性)
Error Subcode=7 :Capability Mismatch(能力属性不匹配)
3 UPDATE Message Error(UPDATE消息错误),对应的具体故障为:
Error Subcode=1 :Malformed Attribute List(奇形属性列表)
Error Subcode=2 :Unrecognized Well-known Attribute(不可识别的Well-known属性值)
Error Subcode=3 :Missing Well-known Mandatory Attribute(无Well-known强制属性)
Error Subcode=4 :Attribute Flags Error(属性标志错误)
Error Subcode=5 :Attribute Length Error(属性长度错误)
Error Subcode=6 :Invalid Attribute(无效的属性值)
4 Hold Timer Expired(消息有效时间到)
5 Finite State Machine Error(有限状态机错误)
6 Cease (遇到致命性错误,TRIP交互立即停止)
通知消息中数据值的长度的计算公式是:数据值长度 = 消息的总长度 - 5
3.2.5 KEEPALIVE(活)消息
KEEPALIVE消息是OPEN消息成功后的一个响应消息,它主要是为了告诉双方LS它们之间已经建立的成功会话还处于活动状态,以便进行UPDATE消息的交互,KEEPALIVE消息发送的时间间隔是自定义的,一般比较合理的最大间隔是OPEN消息中设定寿命值(Hold
Time)的三分之一,如果寿命值为0,则不发送KEEPALIVE消息。
KEEPALIVE消息格式就是TRIP消息的格式,如图8,其无单独的消息格式和内容,只须标明消息类型值为4。
TRIP--IP电话路由的新技术和应用(上)
TRIP--IP电话路由的新技术和应用(下)
作者供稿 CTI论坛编辑
相关链接: