返回介绍

RTMP源站集群部署实例

发布于 2020-11-26 08:54:17 字数 7593 浏览 2034 评论 0 收藏 0

RTMP源站集群部署的步骤,我们给出了一个例子,部署了两个源站做集群,还部署了一个边缘。 实际使用中,可以部署多个源站和多个边缘,形成源站集群。

假设服务器的IP是:192.168.1.170

第一步,获取SRS。详细参考GIT获取代码

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

或者使用git更新已有代码:

git pull

第二步,编译SRS。详细参考Build

./configure && make

第三步,编写SRS源站A配置文件。详细参考RTMP源站集群

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

# conf/origin.cluster.serverA.conf
listen              19350;
max_connections     1000;
daemon              off;
srs_log_tank        console;
pid                 ./objs/origin.cluster.serverA.pid;
http_api {
    enabled         on;
    listen          9090;
}
vhost __defaultVhost__ {
    cluster {
        mode            local;
        origin_cluster  on;
        coworkers       127.0.0.1:9091;
    }
}

第四步,编写SRS源站B配置文件。详细参考RTMP源站集群

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

# conf/origin.cluster.serverB.conf
listen              19351;
max_connections     1000;
daemon              off;
srs_log_tank        console;
pid                 ./objs/origin.cluster.serverB.pid;
http_api {
    enabled         on;
    listen          9091;
}
vhost __defaultVhost__ {
    cluster {
        mode            local;
        origin_cluster  on;
        coworkers       127.0.0.1:9090;
    }
}

第五步,编写SRS边缘配置文件,从多个源站拉流,实现热备和负载均衡。详细参考RTMP源站集群

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

# conf/origin.cluster.edge.conf
listen              1935;
max_connections     1000;
pid                 objs/edge.pid;
daemon              off;
srs_log_tank        console;
vhost __defaultVhost__ {
    cluster {
        mode            remote;
        origin          127.0.0.1:19351 127.0.0.1:19350;
    }
}

Remark: 如果播放器支持RTMP302,当然可以直接播放源站的流,任意源站都能播放,如果流不在访问的源站,会返回RTMP302重定向到流所在的源站。

第六步,启动SRS。详细参考RTMP源站集群

./objs/srs -c conf/origin.cluster.serverA.conf &
./objs/srs -c conf/origin.cluster.serverB.conf &
./objs/srs -c conf/origin.cluster.edge.conf &

第七步,启动推流编码器,推流到19350。详细参考RTMP源站集群

使用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:19350/live/livestream; \
        sleep 1; \
    done

或使用FMLE推流:

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

第八步,观看RTMP流,不管流推到哪个源站,播放边缘的流都能从正确的源站回源取流。详细参考RTMP源站集群

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

备注:请将所有实例的IP地址192.168.1.170都换成部署的服务器IP地址。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文