Pre-requisites:
- Go 1.23+
- Node 20+
Then run
git clone https://github.com/ossrs/srs-sip
cd srs-sip
./build.sh
If on Windows
./build.bat
Run the program:
./objs/srs-sip -c conf/config.yaml
Use docker
docker run -id -p 1985:1985 -p 5060:5060 -p 8025:8025 -p 9000:9000 -p 5060:5060/udp -p 8000:8000/udp --name srs-sip --env CANDIDATE=your_ip ossrs/srs-sip:alpha
- 1985/TCP: SRS监听,SRS-SIP通过此端口调用SRS的API
- 9000/TCP: SRS监听,用于接收国标推送的媒体流
- 8000/UDP:SRS监听,用于RTC播放
- 5060/TCP:SRS-SIP监听,用于国标注册
- 8025/TCP:SRS-SIP监听,用于前端页面
- 注册流程
sequenceDiagram
Device ->> SRS-SIP : 1. Register
SRS-SIP ->> Device : 2. 401
Device ->> SRS-SIP : 3. Register
SRS-SIP ->> Device : 4. 200 OK
- 播放视频流程 Player、SRS-SIP、SRS Server和GB28181 Device的交互图如下:
sequenceDiagram
Player ->> SRS-SIP : 1. Play Request(with id)
SRS-SIP ->> SRS : 2. Publish Request(with ssrc and id)
SRS ->> SRS-SIP : 3. Response(with port)
SRS-SIP ->> Device : 4. Invite(with port)
Device ->> SRS-SIP : 5. 200 OK
SRS-SIP ->> Player : 6. 200 OK(with url)
Device -->> SRS : Media Stream
Player ->> SRS : 7. Play
SRS -->> Player : Media Stream
Player ->> SRS-SIP : 8. Stop Request
SRS-SIP ->> SRS : 9. Unpublish Request
SRS-SIP ->> Device : 10. Bye
- 通过SRS-SIP提供的API接口
/srs-sip/v1/invite
,Player主动发起播放请求,携带设备的通道ID - SRS-SIP向SRS发起推流请求,携带SSRC和ID,SSRC是设备推流时RTP里的字段
- SRS响应推流请求,并返回收流端口。目前SRS仅支持TCP单端口模式,在配置文件
stream_caster.listen
中配置 - SRS-SIP通过GB28181协议向设备发起
Invite
请求,携带SRS的收流端口及SSRC - 设备响应成功
- SRS-SIP响应成功,携带URL,用于播放
- Player通过返回的URL进行拉流播放
- Player停止播放
- SRS-SIP通知SRS停止收流
- SRS-SIP通过设备停止推流
SRS-SIP 提供了完整的 HTTP API 接口,用于设备管理、视频流控制、PTZ控制等功能。
详细的API接口文档请参考:API接口文档
- 设备管理:获取设备列表、通道信息
- 视频流控制:发起视频邀请、暂停/恢复、调整播放速度
- PTZ控制:云台控制(上下左右、缩放)
- 录像查询:查询历史录像记录
- 媒体服务器管理:配置和管理媒体服务器
# 获取设备列表
curl -X GET "http://localhost:8025/srs-sip/v1/devices"
# 发起视频邀请
curl -X POST "http://localhost:8025/srs-sip/v1/invite" \
-H "Content-Type: application/json" \
-d '{
"device_id": "34020000001320000001",
"channel_id": "34020000001320000002",
"media_server_id": 1,
"play_type": 0
}'