欢迎光临

我们一直在努力
当前位置:首页 > 建站经验 >

利用nginx搭建RTMP视频点播、直播、HLS服务器

日期:
后台-插件-广告管理-首页/栏目/内容广告位一(PC)
后台-插件-广告管理-首页/栏目/内容广告位一(手机)
目录
  • nginx的服务器的搭建
  • 点播视频服务器的配置
  • 直播视频服务器的配置
    • 配置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模块。

    ./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/eVSErtvideo/vod; #//视频文件存放位置。
    	}
        }
    }
    http {
        include       mime.types;
        default_type  application/octet-stream;
        sendfile       >


    文件放好之后,那就让我们重新启动一下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名字任意。第二处就是添加两个locatiohttp://n字段,字段的内容请直接看文件吧。

    worker_processes  1;
    
    events {
        worker_connections  1024;
    }
    
    rtmp {
        server { 
            listen 1935;
    	chunk_size 4096;
            
    	application vod {
    		play /opt/video/vod;
    	}
    
    	application live{ #第一处添加的直播字段
    		live>

    有没有看到红框框的live字样呢?如果可以显示出来,证明你的配置生效了。

    还等什么让我们推送一个节目看看(其实专业词叫录制,后面将会使用录制这个词。)吧。

    这次推送我使用的是OBS(Open Broadcaster Software)会给大家介绍如何使用手机采集视频并且推送到服务器上。

    首先安装FFmpeg

    添加源:

    sudo add-apt-repository ppa:kirillshkrogalev/ffmpeg-next
    

    更新源:

    sudo apt-get update
    

    安装:

    sudo apt-get install ffmpeg

    如果是Ubuntu 15.04可以直接使用

    sudo apt-get install ffmpeg

    安装obs-studio

    添加源:

    sudo add-apt-repository ppa:obsproject/obs-studio
    [!--empirenews.page--]

    更新源:

    sudo apt-get update
    

    安装:

    sudo apt-get install obs-studio
    

    配置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> /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;
            }
        }
    }
    
    

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

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

    2.如何给服务器录制视频,在上一节已经说过,这里就不再说了。

    3.查看视频文件是否真的录制上没有,继续看图:

    已经产生切片视频文件了。其中还有一个index.m3u8。

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

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

    到此这篇关于利用nginx搭建RTMP视频点播、直播、HLS服务器的文章就介绍到这了,更多相关nginx搭建RTMP视频点播内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

    后台-插件-广告管理-首页/栏目/内容广告位二(PC)
    后台-插件-广告管理-首页/栏目/内容广告位二(手机)
    后台-插件-广告管理-内容广告位三(PC)
    后台-插件-广告管理-内容广告位三(手机)

    相关阅读

    后台-插件-广告管理-内容广告位四(PC)
    后台-插件-广告管理-内容广告位四(手机)

    热门文章

    后台-插件-广告管理-侧边广告位一(PC)
    后台-插件-广告管理-侧边广告位一(手机)
    • Docker容器实战之镜像与容器的工作原理

    • 目录一. bootfs和rootfs二. 镜像结构三. 容器层四. 联合文件系统?一. bootfs和rootfs 通常而言,linux的操作系统由两类文件系统组成:bootfs(boot file system)和rootfs(root file
    • 详解Nginx的超时keeplive_timeout配置步骤

    • 目录keepalive_timeoutclient_body_timeoutclient_header_timeoutsend_timeoutNginx 处理的每个请求均有相应的超时设置。如果做好这些超时时间的限定,判定超时后资源被释放,
    • nginx 配置指令之location使用详解

    • 目录前言配置策略具体属性介绍Nginx是支持世界上所有网站三分之一的Web服务器。因为轻巧,模块化,用户友好的配置格式以强大的反向代理能力,Nginx迅速取代其他Web服务器成了互联
    • zabbix配置nginx监控的实现

    • 目录案例:zabbix 配置 nginx 监控1. 修改配置文件2. 编写 nginx 监控脚本3. 修改 zabbix 配置文件4. 服务端验证5. 添加模块6. 创建应用集7. 创建监控项8. 定义触发器9. 关联
    • nginx 添加http_stub_status_module模块

    • 目录1. stub_status 作用说明2.查看现有 nginx 编译参数3.使用参数重新配置configure,在原有基础上添加上 --with-http_stub_status_module4.将原来的 nginx 文件备份5. 编译
    后台-插件-广告管理-侧边广告位二(PC)
    后台-插件-广告管理-侧边广告位二(手机)

    最新文章

    • 在Asp.net core项目中使用WebSocket

    • 今天小试了一下在ASP.NET core中使用websocket,这里记录一下: 在 Startup 类的 Configure 方法中添加 WebSocket 中间件。 app.UseWebSockets(); 它也可以传入一些参数 app.Us
    • Vue快速理解事件绑定是什么

    • 目录一、监听事件二、事件修饰符1、stop修饰符阻止事件冒泡2、capture修饰符3、self修饰符4、prevent修饰符5、键盘事件修饰符6、鼠标事件修饰符一、监听事件 监听事件一般
    • C#实现模拟ATM自动取款机功能

    • 目录(1)关于用户帐号的类:Account(2)关于银行数据库的类:BankDatabase(3)关于ATM屏幕显示的类:Screen(4)关于ATM键盘的类:Keypad(5)关于进钞、出钞口的类:DepositSlot(6)关于ATM
    • Java设计模式之抽象工厂模式浅析讲解

    • 1.介绍 当系统准备为用户提供一系列相关对象,又不想让用户代码和这些对象形成耦合时,就可以使用抽象工厂模式。 2.如何实现 1)抽象产品--Car 2)具体产品--BYDCar、TSLCar 3)抽象
    • 如何动态替换Spring容器中的Bean

    • 目录动态替换Spring容器中的Bean原因方案实现Spring中的bean替换问题动态替换Spring容器中的Bean 原因 最近在编写单测时,发现使用 Mock 工具预定义 Service 中方法的行为特
    • C#优雅的实现INotifyPropertyChanged接口

    • INotifyPropertyChanged接口在wpF或WinFrom程序中使用还是经常用到,常用于通知界面属性变更。标准写法如下: class NotifandroidyObject : INotifyPropertyChanged {
    后台-插件-广告管理-侧边广告位三(PC)
    后台-插件-广告管理-侧边广告位三(手机)