从零搭建流媒体服务器+obs推流直播
背景介绍
本文使用的流媒体服务器的搭建是基于rtmp(Real Time Message Protocol)协议的,rtmp协议是应用层的协议,要依靠底层的传输层协议,比如tcp协议来保证信息传输的可靠性。最后提供了一个不错的测试方案。
流媒体服务器依赖的服务,1.nginx 服务器;2.nginx服务器安装需要依赖的服务 OpenSSL、pcre、zlib、 c++、gcc等。
服务器环境是Centos 7.3 64 位,本地操作系统 win7 旗舰版
注意事项
需要资源:1.一台云服务器;2.一台能上网的电脑
需要注意的是本机搭建使用的是Centos 7.X的版本,iptables命令等使用方式有变动,如需修改参照3.I 中修改防火墙操作方式
由于本机上先安装的Apache,而nginx和Apache都是默认的80端口,所以防止冲突本文修改了nginx的默认端口
安装nginx
首先需要注意的是虽然nginx可以使用yum安装,但是yum安装使用的都是编译后的文件进行安装,并且后面所需要的rtmp模块一般在yum源里面是找不到的,所以要想将rtmp也安装进来,我们选择源码安装,经过步骤配置,编译,安装。
本文是使用nginx源码,自行编译安装。首先是下载源码,由于nginx的代码是开源托管在github上,我们先用yum 将git下载下来,然后使用git将源码从github上clone下来
cd
mkdir source #创建源码目录 后面的源码都放在这个目录
cd source
yum -y install git #安装git
git clone https://github.com/nginx/nginx.git #从github服务器上将nginx的源代码下载下来
git clone https://github.com/arut/nginx-rtmp-module.git #将rtmp模块的源码下载下来
下载依赖模块源码pcre、OpenSSL、zlib 如果机器上已经安装了这些模块就不需要了
rpm -qa|grep 模块名字 #查询安装的模块的包信息
wget https://www.openssl.org/source/openssl-1.1.0.tar.gz #下载OpenSSL源码包
wget https://ftp.pcre.org/pub/pcre/pcre-8.39.tar.gz #下载pcre源码包
wget http://www.zlib.net/zlib-1.2.11.tar.gz #下载zlib包源码
tar -zxvf 包名 #解压各个包源码
./auto/configure --prefix=/usr/local/nginx \
--with-pcre=../pcre-8.39 \
--with-openssl=../openssl-1.1.0 \
--with-zlib=../zlib-1.2.11 \
--with-http_v2_module \
--with-http_flv_module \
--with-http_mp4_module \
--add-module=../nginx-rtmp-module/
chmod 777 config.sh #赋予权限
./config.sh #执行脚本
yum -y install gcc #确保依赖的gcc安装
yum -y install gcc-c++ #确保依赖的c++已经安装
make #编译
make install #安装
iptables -I INPUT -p tcp -m state --state NEW --dport 8084 -j ACCEPT #放行8084端口的 NEW状态请求(本机的RELATED,ESTABLISHED状态是默认放行的)
service iptables save #保存规则
service iptables restart #重启防火墙保证新的规则加载进来
vi /usr/local/nginx/conf/nginx.conf #修改配置文件
# rtmp config
rtmp {
server {
listen 1935;
chunk_size 4096;
application live {
live on;
record off;
}
application live2 {
live on;
record off;
}
application vod {
play /var/flvs;
}
application vod_http {
play http://服务器的ip/vod;
}
application hls {
live on;
hls on;
hls_path /tmp/hls;
}
}
}
/usr/local/nginx/sbin/nginx -s reload #修改配置文件重启nginx服务
iptables -I INPUT -p tcp -m state --state NEW --dport 1935 -j ACCEPT #放行1935端口的 NEW状态请求
service iptables save #保存规则
service iptables restart #重启防火墙保证新的规则加载进来
rtmp://你的服务器ip:端口(1935)/live #URL填写流的地址
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
2018-05-14 在SpringBoot中对SpringSecurity的基本使用
2018-05-14 聊聊 Spring Boot 2.0 的 WebFlux
2018-05-14 使用 Spring Boot 2.0 + WebFlux 实现 RESTful API
2018-05-14 Spring Boot 不使用默认的 parent,改用自己的项目的 parent
2018-05-14 Springboot 版本+ jdk 版本 + Maven 版本的匹配
2018-05-14 Spring Boot 学习17--改变JDK编译版本
2018-05-14 Spring Boot 配置大全