当前位置:   article > 正文

DOCKER实战部署SRS4.0流媒体服务器对接GB28181监控视频控制台

DOCKER实战部署SRS4.0流媒体服务器对接GB28181监控视频控制台

DOCKER实战部署SRS4.0流媒体服务器对接GB28181监控视频控制台

一、准备工作docker hub

二、下载镜像

docker pull hasspi/srs4.0
  • 1

三、安装 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
  • 1
  • 2
  • 3

四、进入docker 修改vim conf/push.gb28181.conf 配置文件
访问配置文件

docker exec -it srs4.0 /bin/bash
  • 1
vim conf/push.gb28181.conf
  • 1

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;
    }

}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67

配置SRS(GB28181)
SRS流媒体服务器中和GB28181相关的配置在conf目录下的push.gb28181.conf文件中,内容如下:

push gb28181 stream to SRS.

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;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137

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;
         }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62

五、重启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上行推流支持
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/297124
推荐阅读
相关标签
  

闽ICP备14008679号