开源项目:https://github.com/ossrs/srs-docker#usagehtml
1.centos7安装编译git
Step1:拉git代码,切换到开发分支 git clone https://gitee.com/winlinvip/srs.oschina.git srs && cd srs/trunk && git remote set-url origin https://github.com/ossrs/srs.git && git pull Step2:切换到开发分支 git checkout develop && ./configure --with-gb28181 && make clean && make Step3:编辑push.gb28181.conf,好启动服务 ./objs/srs -c conf/push.gb28181.conf
push.gb28181.conf 配置文件github
# push gb28181 stream to SRS. listen 1935; max_connections 1000; daemon off; srs_log_tank console; http_api { enabled on; listen 1985; } stats { network 0; } stream_caster { enabled on; caster 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; # 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; # 是否开启rtp缓冲 # 开启以后能有效解决rtp乱序等问题 jitterbuffer_enable on; # 服务器主机号,能够域名或ip地址 # 也就是设备端将媒体发送的地址,若是是服务器是内外网 # 须要写外网地址, # 调用api建立stream session时返回ip地址也是host # $CANDIDATE 是系统环境变量,从环境变量获取地址,若是没有配置,用* # *表明指定stats network 的网卡号地址,若是没有配置network,默认则是第0号网卡地址 # TODO: https://github.com/ossrs/srs/pull/1679/files#r400917594 # host $CANDIDATE; host 10.10.9.200; #根据收到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; } } vhost __defaultVhost__ { }
2.检测服务端口是 sip:5060 api:1985 直播推流端口:1935docker
3.配置摄像头centos
4.检查API地址与端口1985是否生效,摄像头是否上线http://ossrs.net/players/srs_gb28181.htmlapi