两个SIP路由实例分析

网络 网络管理
下面我们来对SIP路由机制的两个实际应用案例进行一下分析。以便帮助大家把相关定义和概念融会贯通一下。望对大家有用。

前面我们通过《阐述SIP路由机制的概念》一文,了解了关于SIP路由机制的有关定义和概念。那么接下来,对于这些抽象概念的解析,就让实例来帮助大家理解吧。接下来,我们利用两个SIP路由实例帮助大家把这些概念来融会贯通一下。

SIP路由示例1:

场景:两个UE间有两个Proxy,U1 -> P1 -> P2 -> U2,并且两个Proxy都乐意添加Record-Route头域。

消息流:

【说明】由于我们在此只关心SIP路由机制,因此下面消息中跟路由机制无关的头域都省略了。

U1发出一个INVITE请求给P1(P1是U1的外拨代理服务器):

  1. INVITE sip:callee@domain.com SIP/2.0  
  2. Contact: sip:caller@u1.example.com  

P1不负责域domain.com,消息中也没有Route头域,因此通过DNS查询得到负责该域的Proxy的地址并且把消息转发过去。这里P1在转发前就添加了一个Record-Route头域,里面有一个lr参数,说明P1是一个松散路由器,遵循RFC3261中的路由机制。

  1. INVITE sip:callee@domain.com SIP/2.0  
  2. Contact: sip:caller@u1.example.com  
  3. Record-Route: <sip:p1.example.com;lr> 

P2负责域domain.com,因此它通过定位服务得到callee@domain.com

对应的设备地址是callee@u2.domain.com ,在SIP路由机制中,因此用新的URI重写request-URI。消息中没有Route头域,因此它就把该消息转发给request-URI中的URI,转发前它也增加了一个Record-Route头域,并且也有lr参数。

  1. INVITE sip:callee@u2.domain.com SIP/2.0  
  2. Contact: sip:caller@u1.example.com  
  3. Record-Route: <sip:p2.domain.com;lr>  
  4. Record-Route: <sip:p1.example.com;lr> 

位于u2.domain.com的被叫收到了该INVITE消息,并且返回一个200OK响应。其中就包括了INVITE中的Record-Route头域。

  1. SIP/2.0 200 OK  
  2. Contact: sip:callee@u2.domain.com  
  3. Record-Route: <sip:p2.domain.com;lr>  
  4. Record-Route: <sip:p1.example.com;lr> 

被叫此时也就有了自己的路由集:

  1. (<sip:p2.domain.com;lr>,<sip:p1.example.com;lr>)  

并且它本次会话的远端目的地址设置为INVITE中Contact中的URI:caller@u1.example.com,此后被叫在该会话中的请求消息就发到这个URI。同样,被叫在200 OK响应中也携带了自己的联系地址,主叫收到该响应消息后也会把本次会话的远端目的地址设置为:callee@u2.domain.com,此后主机在该会话中的请求消息就发到这个URI。同样,主叫也有了自己的路由集,只是跟被叫的是反序的:

  1. (<sip:p1.example.com;lr>,<sip:p2.domain.com;lr>)   

通话完毕后,我们架设主叫先挂机,则主叫发出BYE请求:

  1. BYE sip:callee@u2.domain.com SIP/2.0  
  2. Route: <sip:p1.example.com;lr>,<sip:p2.domain.com;lr> 

可以看到,BYE的Route头域正是主机的路由集构造来的。由于p1在***个Route中,因此BYE首先发给P1。

P1收到该消息后,发现request-URI中的URI不属于自己负责的域,而消息有Route头域,并且***个Route头域中的URI正是自己,因此删除之,并且把消息转发给新的***个Route头域中的URI,也就是P2:

  1. BYE sip:callee@u2.domain.com SIP/2.0  
  2. Route: <sip:p2.domain.com;lr> 

P2收到该消息后,发现request-URI中的URI不属于自己负责的域(P2负责的是domain.com,而不是u2.domain.com),***个Route头域中的URI正是自己,因此删除之,此时已经没有Route头域了,因此就转发给了request-URI中的URI。

被叫就会收到BYE消息:

  1. BYE sip:callee@u2.domain.com SIP/2.0 

 #P#

SIP路由示例2:

如果说上面的示例主要关注的是SIP路由流程,那么本示例关注的则是严格路由与松散路由的区别。

场景:U1->P1->P2->P3->P4->U2其中,P3是严格路由的,其余Proxy都是松散路由的,并且4个Proxy都很乐意增加Record-Route头域。

消息流:我们直接给出了到达被叫的INVITE消息:

  1. INVITE sip:callee@u2.domain.com SIP/2.0  
  2. Contact: sip:caller@u1.example.com  
  3. Record-Route: <sip:p4.domain.com;lr>  
  4. Record-Route: <sip:p3.middle.com>  
  5. Record-Route: <sip:p2.example.com;lr>  
  6. Record-Route: <sip:p1.example.com;lr> 

这中间的其他消息我们就不过问了,直接看一下被叫***发出的BYE消息大概是什么样子:

  1. BYE sip:caller@u1.example.com SIP/2.0  
  2. Route: <sip:p4.domain.com;lr>  
  3. Route: <sip:p3.middle.com>  
  4. Route: <sip:p2.example.com;lr>  
  5. Route: <sip:p1.example.com;lr>  

因为P4在***个Route里,因此被叫将BYE消息发给了P4。

P4收到该消息后,发现自己不负责域u1.example.com,但是***个Route头域中的URI正是自己,因此删除之。在SIP路由机制中,P4还发现新的***个Route头域中的URI是一个严格路由器,因此它把request-URI中的URI添加到***一个Route的位置,并且将***个Route“弹出”并且覆盖原来的request-URI。然后将消息转发给当前的request-URI,也就是P3。

  1. BYE sip:p3.middle.com SIP/2.0  
  2. Route: <sip:p2.example.com;lr>  
  3. Route: <sip:p1.example.com;lr>  
  4. Route: <sip:caller@u1.example.com> 

P3收到该消息后,直接把消息作出如下变换并且发给P2:

  1. BYE sip:p2.example.com;lr SIP/2.0  
  2. Route: <sip:p1.example.com;lr>  
  3. Route: <sip:caller@u1.example.com> 

P2收到该消息后,发现消息中的request-URI是自己的,因此在进一步处理先首先对消息做如下变换:

  1. BYE sip:caller@u1.example.com SIP/2.0  
  2. Route: <sip:p1.example.com;lr>  

然后,P2发现自己不负责域u1.example.com 。***个Route中的URI也不是自己的,因此将消息转发给该URI,也就是P1。

P1收到该消息后,发现自己不负责域u1.example.com,但是***个Route头域中的URI正是自己,因此删除之。

消息变成下面的样子:

  1. BYE sip:caller@u1.example.com SIP/2.0 

既然Route头域已经是空,因此P1把消息发给u1.example.com。

到这里,两个SIP路由实例已经讲解完了,不知道大家对这部分知识是否了解了,希望本文的总结,能够让给大家一些参考。

责任编辑:佟健 来源: hi.baidu.com
相关推荐

2009-07-15 18:29:22

Jython应用

2011-07-05 16:13:18

2010-09-17 10:24:55

SIP INVITE

2012-12-17 09:52:18

路由器连接路由器设置

2011-08-29 14:38:10

路由器ADSL猫双路由连接

2019-10-31 08:22:39

shell脚本Linux

2009-11-03 17:24:01

VB.NET特殊形状窗

2009-11-26 10:14:37

路由器连接

2022-07-29 12:56:19

宽带路由器设置

2010-09-26 14:42:58

路由器DHCP设置

2010-08-06 11:28:33

RIP分组格式

2020-10-12 09:39:34

漏洞

2010-08-19 11:22:19

marginpadding

2022-06-17 09:46:51

Chrome 102Chrome浏览器

2009-11-25 15:50:16

路由器调试

2012-11-05 10:15:24

路由器VLAN

2020-11-13 07:16:09

线程互斥锁死循环

2010-09-17 09:34:00

SIP路由机制

2010-07-30 13:16:52

路由器

2019-08-08 09:09:20

MySQL硬件Linux
点赞
收藏

51CTO技术栈公众号