srs服务器搭建

git clone https://gitee.com/siguohui/srs5.git srs
cd srs/trunk
./configure && make -j 2

启动  ./objs/srs -c conf/srs.conf

需要开通端口

UDP    8000
TCP    1985
TCP    1935
TCP    8080

打开网址
http://{SRS服务器所在ip}:8080/players/rtc_publisher.html
srs服务器搭建_第1张图片

这时推流是不行的, 原因就是浏览器要求使用webrtc时需要https
安装Nginx并openssl生成证书
srs服务器搭建_第2张图片
srs服务器搭建_第3张图片

https://gitee.com/winlinvip/srs.oschina
https://gitee.com/ossrs/srs
https://gitee.com/winlinvip/srs-wiki/wikis/v4_CN_Build
https://github.com/ossrs/flutter_live
https://gitee.com/winlinvip/srs-bench
ffmpeg推流

./ffmpeg -re -i ../srs-4.0release/trunk/doc/source.200kbps.768x320.flv 
-vcodec copy -acodec copy -f flv -y rtmp://192.168.198.128:1935/live/livestream
vlc播放rtmp流
rtmp://192.168.198.128:1935/live/livestream
可以直接打开chrome浏览器
http://192.168.198.128:8080/players/rtc_player.html
即可看到srs自带的测试页面
在RTC播放器上输入url
webrtc://192.168.198.128/live/livestream

ffmpeg -re -i  time.flv  -vcodec copy -acodec copy  -f flv -y rtmp://192.168.32.128/live/livestream
ffplay rtmp://192.168.32.128/live/livestream

28181

git checkout develop &&
./configure --with-gb28181 && 
make clean && make
./objs/srs -c conf/push.gb28181.conf 

./objs/srs -c conf/rtc2rtmp.conf
配置摄像头

先找到摄像头IP

使用海康的网络工具SADP https://www.hikvision.com/cn/download_more_393.html?_blank
srs服务器搭建_第4张图片
然后登录到摄像头网页后台按下面的操作配置摄像头,推流到SRS:
srs服务器搭建_第5张图片
最后,观看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

添加http-flv和webrtc预览支持

整合

http.flv.live.conf

rtc.conf

push.gb28181.conf

得到的配置文件,支持rtmp/gb28181上行推流,和rtmp/http-flv/gb28181/webrtc下行拉流
最后,观看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

  1. 添加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 配置, C A N D I D A T E 是 自 动 获 取 e t h 0 的 I P , 如 果 部 署 到 公 网 , 将 CANDIDATE是自动获取eth0的IP,如果部署到公网,将 CANDIDATEeth0IPCANDIDATE改成公网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
srs服务器搭建_第6张图片
可以预览webrtc
srs服务器搭建_第7张图片
可以分别预览rtmp和webrtc流
srs服务器搭建_第8张图片
支持预览,后缀是 id@channel

rtmp://172.16.23.240:1935/live/34020000001320000001@34020000001320000001

http://172.16.23.240:8080/live/[email protected]

webrtc://172.16.23.240:1985/live/34020000001320000001@34020000001320000001

推荐webrtc预览,延迟非常小,局域网在毫秒级,甚至500ms以内,外网还没验证,其他人验证的在1秒左右。

你可能感兴趣的:(android,android)