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

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

头图-77

 

概述

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的特性修复视频卡顿。

 

空空如常

求真得真

 

http://www.hskmm.com/?act=detail&tid=33170

相关文章:

  • DNS 相关
  • 2025 年无锡专线物流公司最新推荐排行榜:聚焦个性化运输解决方案,精选优质服务商往返无锡/冷链无锡/公路无锡/大件无锡专线物流公司推荐
  • Dubbo入门-通过spring-boot来动手实践
  • 使用ceph rdb做k8s后端存储(ceph-csi storageclass
  • 2025 最新火烧板源头厂家推荐排行榜:自有矿山加持 + 品质卓越,芝麻灰 / 五莲花等石材采购优选指南
  • 【IEEE出版、吉首大学主办】第二届智能机器人与自动控制国际学术会议 (IRAC 2025)
  • 第三次课动手动脑合集
  • 2025 年火山石厂家最新推荐排行榜:聚焦自有矿藏与全自动生产,涵盖滤料填料等多品类企业权威指南人工湿地填料/人工湿地滤料/黑色/红色火山石厂家推荐
  • 【SPIE出版、往届已检索】第十届能源系统、电气与电力国际学术会议 (ESEP 2025)
  • 2025 防火隔断厂家最新推荐排行榜:甲级防火玻璃隔断厂家深度测评,精选优质品牌助力采购决策
  • 作业3
  • 2025-10-17
  • 2025 年最新推荐!国内优质球墨铸铁管厂家排行榜,涵盖市政 / 给水 / 水利工程用管,助力采购高效选材
  • Nexpose 8.24.0 for Linux Windows - 漏洞扫描
  • 用于博客美化的测试(后面再更新)
  • 2025 年最新留学中介机构推荐排行榜:覆盖英美澳加新等热门地,专业团队护航学子海外深造之选
  • 有趣评测小程序系统:开启视频与答题变现新创业风口
  • 看图猜成语达人小程序:一站式趣味与变现解决方案
  • Metasploit Pro 4.22.8-20251014 (Linux, Windows) - 专业渗透测试框架
  • 设备租赁归还小程序系统:免人工化租赁管理解决方案
  • Navcat如何上传数据大的sql文件?
  • 实测PaddleOCR-VL:文心4.5最强衍生模型如何重构文档处理效率
  • 高考语文 词类活用
  • 使用Scalar.AspNetCore来管理你的OpenApi
  • 2025年市面上景观灯品牌推荐排行榜:权威解析与选择指南
  • 设计社会意识算法的三大关键问题
  • 【转】[C#] 项目里的配置文件与选项对比
  • Windows定时任务 每隔一段时间(最小到秒级)执行一次指定的Python脚本
  • 深入解析米尔全志T536核心板的实时性技术突破
  • 2025年西安买房终极指南:十大热门楼盘排名揭秘