GB28181推流
介绍
ZLMediaKit 支持 GB28181 的 ps-rtp 推流,支持的编码格式分别为 h264/h265/aac/g711/opus
。 在收到 GB28181 推流后,ZLMediaKit 会依次做以下事情:
- rtp 排序去重。
- rtp 解析成 ps 或 ts。
- ps 或 ts 解析成
h264/h265/aac/g711/opus
。 - 输入到复用器,生成 rtsp/rtmp/ts/fmp4 等格式,以便转换成其他协议或容器。
简单使用
ZLMediaKit 默认开启 10000 端口用于接收 UDP/TCP 的 GB28181 推流,由于国标推流不好测试,ZLMediaKit 同时也支持 rtp_mpegts 推流,代码会自适应判断是否为 ps 还是 ts。 所以如果大家没有摄像头的情况下,可以用 FFmpeg 简单测试,基本上体验跟国标推流并无二致。
ffmpeg 推流命令:
ffmpeg -re -i www/record/robot.mp4 -vcodec h264 -acodec aac -f rtp_mpegts rtp://127.0.0.1:10000
MediaServer 收到推流后的日志:
上图中,这个推流的 rtp ssrc 为 BFC2C622(16 进制打印),这个流的 app 为
rtp
, stream_id 为BFC2C622
,您可以根据wiki来组合成 url 并播放这个流。
需要指出的是,国标推流的 app 固定为 rtp,你只能通过代码来修改它,stream_id 为 rtp 流的 ssrc,这个是随机的,在 FFmpeg 中貌似没法控制。
另外,每次推流时,请更换 ssrc,否则 ZLMediaKit 发现推流端 ip 和端口变化后,会直接丢弃 rtp 包(现象如此issue);这样做的目的是为了防止两个设备使用同一个 ssrc 推流时互相干扰。
高阶使用
在推流给 10000 端口时,您可能发现有个缺陷,就是 stream_id 是 ssrc,比较抽象,可能还没法控制。
那么我们能否自定义 stream_id? 答案是肯定的,ZLMediaKit 通过restful api可以动态开启国标收流端口(同时支持 udp/tcp 模式)。
在使用 openRtpServer 接口动态开启国标收流端口后,这个端口只能产生一个流,也就是说,一个摄像头需要一个服务器端口用于接收国标推流。
- 以下是演示范例(postman 工具调用 openRtpServer 接口创建随机端口):
- 然后启动 FFmpeg 推流
ffmpeg -re -i www/record/robot.mp4 -vcodec h264 -acodec aac -f rtp_mpegts rtp://127.0.0.1:50077
以下是推流后注册的服务器日志
需要指出的是,如果 openRtpServer 接口创建的端口一直没收到流(或者解析不出流),那么会自动关闭和释放。
调试文件生成
如果你的 MediaServer 能收到国标推流,但是未出现媒体注册
相关日志,那么有可能是流有些异常,你可以修改配置文件rtp_proxy.dumpDir
指定调试文件导出目录, 这样 ZLMediaKit 会把国标流导出到该文件夹,就像这样:
你可以直接用 ffplay 播放mp2/video后缀的文件
,rtp
后缀的文件,你可以用测试工具test_rtp
调试,或者你可以把它分享给其他人帮你分析原因。
让 ZLMediaKit 往其他国标服务器推流
你可以使用restful api让 ZLMediaKit 生成国标流并往其他服务器推送,支持其他任何已注册的流转国标流。
- postman 调用 startSendRtp 接口推送国标流:
- 上图中是推送国标流给自己,当然你也可以推送给其他服务器,支持 udp/tcp 方式推流。
性能
GB28181 的推流性能测试,请参考:#961
丢包问题调试
如果在测试 GB28181 UDP 推流时,频繁打印以下日志:
请查看此issue,特别提示,wifi 情况下,由于无线网络干扰严重,丢包问题很可能确实是网络质量差导致的。