赞
踩
DOCKER实战部署SRS4.0流媒体服务器对接GB28181监控视频控制台
一、准备工作docker hub
二、下载镜像
docker pull hasspi/srs4.0
三、安装 SRS
CANDIDATE="192.168.110.115"
docker run -p 1935:1935 -p 1985:1985 -p 8080:8080 -p 5060:5060 -p 5060:5060/udp -p 9000:9000/udp --name srs4.0 --network host hasspi/srs4.0 ./objs/srs -c conf/push.gb28181.conf
四、进入docker 修改vim conf/push.gb28181.conf 配置文件
访问配置文件
docker exec -it srs4.0 /bin/bash
vim conf/push.gb28181.conf
host $CANDIDATE; 将 $CANDIDATE 修改为自己的IP例如host 192.168.10.111;后保存 配置文件
listen 1935; #必须有,rtmp协议,公网必须开放这个端口 max_connections 1000; daemon off; srs_log_tank console; http_api { enabled on; #必须有,webrtc播放和推流需要这个端口 listen 1985; } http_server { enabled on; listen 8080; #开发阶段需要,这个是srs自带的web页面, dir ./objs/nginx/html; } srt_server { enabled on; listen 10080; maxbw 1000000000; connect_timeout 4000; latency 20; peerlatency 20; recvlatency 20; } rtc_server { enabled on; listen 8000; candidate 公网IP; #配置上公网IP, } # @doc https://github.com/ossrs/srs/issues/1147#issuecomment-577607026 vhost __defaultVhost__ { #这个是rtc配置,开启rtmp转rtc rtc { enabled on; rtmp_to_rtc on; rtc_to_rtmp on; } #开启http-flv http_remux { enabled on; mount [vhost]/[app]/[stream].flv; } #rtmp的低时延配置 tcp_nodelay on; min_latency on; play { gop_cache off; queue_length 10; mw_latency 100; } publish { mr off; } }
配置SRS(GB28181)
SRS流媒体服务器中和GB28181相关的配置在conf目录下的push.gb28181.conf文件中,内容如下:
listen 1935; ## RTMP服务端口号,可用于拉取28181的推流数据 max_connections 1000; daemon off; srs_log_tank console; ## 表示服务在控制台运行,方便看日志 http_api { ## SRS提供了标准的HTTP API接口,可用于触发GB28181-SIP信令 enabled on; listen 1985; } http_server { ## HTTP Server用于支持HLS拉流 enabled on; listen 8080; } stats { network 0; } stream_caster { enabled on; caster gb28181; ## 打开GB28181功能 # 转发流到rtmp服务器地址与端口 # TODO: https://github.com/ossrs/srs/pull/1679/files#r400875104 # [stream] is VideoChannelCodecID(视频通道编码ID) for sip # 自动创建的道通[stream] 是‘chid[ssrc]’ [ssrc]是rtp的ssrc # [ssrc] rtp中的ssrc output rtmp://127.0.0.1:1935/live/[stream]; # 接收设备端rtp流的多路复用端口 listen 9000; # 多路复用端口类型,on为tcp,off为udp # 默认:on tcp_enable on; # rtp接收监听端口范围,最小值 rtp_port_min 58200; # rtp接收监听端口范围,最大值 rtp_port_max 58300; # 是否等待关键帧之后,再转发, # off:不需等待,直接转发 # on:等第一个关键帧后,再转发 wait_keyframe on; # rtp包空闲等待时间,如果指定时间没有收到任何包 # rtp监听连接自动停止,发送BYE命令 rtp_idle_timeout 30; # 是否转发音频流 # 目前只支持aac格式,所以需要设备支持aac格式 # on:转发音频 # off:不转发音频,只有视频 # *注意*!!!:flv 只支持11025 22050 44100 三种 # 如果设备端没有三种中任何一个,转发时为自动选择一种格式 # 同时也会将adts的头封装在flv aac raw数据中 # 这样的话播放器为自动通过adts头自动选择采样频率 # 像ffplay, vlc都可以,但是flash是没有声音, # 因为flash,只支持11025 22050 44100 audio_enable off; # 服务器主机号,可以域名或ip地址 # 也就是设备端将媒体发送的地址,如果是服务器是内外网 # 需要写外网地址, # 调用api创建stream session时返回ip地址也是host # $CANDIDATE 是系统环境变量,从环境变量获取地址,如果没有配置,用* # *代表指定stats network 的网卡号地址,如果没有配置network,默认则是第0号网卡地址 # TODO: https://github.com/ossrs/srs/pull/1679/files#r400917594 host $CANDIDATE; #根据收到ps rtp包自带创建rtmp媒体通道,不需要api接口创建 #rtmp地址参数[stream] 就是通道id 格式chid[ssrc] auto_create_channel off; sip { # 是否启用srs内部sip信令 # 为on信令走srs, off 只转发ps流 enabled on; # sip监听udp端口 listen 5060; # SIP server ID(SIP服务器ID). # 设备端配置编号需要与该值一致,否则无法注册 serial 34020000002000000001; # SIP server domain(SIP服务器域) realm 3402000000; # 服务端发送ack后,接收回应的超时时间,单位为秒 # 如果指定时间没有回应,认为失败 ack_timeout 30; # 设备心跳维持时间,如果指定时间内(秒)没有接收一个心跳 # 认为设备离线 keepalive_timeout 120; # 注册之后是否自动给设备端发送invite # on: 是 off 不是,需要通过api控制 auto_play on; # 设备将流发送的端口,是否固定 # on 发送流到多路复用端口 如9000 # off 自动从rtp_mix_port - rtp_max_port 之间的值中 # 选一个可以用的端口 invite_port_fixed on; # 向设备或下级域查询设备列表的间隔,单位(秒) # 默认60秒 query_catalog_interval 60; } } rtc_server { enabled on; # Listen at udp://8000 listen 8000; # # The $CANDIDATE means fetch from env, if not configed, use * as default. # # The * means retrieving server IP automatically, from all network interfaces, # @see https://github.com/ossrs/srs/issues/307#issuecomment-599028124 candidate $CANDIDATE; } vhost __defaultVhost__ { rtc { ## 打开WebRTC功能 enabled on; bframe discard; } http_remux { ## 打开HTTP-Flv功能 enabled on; mount [vhost]/[app]/[stream].flv; } }
srs4.0配置文件
listen 1935; max_connections 1000; daemon off; srs_log_tank console; http_api { enabled on; listen 1985; } http_server { enabled on; listen 8080; dir ./objs/nginx/html; } stats { network 0; } stream_caster { enabled on; caster gb28181; # TODO: https://github.com/ossrs/srs/pull/1679/files#r400875104 output rtmp://127.0.0.1:1935/live/[stream]; listen 9000; rtp_port_min 58200; rtp_port_max 58300; wait_keyframe on; rtp_idle_timeout 30; audio_enable off; jitterbuffer_enable on; # TODO: https://github.com/ossrs/srs/pull/1679/files#r400917594 host 139.198.177.131; auto_create_channel off; sip { enabled on; listen 5060; serial 34020000002000000001; realm 3402000000; ack_timeout 30; keepalive_timeout 120; auto_play on; invite_port_fixed on; query_catalog_interval 60; } } vhost defaultVhost { rtc { enabled on; bframe discard; } hls { enabled on; hls_path ./objs/nginx/html; hls_fragment 10; hls_window 30; } http_remux { enabled on; mount [vhost]/[app]/[stream].flv; } }
五、重启docker镜像
六、GB28181海康设备配置在这里插入图片描述
七、webui控制台 :
http://192.168.110.115:1985/console/ng_index.html#/streams
支持预览,后缀是 id@channel
rtmp://172.16.23.240:1935/live/34020000001320000001@34020000001320000001
http://172.16.23.240:8080/live/34020000001320000001@34020000001320000001.flv
webrtc://172.16.23.240:1985/live/34020000001320000001@34020000001320000001
推荐webrtc预览,延迟非常小,局域网在毫秒级,甚至500ms以内,外网还没验证,其他人验证的在1秒左右。
添加webrtc上行推流支持
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。