当前位置: 首页 > news >正文

Nginx搭建RTMP点播流媒体服务器步骤详解,Nginx+RTMP+OBS推流搭建流媒体服务器

开发环境

· Ubuntu 14.04 server
· nginx-1.8.1
· nginx-rtmp-module

nginx服务器搭建

安装nginx的依赖库

sudo apt-get update
sudo apt-get install libpcre3 libpcre3-dev
sudo apt-get install openssl libssl-dev

配置并编译nginx

使用nginx的默认配置,添加nginx的rtmp模块。

Nginx搭建RTMP点播流媒体服务器步骤详解,Nginx+RTMP+OBS推流搭建流媒体服务器

./configure --add-module=../nginx-rtmp-module-master
make
sudo make install

运行测试nginx

进入安装目录/usr/local/nginx,运行命令./sbin/nginx
注意:以后所有的命令都在/usr/local/nginx目录运行,也nginx配置文件的相对目录。

打开浏览器在地址栏输入:localhost。如果,如下图显示那样就证明你的nginx服务器搭建成功了。

在这里插入图片描述

点播视频服务器的配置

通过上一步nginx服务器已经搭建完成,然后我们就可以开启一个视频点播的服务了。打开配置文件nginx.conf,添加RTMP的配置。

worker_processes  1;events {worker_connections  1024;
}
rtmp {                #RTMP服务server {listen 1935;  #//服务端口 chunk_size 4096;   #//数据传输块的大小application vod {play /opt/video/vod; #//视频文件存放位置。}}
}
http {include       mime.types;default_type  application/octet-stream;sendfile        on;keepalive_timeout  65;server {listen       80;server_name  localhost;location / {root   html;index  index.html index.htm;}error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}}
}

配置目录*/opt/video/vod*为存放视频文件的位置了,那我们就往里面放一个文件吧。我放了一个qq.mp4文件。

在这里插入图片描述

文件放好之后,那就让我们重新启动一下nginx

sudo ./sbin/nginx -s reload

打开视频播放软件选用的是VLC media-> open network stream…
如图填写我们要点播的节目地址rtmp://localhost/vod/qq.mp4 如图:

在这里插入图片描述
点击play就可以播放了。

当然点播不使用RTMP插件nginx自身也是可以实现点播服务的。那就是配置location部分,由于下面我们要配置直播和回看功能所以选用了RTMP服务。

直播视频服务器的配置

接着我们就在点播服务器配置文件的基础之上添加直播服务器的配置。一共2个位置,第一处就是给RTMP服务添加一个application这个名字可以任意起,也可以起多个名字,由于是直播我就叫做它live吧,如果打算弄多个频道的直播就可以live_cctv1、live_cctv2名字任意。第二处就是添加两个location字段,字段的内容请直接看文件吧。

worker_processes  1;events {worker_connections  1024;
}rtmp {server { listen 1935;chunk_size 4096;application vod {play /opt/video/vod;}application live{ #第一处添加的直播字段live on;}}}http {include       mime.types;default_type  application/octet-stream;sendfile        on;keepalive_timeout  65;server {listen       80;server_name  localhost;location /stat {     #第二处添加的location字段。rtmp_stat all;rtmp_stat_stylesheet stat.xsl;}location /stat.xsl { #第二处添加的location字段。root /usr/local/nginx/nginx-rtmp-module/;}location / {root   html;index  index.html index.htm;}error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}}
}

添加完这两处之后,重新启动nginx打开浏览器看看,是否有如下图显示:

在这里插入图片描述
有没有看到红框框的live字样呢?如果可以显示出来,证明你的配置生效了。

还等什么让我们录制一个节目看看

这次录制我使用的是OBS(Open Broadcaster Software)

配置OBS如图:

在这里插入图片描述

点击红圈添加“Media Source”,会弹出一个框框,里面的内容就按照图片显示配置就可以了。点击“OK”就能在你的屏幕上播放了。

配置节目的输出流如图所示:

在这里插入图片描述

首先点击红圈“setting”进入设置界面。记得要正确填写要录制的服务器路径啊。配置好就可以点击OK了。退出后点击蓝圈,就开始录制节目了。

查看我们的了录制的节目,服务器有没有接收到呢?打开我的服务器地址“http://localhost/stat”查看一下 ,你的显示是否和我的相同呢?如果相同证明服务器已经接收到了录制的节目,客户端可以进行播放了。

在这里插入图片描述

播放的地址就是“rtmp://localhost/live/test”,如果你本地有支持rtmp协议的播放器就可以试试了。最后奉上一张观看直播的屏幕截图。

在这里插入图片描述

实时回看视频服务器的配置

我们想一想如果直播服务能够把节目录制在本地,我们不就可以直接进行回看先前的节目了吗?回看一分钟、一小时甚至一天的,想想就兴奋,不用写代码有现成的可以使用,怎么用呢?继续看nginx的配置吧。

worker_processes  1;events {worker_connections  1024;
}rtmp {server {listen 1935;chunk_size 4096;application vod {play /opt/video/vod;}application live {live on;hls on; #这个参数把直播服务器改造成实时回放服务器。wait_key on; #对视频切片进行保护,这样就不会产生马赛克了。hls_path /opt/video/hls; #切片视频文件存放位置。hls_fragment 10s;     #每个视频切片的时长。hls_playlist_length 60s;  #总共可以回看的事件,这里设置的是1分钟。hls_continuous on; #连续模式。hls_cleanup on;    #对多余的切片进行删除。hls_nested on;     #嵌套模式。}}
}http {include       mime.types;default_type  application/octet-stream;sendfile        on;keepalive_timeout  65;server {listen       80;server_name  localhost;location /stat {rtmp_stat all;rtmp_stat_stylesheet stat.xsl;}location /stat.xsl {root /usr/local/nginx/nginx-rtmp-module/;}location /live {  #这里也是需要添加的字段。types {  application/vnd.apple.mpegurl m3u8;  video/mp2t ts;  }alias /opt/video/hls;   expires -1;add_header Cache-Control no-cache;  }  location / {root   html;index  index.html index.htm;}error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}}
}

添加完成后需要重新启动nginx,由于这次nginx需要向服务器写切片视频文件,但nginx我又没有给nginx指定用户名只能走默认的nobody用户和nogroup用户组,其实就是没有组。所以我对需要写入的目录做了增大权限的修改。

如下图,这样做就是为了避免由于权限问题而无法写文件。

在这里插入图片描述
如何给服务器录制视频,在上一节已经说过,这里就不再说了。
查看视频文件是否真的录制上没有,继续看图:

在这里插入图片描述
已经产生切片视频文件了。其中还有一个index.m3u8。

播放视频,这次可是http开头的了,“http://localhost/live/test/index.m3u8”。

已经可以播放了,如何回看呢?其实这个index.m3u8文件仅仅是目录。想回看那个就播放那个.ts文件就可以了。

到此已经结束。

感谢您的阅读,服务器大本营-技术文章内容集合站,助您成为更专业的服务器管理员!

http://www.dtcms.com/a/606247.html

相关文章:

  • 东莞建设网站官网住房和城乡网站平台系统设计公司
  • 具身智能-一文详解视觉-语言-动作(VLA)大模型(2)
  • 如何使用 Docker 打包一个简单的应用程序:简易指南
  • Hyper-V Windows 11 Pro x64 开局问题
  • 长沙外贸建站土地 水利 勘测设计 公司宣传册设计样本
  • Cursor区域限制解决方法, Cursor 提示:“Model not available“的原因
  • 自签名证书需要手动确认风险导致nginx转发无效问题
  • 重庆市建设工程安全网站广告营销公司
  • 编译型语言有哪些 | 深入了解编译型语言的工作原理和特点
  • 实践教程|如何创建一个WhatsApp AI Chatbot
  • 网站流量分成专题制作 wordpress
  • 深度学习中适合长期租用的高性价比便宜的GPU云服务器有哪些?
  • 【DaisyUI】如何覆盖 dropdown 下拉效果?
  • 个人网站可以挂广告吗网站开发项目合同书
  • 网站建设前提企业信息管理
  • 每日两题day42
  • 最优惠的手机网站建设wordpress页面访问量
  • AI提效前端开发
  • 建立主题网站的知识点东莞市做网站公司
  • 怎么重启电脑的网卡(Windows系统)?
  • 【STM32】串口
  • 杭州建网站装修材料
  • 从U盘损坏中恢复视频文件并修复修改日期的完整解决方案
  • 网站建设人员wordpress个人
  • 免费项目网站wordpress如何导入模板数据库
  • 三坐标测量软件路径仿真和碰撞检测功能
  • K8s Ingress 与 Ingress API 全解析:外部访问集群的统一入口
  • kubernetes部署
  • 【2025最新】05 Spring Security 构建 RESTful Web 注册服务 - 2
  • 《C++在LLM系统底座中的深度赋能逻辑》