网站首页 > 技术文章 正文
SIP网络涉及了很多相关的网络配置。因为配置不当的原因,我们经常会看到很多SIP呼叫中30秒掉线的问题和RTP流路由到错误的地址和端口的问题。笔者在以前的历史文档中对30秒掉线等问题做过非常多的介绍,但是,一些文档没有涉及到具体的平台的某些特定的参数设置,所涵盖的内容比较宽泛,仅是一个仅仅问题的数量方法。在这些问题中,很多问题其实大部分都和NAT相关,地址端口的错误路由导致了RTP路由错误,最终导致语音流不能正确抵达终端。今天,我们针对Asterisk平台和几个特定的参数(Via,Contact,SDP中的c=和m=行),结合以上所提到的问题做进一步的介绍。
关于Via和Contact 头的完整详解,读者可以参考笔者的文章来做进一步的了解学习。
1)一封信读懂SIP注册消息关键词
2)SIP语音环境中十大经典问题及解决办法
3)关于SIP Proxy处理中的八大疑问讨论
下面,我们通过以上三种参数的设置来进一步解释如何通过调整参数的方式来解决前面我们所提到的问题。
1) 检查 Via header
在SIP消息中,Via头中显示了消息路径,并且决定了响应消息的最终返回的目的地路径。如果消息设置错误的话,响应消息不会抵达正确的目的地地址,因此就会导致无RTP流的问题。默认的Asterisk设置会返回请求所带的源地址和端口,这样可以避免NAT问题。但是,一些SIP话机(部分思科话机)则要求Asterisk发送响应消息到Via 头中提供的端口上。为了解决这个问题,在chan_pjsip中,用户需要在endpoint的配置参数中,设置force_rport=no:
[mypeer1]
type=endpoint
force_rport=no
rewrite_contact=yes
rtp_symmetric=yes
;..
https://wiki.asterisk.org/wiki/display/AST/Migrating+from+chan_sip+to+res_pjsip
通过以上设置,就可以解决发送到错误端口的问题。
2) 检查Contact header
在SIP消息中,Contact头的作用是通知后续的请求消息发送到Contact地址。Contact header会出现在呼叫,注册,订阅等消息中。在实际环境中,如果呼叫双方不在同一网络环境下,则可能双方的通信失去联系。200 OK发送出去以后,因为地址的问题,可能200 OK根本没有抵达对端,经过大概30秒的不断发送回传,最后挂机。在Asterisk的chan_pjsip中,用户可以设置rewrite_contact=yes 来解决这个问题。这个参数会修改实际收到的IP地址和端口到请求中的实际的IP和端口。这样就可以保持互通时的地址端口不会被第三方的设置所干扰。
3) 检查SDP中的c=和m=行
很多人都知道,媒体流实际上是不会受NAT影响的。媒体流交互的主要途径是通过SDP中的c=和m=行来获取。媒体流通过c=和m=行参数来命令管理媒体的路径。就像Contact一样,如果出现了错误的地址信息以后,同样,媒体流也不会成功发送到正确的终端地址,也可能导致语音流丢失。chan_pjsip中的rtp_symmetric=yes 可以解决这个问题。通过此参数设置,Asterisk RTP启动以后就会把它接收到的媒体源地址锁住,然后对其地址发送出局的媒体流,并且忽略了c=和m=行中携带的错误地址。
通过以上三种方式的排查,基本上可以解决部分Asterisk中的30秒挂机问题和RTP地址错误的问题。当然,NAT问题本身是一个非常复杂的问题,我们这里没有涉及ALG,路由器设置,SBC设置等讨论。读者可以查阅笔者历史文档做更多了解。
参考资料:
https://wiki.asterisk.org/wiki/display/AST/Configuring+res_pjsip+to+work+through+NAT
猜你喜欢
- 2024-10-30 软交换折腾小记 软交换与ngn
- 2024-10-30 Asterisk-ARI对通道中的DTMF事件处理
- 2024-10-30 Asterisk通道和ARI接口的通信 alphy通道
- 2024-10-30 使用WebRTC技术实现浏览器和其他电话终端之间的呼叫
- 2024-10-30 网易云信CTO阙杭宁:如何保障十万不同应用的通讯稳定与实时性
- 2024-10-30 融合通信功能配置示例-1-如何快速批量添加SIP分机
- 2024-10-30 PJSIP集成G729 (vs2022版) 乚a7841集成块
- 2024-10-30 JFrog 披露PJSIP开源多媒体通信库的五个漏洞
- 2024-10-30 PJSIP 2.12.1 编译 与 C# Pjsip (Pjsua2 api )应用
你 发表评论:
欢迎- 最近发表
-
- 在 Spring Boot 项目中使用 activiti
- 开箱即用-activiti流程引擎(active 流程引擎)
- 在springBoot项目中整合使用activiti
- activiti中的网关是干什么的?(activiti包含网关)
- SpringBoot集成工作流Activiti(完整源码和配套文档)
- Activiti工作流介绍及使用(activiti工作流会签)
- SpringBoot集成工作流Activiti(实际项目演示)
- activiti工作流引擎(activiti工作流引擎怎么用)
- 工作流Activiti初体验及在数据库中生成的表
- Activiti工作流浅析(activiti6.0工作流引擎深度解析)
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)