微信多群直播服务器,基于srs直播群集架构之一路rtmp推流,多rtmp拉流

2024-03-25 01:50

本文主要是介绍微信多群直播服务器,基于srs直播群集架构之一路rtmp推流,多rtmp拉流,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于srs直播群集架构之一路rtmp推流,多rtmp拉流

一、架构设计

1、基础网络设施架构

2、一台目标推流的服务器,负责直播的源存储转发(origin)

3、一台loadbalance服务器,负责边界拉流服务器的负载调度(loadbalance)

4、两台realserver服务器,参与负载调度的边界拉流服务器(edge)

5、参与负载调度的服务器可以横向扩展

6、架构设计图,见下图

a09aefb4e6a5f3f6cdb2abf83a89bccb.png

二、环境说明

所有服务器系统:centos-6.7-x86_64 Linux内核2.6.32

推流系统:网络摄像头作为视频源(rtsp),obs采集视频并推流(rtmp)

直播服务器软件: srs(simple-rtmp-server) SRS-CentOS6-x86_64-2.0.205.zip

loadbalance软件: ipvsadm-1.26-4.el6.x86_64 && keepalived-1.2.13-5.el6_6.x86_64

三、系统实现

1、推流服务器配置,即srs-origin

网卡配置:eth2:172.16.1.207/24

srs服务器配置:

a.安装srs服务器,默认安装后路径 /usr/local/srs

cd  /usr/local/src

unzip SRS-CentOS6-x86_64-2.0.205.zip

./ INSTALL

b.修改配置文件ln -s /usr/local/srs /etc/srs

vim origin.conf

listen              1935;

max_connections     1000;

pid                 objs/origin.pid;

srs_log_file        ./objs/origin.log;

vhost __defaultVhost__ {

gop_cache       off;

queue_length    10;

min_latency     on;

mr {

enabled     off;

}

mw_latency      100;

tcp_nodelay     on;

}

将/etc/init.d/srs 启动脚本中srs.conf  修改为origin.conf

c.启动srs服务

service srs start

推流和拉流测试rtmp://172.16.1.228/live/livestream

2、loadbalance服务器配置,即loadbalance

网卡配置eth2:172.16.1.208/24  eth2:0:172.16.1.200/24

网络参数配置:vim /etc/sysctrl.conf  修改 net.ipv4.ip_forward = 1

安装调度器软件ipvsadm&&keepalived :yum install ipvsadm keepalived -y

配置keepalived:vim /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {

notification_email {

}

notification_email_from keepalived@localhost

#smtp_server 192.168.200.1

#smtp_connect_timeout 30

#router_id LVS_DEVEL

}

vrrp_instance VI_1 {

state MASTER

interface eth2

virtual_router_id 51

priority 100

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

172.16.1.200

}

}

virtual_server 172.16.1.200 1935 {

delay_loop 6

lb_algo rr

lb_kind DR

nat_mask 255.255.255.0

persistence_timeout 50

protocol TCP

real_server 172.16.1.211 1935 {

weight 1

TCP_CHECK {

connect_timeout 3

nb_get_retry 3

delay_before_retry 3

}

}

real_server 172.16.1.207 1935 {

weight 1

TCP_CHECK {

connect_timeout 3

nb_get_retry 3

delay_before_retry 3

}

}

}

启动服务和保存配置:service network restart  service ipvsadm start   service keepalived start

3、realserver1服务器配置,即srs-edge1

网卡配置:eth2:172.16.1.211/24  lo:0:172.16.1.200/32

网络参数配置:vim /etc/sysctrl.conf  修改 net.ipv4.ip_forward = 1  添加                                                                                                                   net.ipv4.conf.all.arp_ignore=1

net.ipv4.conf.all.arp_announce=2

添加本地路由:route add -host 172.16.1.200 dev lo:0

srs服务器配置:

a.安装srs服务器,默认安装后路径 /usr/local/srs

cd  /usr/local/src

unzip SRS-CentOS6-x86_64-2.0.205.zip

./ INSTALL

b.修改配置文件ln -s /usr/local/srs /etc/srs

vim edge.conf

listen              1935;

max_connections     1000;

pid                 objs/edge.pid;

srs_log_file        ./objs/edge.log;

vhost __defaultVhost__ {

mode            remote;

origin          172.16.1.228:1935;

}

将/etc/init.d/srs 启动脚本中srs.conf  修改为edge.conf

c.启动srs服务,并重启网卡服务

service srs start  service network restart

4、realserver2服务器配置,即srs-edge2

网卡配置:eth2:172.16.1.207/24  lo:0:172.16.1.200/32

网络参数配置:vim /etc/sysctrl.conf  修改 net.ipv4.ip_forward = 1  添加                                                                                                                   net.ipv4.conf.all.arp_ignore=1

net.ipv4.conf.all.arp_announce=2

添加本地路由:route add -host 172.16.1.200 dev lo:0

srs服务器配置:

a.安装srs服务器,默认安装后路径 /usr/local/srs

cd  /usr/local/src

unzip SRS-CentOS6-x86_64-2.0.205.zip

./ INSTALL

b.修改配置文件ln -s /usr/local/srs /etc/srs

vim edge.conf

listen              1935;

max_connections     1000;

pid                 objs/edge.pid;

srs_log_file        ./objs/edge.log;

vhost __defaultVhost__ {

mode            remote;

origin          172.16.1.228:1935;

}

将/etc/init.d/srs 启动脚本中srs.conf  修改为edge.conf

c.启动srs服务,并重启网卡服务

service srs start  service network restart

四、系统测试

最终群集结果:

单路推流服务器地址:rtmp://172.16.1.228/live/streamlive

多路拉流服务器地址:rtmp://172.16.1.200/live/streamlive

这篇关于微信多群直播服务器,基于srs直播群集架构之一路rtmp推流,多rtmp拉流的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/843488

相关文章

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

系统架构设计师: 信息安全技术

简简单单 Online zuozuo: 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo :本心、输入输出、结果 简简单单 Online zuozuo : 文章目录 系统架构设计师: 信息安全技术前言信息安全的基本要素:信息安全的范围:安全措施的目标:访问控制技术要素:访问控制包括:等保

利用命令模式构建高效的手游后端架构

在现代手游开发中,后端架构的设计对于支持高并发、快速迭代和复杂游戏逻辑至关重要。命令模式作为一种行为设计模式,可以有效地解耦请求的发起者与接收者,提升系统的可维护性和扩展性。本文将深入探讨如何利用命令模式构建一个强大且灵活的手游后端架构。 1. 命令模式的概念与优势 命令模式通过将请求封装为对象,使得请求的发起者和接收者之间的耦合度降低。这种模式的主要优势包括: 解耦请求发起者与处理者

速盾:直播 cdn 服务器带宽?

在当今数字化时代,直播已经成为了一种非常流行的娱乐和商业活动形式。为了确保直播的流畅性和高质量,直播平台通常会使用 CDN(Content Delivery Network,内容分发网络)服务器来分发直播流。而 CDN 服务器的带宽则是影响直播质量的一个重要因素。下面我们就来探讨一下速盾视角下的直播 CDN 服务器带宽问题。 一、直播对带宽的需求 高清视频流 直播通常需要传输高清视频

uniapp设置微信小程序的交互反馈

链接:uni.showToast(OBJECT) | uni-app官网 (dcloud.net.cn) 设置操作成功的弹窗: title是我们弹窗提示的文字 showToast是我们在加载的时候进入就会弹出的提示。 2.设置失败的提示窗口和标签 icon:'error'是设置我们失败的logo 设置的文字上限是7个文字,如果需要设置的提示文字过长就需要设置icon并给

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹