news 2026/4/18 5:23:03

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/9 21:48:02

什么是品牌全案?

一、品牌全案的内涵:三大核心构成层一个完整的品牌全案,通常包含三个层层递进、环环相扣的板块:战略层:构建品牌的“大脑与心脏”这是全案的基石,解决“我是谁、为谁服务、为何存在”的根本问题。核心产出:…

作者头像 李华
网站建设 2026/4/16 11:20:03

无锡短视频创作电话

无锡短视频创作电话:企业如何通过专业代运营实现营销突破在数字化营销浪潮中,短视频已成为企业品牌传播和用户互动的重要渠道。对于无锡地区的企业而言,如何高效利用短视频创作提升市场影响力,成为亟待解决的问题。本文将深入探讨…

作者头像 李华
网站建设 2026/4/18 5:20:16

【光照】UnityURP渲染中的HDR

HDR 概述高动态范围(HDR)渲染是Unity通用渲染管线(URP)中的关键技术,它解决了传统低动态范围(LDR)渲染无法准确表现真实世界光照强度范围的问题。在真实世界中,光照强度的变化范围极大(从阴暗室内到阳光直射可达100,000:1),而传统8位LDR渲染只…

作者头像 李华
网站建设 2026/4/15 18:02:04

数据结构:有向无环图

有向无环图 资料:https://pan.quark.cn/s/43d906ddfa1b、https://pan.quark.cn/s/90ad8fba8347、https://pan.quark.cn/s/d9d72152d3cf 一、有向无环图的定义 有向无环图(Directed Acyclic Graph,简称DAG)是一类特殊的有向图&…

作者头像 李华
网站建设 2026/4/11 19:17:21

13、Linux 文件归档、压缩与查找实用指南(上)

Linux 文件归档、压缩与查找实用指南(上) 在当今数字化时代,我们面临着海量文件的管理挑战,无论是归档压缩以节省空间,还是快速准确地查找所需文件。Linux 提供了一系列强大的工具来应对这些问题,下面将为你详细介绍相关的操作和技巧。 1. 使用 tar 和 gzip 进行文件归…

作者头像 李华
网站建设 2026/4/17 18:44:59

微信小程序任务管理终极指南:5分钟打造高效待办系统

微信小程序任务管理终极指南:5分钟打造高效待办系统 【免费下载链接】weapp-todos 一个简单的任务清单小程序, awesome weapp demo, todos, todolist 项目地址: https://gitcode.com/gh_mirrors/we/weapp-todos 在快节奏的现代生活中,高效的任务管…

作者头像 李华