当前位置: 首页 > news >正文

rtpengine作为媒体代理的一个问题

主要原因是AB路的rfc2833的payload有差异造成的,可以通过kamailio的配置逻辑来修复。

环境

CentOS 7.9

kamailio:5.8.3-bullseye docker

rtpengine:mr13.1.1.6-4 docker

问题

kamailio 5.8.3 + rtpengine 13.1.1.6,媒体代理模式。

A路invite的sdp中dtmf参数如下。

m=audio 45540 RTP/AVP 8 18 97

a=rtpmap:97 telephone-event/8000

a=fmtp:97 0-15

经过kamailio转发后的invite的sdp。

m=audio 33088 RTP/AVP 8 18 97

a=rtpmap:97 telephone-event/8000

a=fmtp:97 0-15

B路响应的200OK的sdp中dtmf参数如下。

m=audio 16394 RTP/AVP 8 101

a=rtpmap:101 telephone-event/8000

a=fmtp:101 0-16

经过kamailio转发后的200OK。

m=audio 31724 RTP/AVP 8

A路sdp中dtmf的payload为97,kaimailio正常透传,B路响应sdp中dtmf的payload为101,经过kamailio+rtpengine处理后,sdp中的dtmf编码被删除了。

通话接通后,A路按键发送DTMF码,采用inband波形模式,B路无法正常识别。

修复

问题的本质是B路响应的sdp中dtmf的payload被删除了,但是媒体通道并没有受影响,媒体转发也没有任何问题,所以最直接的办法就是在kamailio的cfg配置中再把payload加回去。

修改kamailio.cfg文件,主要修改如下。

...

modparam("rtpengine", "write_sdp_pv", "$avp(sdp)")

...

route[RESET_DTMF]{

xinfo("route[RESET_DTMF]\n");

# reset DTMF payload

if(search_body("telephone-event/8000") && !search_str($avp(sdp), "telephone-event/8000"))

{

xinfo("Added DTMF 101 payload to SDP\n");

$avp(sdp) = $(avp(sdp){re.subst,/^(m=audio.* 8)/\1 101/});

$avp(sdp) = $(avp(sdp){re.subst,/^(a=rtpmap:8 PCMA.*)$/\1\na=rtpmap:101 telephone-event\/8000\na=fmtp:101 0-15/});

set_body("$avp(sdp)", "application/sdp");

}

else {

xinfo("DTMF 101 payload already exists in SDP\n");

set_body("$avp(sdp)", "application/sdp");

}

return;

}

route[RTPENGINE] {

xinfo("route[RTPENGINE]\n");

# check if have sdp

if (!has_body("application/sdp"))

{

xinfo("!has_body(application/sdp)\n");

return;

}

if(ds_is_from_list("3060") || ds_is_from_list("3061"))

{

xinfo("route[RTPENGINE], 3060|3061\n");

# from pub, to priv

rtpengine_manage("replace-origin replace-session-connection direction=pub direction=priv ");

set_body("$avp(sdp)", "application/sdp");

}

else if(ds_is_from_list("5060"))

{

xinfo("route[RTPENGINE], 5060\n");

# from priv, to pub

rtpengine_manage("replace-origin replace-session-connection direction=priv direction=pub ");

route(RESET_DTMF);

}

return;

}

思路就是针对AB路会有不同payload的场景,调用route(RESET_DTMF),在PCMA编码的后面加上payload=101的编码。

测试

重启kamailio,发起呼叫。

从信令中看到,经过kamailio处理后的200OK的sdp中增加了payload=101的dtmf编码。

A路按键测试,可以看到rtpengine正常转发了dtmf码。

image

总结

kamailio+rtpengine作为媒体代理的方式简单易用,转发效率高,不会修改媒体包的内容,rtp和rtcp都可以正常透传转发。

http://www.cnnetsun.cn/news/40859.html

相关文章:

  • Caesium图像压缩器高级配置与定制化指南
  • Graphiti时序知识图谱:5大革新策略重塑动态知识管理
  • CMATH:如何5分钟掌握小学数学计算能力评估
  • 使用RNNoise进行音频降噪
  • 风储模型中的功率分配模型
  • 眼见非实(Bugku杂项入门)
  • 毕方Talon:鸿蒙开发的编译时安全守护神
  • 创客匠人峰会新解:高势能 IP 打造 ——AI 时代知识变现的十倍增长密码
  • Java线程池与Executor框架完全指南:一看就会,一看就懂!
  • 随机图床 _
  • PETools 逆向工程工具完整使用指南
  • 改善深层神经网络 第一周:深度学习的实践(四)其他缓解过拟合的方法
  • 品牌营销 深度心智方法论
  • STM32之使用DWT外设编写延时函数
  • 选择中国优化路线的美国独立服务器的8大好处
  • Abaqus三维纤维复合材料Vumat子程序:弹性层压板+Hashin损伤(纤维)+Puck损...
  • 移动应用无障碍测试完全指南:如何用Maestro实现WCAG标准自动化验证
  • Effective C++ 中文版第3版:C++进阶编程的终极指南
  • Slang光线追踪加速结构深度解析:从理论到性能优化实践
  • DeepSeek-R1-Distill-Qwen-7B集群部署终极指南:轻松搞定AI推理服务
  • 风储调频在Matlab/Simulink中的探索:基于四机两区系统的实践
  • 基于Java Swing的猜数字小游戏(2)
  • 提升 Web 端 JavaScript 的可信度:WAICT 体系详解
  • Solon (可替换 SpringBoot)集成 Docker 实战:30分钟搞定轻量级应用容器化部署
  • 一次 React 项目 lock 文件冲突修复:从 Hook 报错到 Vite 配置优化
  • 记录一次USB虚拟网络问题排查
  • 学Simulink——基于高比例可再生能源渗透的复杂电网建模场景实例:大规模光伏并网对区域电网频率稳定影响研究
  • CANN Samples(十九):特色场景:机器人 AI 绘画 手写识别等
  • 毕设开源 深度学习YOLO交通路面缺陷检测系统(源码+论文)
  • 【URP】Unity[后处理]色彩调整ColorAdjustments