RTSP转WebRTC视频协议解决方案

1、视频原理
浏览器或是音视频播放器播放互联网上视频文件,需要对接收数据经过以下几个步骤:

解析协议-> 解封装 -> 解码音视频 -> 音视频同步。

简单起见,可将视频数据分为以下四层如下表1-1所示,可结合图1-1了解其数据流在各阶段的处理流程

音视频流各协议层处理作用分别如下所述:

解协议

将流媒体协议的数据解析为标准的相应的封装格式数据。视音频在网络上传播的时候,常常采用各种流媒体协议,例如HTTP,RTMP,WebRTC或是MMS等等。这些协议在传输视音频数据的同时,也会传输一些信令数据。这些信令数据包括对播放的控制(播放,暂停,停止),或者对网络状态的描述等。解协议的过程中会去除掉信令数据而只保留视音频数据。例如,采用RTMP协议传输的数据,经过解协议操作后,输出FLV格式的数据。

解封装

将输入的封装格式的数据,分离成为音频流压缩编码数据和视频流压缩编码数据。封装格式种类很多,例如MP4,MKV,RMVB,TS,FLV,AVI等等,它的作用就是将已经压缩编码的视频数据和音频数据按照一定的格式放到一起。例如,FLV格式的数据,经过解封装操作后,输出H.264编码的视频码流和AAC编码的音频码流。

解码

将视频/音频压缩编码数据,解码成为非压缩的视频/音频原始数据。音频的压缩编码标准包含AAC,MP3,AC-3等等,视频的压缩编码标准则包含H.264,MPEG2,VC-1等等。解码是整个系统中最重要也是最复杂的一个环节。通过解码,压缩编码的视频数据输出成为非压缩的颜色数据,例如YUV420P,RGB等等;压缩编码的音频数据输出成为非压缩的音频抽样数据,例如PCM数据。

视音频同步

根据解封装模块处理过程中获取到的参数信息,同步解码出来的视频和音频数据,并将视频音频数据送至系统的显卡和声卡播放出来

2、系统架构
实现视频端到端播放,整个数据流经过四个组件: 推流端(ffmpeg)、播放端(浏览器)、流媒体服务器和协议转换器。具体系统架构图如下:

3、代码实践
3.1 流媒体服务器
流媒体服务器选用开源代码mediamtx

注意

构建二进制文件,需要golang环境,版本需要1.18.x以上;

可以关闭mediamtx原生的webrtc播放功能(webrtcDisable: yes),只提供以RTSP协议方式读取流。
 

$make binaries
$./mediatx
3.2 协议转换器

将以RTSP协议读取视频流并转换为WebRTC协议视频流传给浏览器。 

3.3 推送端

利用ffmpeg循环读取视频流并加上时间戳,具体命令如下

 $ffmpeg -re -stream_loop -1 -i oceans.mp4 -vf "settb=AVTB,\n            setpts='trunc(PTS/1K)*1K+st(1,trunc(RTCTIME/1K))-1K*trunc(ld(1)/1K)',\n            drawtext=fontsize=60:text='%{localtime}.%{eif\:1M*t-1K*trunc(t*1K)\:d}'" -x264-params "keyint=10:min-keyint=1" -crf 26 -c:v libx264 -an -b:v 500k -bufsize 500k -preset ultrafast  -rtsp_transport tcp -f rtsp rtsp://127.0.0.1:8554/mystream

3.4 浏览器端
前端代码借鉴mediamtx项目内关于原生支持webrtc的前端浏览代码。

注意

改造websocket连接请求参数格式,通过传递topic请求参数来表征播放流的path路径

4、总结
本文重点在于阐述工程实践部分,从整体勾勒视频流端到端数据流以及简要概述相关组件的功能,而理论描述方面则简略提及视频相关协议,如RTP/RCTP、SDP、RTSP、WebRTC等,还有相关技术概念,如NAT、P2P和ICE candidate等。在实现RTSP协议转换WebRTC协议模块方面则借鉴模仿开源组件mediamtx中WebRTC服务模块处理代码,并结合开源的gortsplib库糅合而成。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值