Usage
1. 編譯SRS
編譯SRS,需要切換到Develop分支,並開啟gb28181功能:
git checkout develop &&
./configure --with-gb28181 &&
make clean && make
然后使用配置文件conf/push.gb28181.conf 啟動:
./objs/srs -c conf/push.gb28181.conf
2. 配置攝像頭
先找到攝像頭IP
使用海康的網絡工具SADP https://www.hikvision.com/cn/download_more_393.html?_blank

然后登錄到攝像頭網頁后台按下面的操作配置攝像頭,推流到SRS:
最后,觀看RTMP流:rtmp://localhost:1935/live/34020000001320000001
Remark: 海康攝像頭默認會連接螢石雲,可以在APP上看到攝像頭的內網IP,然后訪問這個IP進入管理頁面。其他攝像頭也有對應辦法,可以配置攝像頭使用GB28181推流。
Remark:如果看不了流,請確認你的服務器IP,還有流名稱也就是
視頻通道編碼ID是否正確。
Remark: 默認不開啟聲音,如果需要開啟聲音,要打開配置
audio_enable on;,並且在攝像頭的音頻配置中開啟。
Remark: 若需要開啟音頻,需要將編碼設置為AAC,同時采樣率設置為44100HZ,否則Flash可能無法觀看。
以上這段應用說明在SRS develop分支的issues里
https://github.com/ossrs/srs/issues/1500
3. 添加http-flv和webrtc預覽支持
整合
http.flv.live.conf
rtc.conf
push.gb28181.conf
得到的配置文件,支持rtmp/gb28181上行推流,和rtmp/http-flv/gb28181/webrtc下行拉流
# push gb28181 stream to SRS.
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;
# 轉發流到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 off;
# 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__ {
http_remux {
enabled on;
mount [vhost]/[app]/[stream].flv;
}
rtc {
enabled on;
bframe discard;
}
}
注意:host 配置,$CANDIDATE是自動獲取eth0的IP,如果部署到公網,將$CANDIDATE改成公網IP
啟動 srs
./objs/srs -c conf/push.gb28181.conf
啟動 srs_player
在srs/trunk/research/players目錄運行一個http服務
python -m SimpleHTTPServer 9000
進入播放器 172.16.23.240:9000
可以預覽rtmp

可以預覽webrtc

可以分別預覽rtmp和webrtc流
支持預覽,后綴是 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秒左右。
4. 添加webrtc上行推流支持
等SRS夏立新大佬提交代碼了再來驗證

