SRS使用推流,拉流,连接客户端(一)

SRS (Simple Realtime Server) | SRS (ossrs.net)

1. 安装

1.1 github 获取源码

git clone https://github.com/ossrs/srs.git

1.2 编译

1.2.1 关闭防火墙和 selinux

先关闭防火墙,防止有时候启动没有问题,但是就是看不了。

Centos6.x 下关闭防火墙和 selinux 的命令:

# disable the firewall
sudo /etc/init.d/iptables stop
sudo /sbin/chkconfig iptables off

selinux也需要disable,运行命令getenforce,若不是Disabled,执行下面的步骤:

  1. 编辑配置文件:sudo vi /etc/sysconfig/selinux
  2. 把SELINUX的值改为disabled:SELINUX=disabled
  3. 重启系统:sudo init 6

Ubuntu 下关闭防火墙的命令为:

ufw disable

Ubuntu 下默认没有安装 selinux,需要手动安装。

1.2.2 编译
./configure && make

指定配置文件,即可启动SRS

./objs/srs -c conf/srs.conf

核心协议了解一下

2. 部署

SRS 官方详细文档

2.1 RTMP 部署实例

RTMP部署实例

假设服务器的IP是:192.168.1.170

2.1.1 编写SRS配置文件

SRS 只需要配置 vhost 和帧听端口,以及支持的最大连接数,就可以支持 RTMP:

# conf/rtmp.conf
listen              1935
max_connextions     1000
daemon              off;
srs_log_tank        console;
vhost __defaultVhost__ {
}
2.1.2 启动 SRS
./objs/srs -c conf/rtmp.conf
2.1.3 推送RTMP流
  1. 使用FFMPEG命令推流:
for((;;)); do \
    ./objs/ffmpeg/bin/ffmpeg -re -i ./doc/source.200kbps.768x320.flv \
    -vcodec copy -acodec copy \
    -f flv -y rtmp://192.168.1.170/live/livestream; \
    sleep 1; \
done
  1. 使用FMLE推流,在FMS URL中输入vhost/app,在Stream中输入流名称。譬如:
# 譬如RTMP流:rtmp://192.168.1.170/live/livestream
FMS URL: rtmp://192.168.1.170/live
Stream: livestream

RTMP的URL规则,Vhost规则,参考: RTMP URL&Vhost

2.1.4 观看 RTMP 流

可以使用支持RTMP流的播放器播放,譬如vlc/flash player,播放地址:rtmp://192.168.1.170/live/livestream

或者使用在线SRS播放器播放: srs-player

2.1.5 RTMP 流的低延时配置

RTMP 流的延时在 1~3 秒,比 HLS 的延时更靠谱,低延时的配置参考: 低延时

2.2 HLS 部署实例

HLS部署实例

假设服务器的IP是:192.168.1.170

2.2.1 编译 SRS
./configure --with-nginx && make
2.2.2 启动分发 hls(m3u8/ts) 的 nginx
sudo ./objs/nginx/sbin/nginx
2.2.3 编写 SRS 配置文件

将以下内容保存为文件,如 conf/hls.conf,服务器启动时指定该配置文件(srs 的 conf 文件夹有该文件)。

# conf/hls.conf
listen              1935;
max_connections     1000;
daemon              off;
srs_log_tank        console;
vhost __defaultVhost__ {
    hls {
        enabled         on;
        hls_fragment    10;
        hls_window      60;
        hls_path        ./objs/nginx/html;
        hls_m3u8_file   [app]/[stream].m3u8;
        hls_ts_file     [app]/[stream]-[seq].ts;
    }
}

备注:hls_path 必须存在,srs 只会自动创建 ${hls_path} 下的 app 的目录。参考: Delivery HLS

2.2.4 启动 SRS
./objs/srs -c conf/hls_conf
2.2.5 启动推流编码器

使用 FFMPEG 命令推流:

.
    for((;;)); do \
        ./objs/ffmpeg/bin/ffmpeg -re -i ./doc/source.200kbps.768x320.flv \
        -vcodec copy -acodec copy \
        -f flv -y rtmp://192.168.1.170/live/livestream; \
        sleep 1; \
    done

或使用支持 h.264 + aac 的 FMLE 推流(若不支持 h.264 + aac,则可以使用 srs 转码,参考转码后分发HLS部署实例

FMS URL: rtmp://192.168.1.170/live
Stream: livestream

生成的流地址为:

2.2.6 观看 RTMP 流。

RTMP 流地址为: rtmp://192.168.1.170/live/livestream
可以使用 VLC 观看。或者使用在线 SRS 播放器播放: srs-player
备注:请将所有实例的IP地址192.168.1.170都换成部署的服务器IP地址。

2.2.7 观看 HLS 流

HLS 流地址为: http://192.168.1.170/live/livestream.m3u8
可以使用 VLC 观看,或者使用在线 SRS 播放器播放: jwplayer
备注:请将所有实例的IP地址192.168.1.170都换成部署的服务器IP地址。
注意:VLC无法观看纯音频流,jwplayer可以观看。
分发纯音频流参考: HLS audio only

2.3 RTMP 集群部署实例

RTMP集群部署实例

2.3.1 编写 SRS 源站配置文件
# conf/origin.conf
listen              19350;
max_connections     1000;
daemon              off;
pid                 objs/origin.pid;
srs_log_tank        console;
vhost __defaultVhost__ {
}
2.3.2 编写 SRS 边缘配置文件
# conf/edge.conf
listen              1935;
max_connections     1000;
pid                 objs/edge.pid;
daemon              off;
srs_log_tank        console;
vhost __defaultVhost__ {
    mode            remote;
    origin          127.0.0.1:19350;
}
2.3.3 启动 SRS
./objs/srs -c conf/origin.conf &
./objs/srs -c conf/edge.conf &
2.3.4 启动推流编码器

使用FFMPEG命令推流:

.
    for((;;)); do \
        ./objs/ffmpeg/bin/ffmpeg -re -i ./doc/source.200kbps.768x320.flv \
        -vcodec copy -acodec copy \
        -f flv -y rtmp://192.168.1.170/live/livestream; \
        sleep 1; \
    done

或使用FMLE推流:

FMS URL: rtmp://192.168.1.170/live
Stream: livestream
2.3.5 观看 RTMP 流

源站RTMP流地址为:rtmp://192.168.1.170:19350/live/livestream,可以使用 VLC 观看,或者使用在线 SRS 播放器播放: srs-player-19350

边缘RTMP流地址为:rtmp://192.168.1.170/live/livestream,可以使用 VLC 观看,或者使用在线 SRS 播放器播放: srs-player-19350

  • 31
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot是一个用于创建独立的、基于Spring的应用程序的开源框架。它简化了Spring应用程序的配置和部署,并提供了很多开箱即用的特性和功能。 SRS(Simple-RTMP-Server)是一个开源的音视频传输服务器,支持RTMP、HLS和DASH等协议推流拉流SRS的核心功能之一。 在Spring Boot中集成SRS,可以方便地实现推流拉流功能。首先,我们需要在项目的pom.xml文件中添加SRS的依赖。然后,在Spring Boot的配置文件中,我们可以配置SRS的相关参数,如RTMP服务器的地址、端口等。 对于推流,我们可以使用SRS推流API来将音视频数据送到SRS服务器。我们可以根据需要选择合适的推流编码器和封装格式,然后使用SRS提供的API发送数据包给服务器。服务器会对推流的数据进行处理,并将其保存为音视频文件或者转发给其他客户端。 对于拉流,我们可以使用SRS拉流API从SRS服务器获取音视频数据。我们可以指定要取的流的URL,然后使用SRS提供的API接收服务器发送的数据包。我们可以根据需要解码和播放音视频数据,或者将其保存为文件。 总之,通过在Spring Boot中集成SRS,我们可以方便地实现推流拉流功能。这使得我们能够更加灵活地处理音视频数据,满足不同场景下的需求,如直播、点播等。同时,Spring Boot的简洁、易用的特性也能够提高开发效率,使得整个开发过程更加高效、便捷。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全能技术师

相关资源在博客首页资源下获取

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值