104 lines
2.5 KiB
Markdown
104 lines
2.5 KiB
Markdown
# SRS-SIP
|
||
|
||
## Usage
|
||
|
||
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监听,用于前端页面
|
||
|
||
## Sequence
|
||
|
||
1. 注册流程
|
||
```mermaid
|
||
sequenceDiagram
|
||
Device ->> SRS-SIP : 1. Register
|
||
SRS-SIP ->> Device : 2. 401
|
||
Device ->> SRS-SIP : 3. Register
|
||
SRS-SIP ->> Device : 4. 200 OK
|
||
```
|
||
|
||
2. 播放视频流程
|
||
Player、SRS-SIP、SRS Server和GB28181 Device的交互图如下:
|
||
|
||
```mermaid
|
||
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
|
||
```
|
||
|
||
1. 通过SRS-SIP提供的API接口`/srs-sip/v1/invite`,Player主动发起播放请求,携带设备的通道ID
|
||
2. SRS-SIP向SRS发起推流请求,携带SSRC和ID,SSRC是设备推流时RTP里的字段
|
||
3. SRS响应推流请求,并返回收流端口。目前SRS仅支持TCP单端口模式,在配置文件`stream_caster.listen`中配置
|
||
4. SRS-SIP通过GB28181协议向设备发起`Invite`请求,携带SRS的收流端口及SSRC
|
||
5. 设备响应成功
|
||
6. SRS-SIP响应成功,携带URL,用于播放
|
||
7. Player通过返回的URL进行拉流播放
|
||
8. Player停止播放
|
||
9. SRS-SIP通知SRS停止收流
|
||
10. SRS-SIP通过设备停止推流
|
||
|
||
|
||
## API 接口
|
||
|
||
- 请求与响应数据格式为JSON
|
||
- 所有响应的统一结构为:
|
||
```json
|
||
{
|
||
"code": 0,
|
||
"data": {}
|
||
}
|
||
```
|
||
|
||
错误响应示例:
|
||
```
|
||
{
|
||
"code": 500,
|
||
"data": {
|
||
"msg": "error message"
|
||
}
|
||
}
|
||
```
|
||
|
||
### 接口列表
|
||
|
||
暂无,请参考demo。
|