news 2026/4/23 14:38:27

freeswitch的proxy_media模式下video流的问题与修正

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
freeswitch的proxy_media模式下video流的问题与修正

概述

freeswitch是一款简单好用的VOIP开源软交换平台。

测试过程中发现fs的proxy_media模式的一个bug,就是video媒体流的转发处理有问题。

环境

CentOS 7.9

freeswitch 1.6.20

问题

fs配置为proxy_media模式,A路发起呼叫,A路远端的sdp中有audio和video媒体信息。

a642b367-754c-492e-b227-87f94e8010c7 m=audio 16394 RTP/AVP 8 18 101

a642b367-754c-492e-b227-87f94e8010c7 m=video 16396 RTP/AVP 99

fs处理拨号计划后,发起B路呼叫,B路的sdp继承了A路的sdp,本地sdp信息如下。

a642b367-754c-492e-b227-87f94e8010c7 m=audio 54398 RTP/AVP 8 18 101

a642b367-754c-492e-b227-87f94e8010c7 m=video 54400 RTP/AVP 99

B路收到终端的183sdp信息,处理媒体信息后,本地sdp修改如下。

a642b367-754c-492e-b227-87f94e8010c7 m=audio 54398 RTP/AVP 8 18 101

a642b367-754c-492e-b227-87f94e8010c7 m=video 44622 RTP/AVP 99

其中B路本端的audio端口为54398,video的端口从54400修改为了44622。

结果就是,B路本端的video媒体流从44622端口发到远端,远端的video媒体流送到本地的54400,造成媒体流擦肩而过。

查看switch_core_media.c的switch_core_media_patch_sdp函数,在处理video信息时,强制重选了video本地端口,而audio端口处理正常。

switch_core_media_choose_port(session, SWITCH_MEDIA_TYPE_VIDEO, 1);

查看调用堆栈,mod_sofia模块在处理183sdp的流程中,proxy_media模式下会主动调用“switch_core_media_patch_sdp”这一并无必要的操作。

修复

修改mod_sofia模块的sofia.c文件,屏蔽“switch_core_media_patch_sdp”操作。

} else if (switch_channel_test_flag(channel, CF_PROXY_MEDIA)) {

switch_channel_set_variable(channel, SWITCH_ENDPOINT_DISPOSITION_VARIABLE, "PROXY MEDIA");

// switch_core_media_patch_sdp(tech_pvt->session);

if (sofia_media_activate_rtp(tech_pvt) != SWITCH_STATUS_SUCCESS) {

nua_respond(nh, SIP_488_NOT_ACCEPTABLE, TAG_END());

switch_channel_hangup(channel, SWITCH_CAUSE_INCOMPATIBLE_DESTINATION);

} else{

switch_channel_mark_pre_answered(channel);

}

测试

重新编译mod_sofia模块后,测试视频流程,媒体协商正常,B路本地端口协商正常,媒体流正常转发。

总结

未经过充分测试,不清楚对其他业务流程的影响。

经过修改后的fs虽然可以正常转发rtp媒体流,但是仍然无法转发rtcp消息,在网络较差的情况下,视频媒体流无法利用rtcp的特性修复视频卡顿。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 13:36:40

RepRapFirmware开源固件:3D打印机的智能控制核心终极指南

RepRapFirmware开源固件:3D打印机的智能控制核心终极指南 【免费下载链接】RepRapFirmware OO C RepRap Firmware 项目地址: https://gitcode.com/gh_mirrors/re/RepRapFirmware 在当今蓬勃发展的3D打印领域,一个高效稳定的控制固件是实现高质量打…

作者头像 李华
网站建设 2026/4/23 13:30:49

鸿蒙投屏神器HOScrcpy:零基础快速上手完整教程

鸿蒙投屏神器HOScrcpy:零基础快速上手完整教程 【免费下载链接】鸿蒙远程真机工具 该工具主要提供鸿蒙系统下基于视频流的投屏功能,帧率基本持平真机帧率,达到远程真机的效果。 项目地址: https://gitcode.com/OpenHarmonyToolkitsPlaza/HO…

作者头像 李华
网站建设 2026/4/23 13:30:05

18、Linux系统磁盘使用查询与软件安装管理全攻略

Linux系统磁盘使用查询与软件安装管理全攻略 1. 磁盘使用查询 在Linux系统中,有时候我们只需要知道某个目录的总使用空间,而不需要其所有子目录的详细信息。这时,可以使用 du 命令结合 -s 选项来实现。例如: $ cd music $ du -hs 2.6G .这里, du -hs 命令简洁…

作者头像 李华
网站建设 2026/4/23 12:29:14

【Redis从入门到精通,看这一篇就够了!】

在当今的后端开发领域,Redis绝对是一个绕不开的“明星中间件”。它以超高的性能、丰富的数据类型和灵活的使用场景,成为缓存、分布式锁、消息队列等场景的首选方案。很多小白在接触Redis时,会被“集群”“持久化”“红锁”这些概念吓倒&#…

作者头像 李华
网站建设 2026/4/23 12:30:27

重绘和重排怎么触发?怎么优化?

重绘(Repaint) 定义:元素样式改变但不影响布局时触发,仅重新绘制元素外观,不改变DOM几何结构。常见场景:修改color、background-color、opacity、box-shadow等。 重排(Reflow) 定义&…

作者头像 李华
网站建设 2026/4/23 13:54:55

[Java 并发编程] 线程池

线程池 1. 初识线程池 ​ 我们之所以引入线程,是因为进程的创建和销毁过于重量,而线程可以共享更多内存资源,因此成为显著提高效率的手段。但线程也是 OS 分配的,也涉及用户态和内核态的切换,也是一种很有限的资源&a…

作者头像 李华