SRS流媒体服务器之RTC播放环境搭建

环境概述

srs版本

复制代码
commit 44f0c36b61bc7c3a1d51cb60be0ec184c840f09d
Author: winlin <winlin@vip.126.com>
Date:   Wed Aug 2 10:34:41 2023 +0800

    Release v4.0-r5, 4.0 release5, v4.0.271, 145574 lines.

rtc.conf

复制代码
# WebRTC streaming config for SRS.
# @see full.conf for detail config.

listen              1935;
max_connections     1000;
daemon              off;
srs_log_tank        console;

http_server {
    enabled         on;
    listen          8080;
    dir             ./objs/nginx/html;
}

http_api {
    enabled         on;
    listen          1985;
}
stats {
    network         0;
}
rtc_server {
    enabled on;
    listen 8000; # UDP port
    # @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#config-candidate
    candidate $CANDIDATE;
}

vhost __defaultVhost__ {
    rtc {
        enabled     on;
        # @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtmp-to-rtc
        rtmp_to_rtc on;
        # @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtc-to-rtmp
        rtc_to_rtmp on;
    }
    http_remux {
        enabled     on;
        mount       [vhost]/[app]/[stream].flv;
    }
    play {
        mw_latency 100;
        mw_msgs 4;
        queue_length 10;
        send_min_interval 10.0;
        reduce_sequence_header on;
    }

}

srs内置推流文件

srs源代码是自带测试文件的,可使用ffmpeg进行推流尝试。

复制代码
ffmpeg -re -i ./doc/source.200kbps.768x320.flv -c copy -f flv rtmp://192.168.126.129/live/livestream

RTC播放器问题

由于是早期版本,rtc和rtmp播放地址不同。

rtmp播放地址:

复制代码
http://192.168.126.129:8080/players/srs_player.html
http://192.168.126.129:8080/players/rtc_publisher.html

webrtc拉流播放地址:

复制代码
http://192.168.126.129:8080/players/rtc_player.html

webrtc拉流播放问题

在使⽤Chrome浏览器推流时会报:TypeError: Cannot read property 'getUserMedia' of undefined 错误,这个错误主要是https证书问题。

解决办法:先把chrome完全退出,右击桌⾯上chrome的快捷键,点击属性,在⽬标⼀栏添加如下内容, 记着有个英⽂空格,IP换成⾃⼰的。

复制代码
"C:\Program Files\Google\Chrome\Application\chrome.exe" --ignore-certificate-errors --allow-running-insecure-content --unsafely-treat-insecure-origin-as-secure=http://192.168.126.129:8080"

vlc如何播放?

问题:由于VLC播放器原生不支持WebRTC协议webrtc://协议头),直接使用VLC播放SRS的WebRTC流会遇到兼容性问题。

复制代码
http_server {
    enabled on;
    listen 8080;  # HTTP服务端口
}

vhost __defaultVhost__ {
    http_remux {
        enabled on;   # 启用HTTP-FLV/HLS
        mount [vhost]/[app]/[stream].flv;
    }
}

SRS支持将WebRTC流自动转换为HTTP-FLVHLS协议,可通过VLC直接播放转换后的地址。

获取可播放地址

WebRTC流地址 webrtc://192.168.126.129/live/livestream

对应以下协议地址:

HTTP-FLV: http://192.168.126.129:8080/live/livestream.flv

HLS: http://192.168.126.129:8080/live/livestream.m3u8

学习资料分享

40voice · GitHub

相关推荐
~央千澈~3 天前
优雅草蜻蜓R实时音视频会议系统云原生私有化部署方案深度解析-优雅草卓伊凡|贝贝|clam|麻子|夜辰
webrtc·实时音视频
不老刘4 天前
基于LiveKit Go 实现腾讯云实时音视频功能
golang·腾讯云·实时音视频
NYFEA6 天前
RTC实时时钟DS1339U-33国产替代FRTC1339M
实时音视频
~央千澈~6 天前
优雅草蜻蜓T语音会议系统私有化部署方案与RTC技术深度解析-优雅草卓伊凡|clam
webrtc·实时音视频·rtc
许白掰6 天前
【stm32】HAL库开发——CubeMX配置RTC,单片机工作模式和看门狗
stm32·单片机·嵌入式硬件·学习·实时音视频
从后端到QT7 天前
SRS流媒体服务器(8)源码分析之rtc/rtmp互相转码详解
运维·服务器·实时音视频
音视频牛哥8 天前
计算机视觉的新浪潮:扩散模型(Diffusion Models)技术剖析与应用前景
人工智能·计算机视觉·ai·音视频·实时音视频·扩散模型
从后端到QT8 天前
SRS流媒体服务器之本地测试rtc推流bug
bug·实时音视频
云资源服务商20 天前
腾讯云IM即时通讯:开启实时通信新时代
云计算·腾讯云·实时音视频
c7_ln1 个月前
嵌入式里的时间魔法:RTC 与 BKP 深度拆解
stm32·嵌入式硬件·实时音视频·江协科技