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

相关推荐
危桥带雨1 天前
RTC理论知识
stm32·单片机·嵌入式硬件·实时音视频
rit84324991 天前
基于STM32的RTC(实时时钟)程序设计与实现
stm32·嵌入式硬件·实时音视频
nibabaoo6 天前
前端开发攻略---H5页面手机获取摄像头权限回显出画面并且同步到PC页面
javascript·websocket·实时音视频·实时同步·录制
拉拉尼亚8 天前
WebRTC 完全指南:原理、教程与应用场景
前端·typescript·实时音视频
王家视频教程图书馆11 天前
另外还有一个小问题,就是两个部手机进行测试的时候,进行外部 RTC 通话的时候。我使用 QQ 音乐播放背景音乐,但是背景音乐没有加上。有冲突
实时音视频
海水冷却15 天前
2026年实时音视频服务计费模式指南
实时音视频
番茄灭世神17 天前
PN学堂GD32教程第8篇——RTC
实时音视频
runner365.git17 天前
RTC实现VoiceAgent(二)
大模型·webrtc·实时音视频·voiceagent
xuxie9917 天前
N18 RTC
单片机·嵌入式硬件·实时音视频
runner365.git18 天前
RTC会议实时翻译系统
实时音视频