专栏首页PHP技术大全Ubuntu中使用Nginx+rtmp搭建流媒体直播服务.md
原创

Ubuntu中使用Nginx+rtmp搭建流媒体直播服务.md

一、背景

本篇文章是继上一篇文章《Ubuntu中使用Nginx+rtmp模块搭建流媒体视频点播服务》文章而写,在上一篇文章中我们搭建了一个点播服务器,在此基础上我们再搭建一个直播服务器,

二、配置rtmp直播服务

我们需要在nginx配置文件中增加直播的配置,这里我们依然使用vim命令打开配置文件,执行命令如下

vim  /usr/local/nginx/conf/nginx.conf

vim命令执行之后,我们将直播配置添加到rtmp项配置下面,其中的含义已经在配置中注明,配置如下所示

        application live{
            live on;        #直播

            #回看功能 视频切片变成ts文件
            hls on;                                 #这个参数把直播服务器改造成实时回放服务器。
            wait_key on;                           #对视频切片进行保护,这样就不会产生马赛克了。
            hls_path /opt/video/rtmp/hls;       #切片视频文件存放位置。
            hls_fragment 10s;                       #每个视频切片的时长。
            hls_playlist_length 60s;                #总共可以回看的事件,这里设置的是1分钟。
            hls_continuous on;                      #连续模式。
            hls_cleanup on;                         #对多余的切片进行删除。
            hls_nested on;                          #嵌套模式。

        }

添加后,如下图所示

image

在上图中蓝色字体乱码,这个可以暂时忽略它,或者直接删除它。

接着我们再将另外一项配置增加到HTTP服务中,这个是用来监控我们的推流状态的,如果不配置我们就不方便监控推流的状态;我们容器映射到外面的http端口为8081,所以这里我们也把NGINX里面的HTTP端口也改为8081,这样我们才可以访问到,配置项如下

    location /stat {    #第二处添加的location字段。
            rtmp_stat all;
        rtmp_stat_stylesheet stat.xsl;
    }

    location /stat.xsl { #第二处添加的location字段。
       root /etc/rtmpServer/nginx-rtmp-module/;
   }

增加配置之后,如下图所示

image

在上图中可以看到,上面有一个配置路径是/etc/rtmpServer/nginx-rtmp-module/这是我们开始下载源码解压的位置,如果你解压的位置不是这个,就需要将这里改成你解压的位置。

设置好nginx配置之后,我们保存并退出,然后你重启nginx服务器,让刚才的配置生效,重启的命令如下

/usr/local/nginx/sbin/nginx -s reload

命令执行之后,返回的信息如下图所示

image

在上图中可以看到重启没有报错,说明我们的配置没有出现语法错误,并且重启已经成功了。

三、OBS推流

在上面nginx配置完成之后,其实直播服务已经搭建完成了,但是我们还需要验证一下,最简单的方式就是推流然后去拉流播放,推流我们一般使用obs进行推流,官网地址如下所示

https://obsproject.com/

在官网首页有下载地址,如下图所示

image

在上图中可以看到支持Windows和Linux以及Mac系统的版本,这里我下载的是Mac版本,把OBS下载并安装好之后,打开界面如下图所示

image

在上图中可以看到我添加了一个媒体源,媒体源这里可以选择录制屏幕,也可以选择一个视频文件等各种方式

接着点击右侧的设置按钮,会弹出一个设置框,找到里面的推流项,然后设置推流地址,如下图所示

image

在上图中可以看到我填写的服务器地址为rtmp://127.0.0.1/live,串流密码为:test,设置好之后点击下方的确定,然后回到主窗口中点击开始推流按钮,就会开始推流,如下图所示

image

在上图中可以下方的状态栏可以看到已经在开始推流了,其中的LIVE后面的为当期推流持续时间,CPU后面的百分比代表推流占用了多少CUP资源,在客户端显示推流成功之后,我们可以通过浏览器访问推流监控页面,地址如下所示

http://127.0.0.1:8081/stat

浏览器打开监控页面,返回的信息如下图所示

image

在上图中可以看到test频道有已经一路流推送了上来,说明服务端已经接收到数据流

四、使用vlc拉流

推流上来之后,我们就可以进行拉流测试,这里我们依然以VLC播放器来测试,打开菜单栏中的选项 File->Open Network

image

在上图中可以看到有一个输入框,在里面填入播放地址rtmp://127.0.0.1/live/test,然后点击下方的open按钮,然后就可以播放了,如果没有意外情况,播放效果如下图所示

image

在上图中可以看到已经开始播放我刚才推送上去的视频了

直播转录播

如果我们需要将推流的视频存保留下来将来用作回放,并不需要特意配置,因为nginx-rtmp-moudle模块已经帮我们保存了,保存的位置是在nginx配置中hls_path项设置的位置,我们通过CD命令查看一下,执行命令如下所示

cd /opt/video/rtmp/hls/test && ls

命令执行之后,返回的文件列表信息如下图所示

image

在上图中可以看到TS片,到此我们通过nginx+rtmp搭建直播服务已经完成了,下一篇我们将通过SRS搭建流媒体服务器。


作者:汤青松

日期:2019-12-04

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Ubuntu中使用Nginx+rtmp模块搭建流媒体视频点播服务

    不知不觉笔者来到流媒体部门已经一年半多了,积攒了不少的流媒体知识,但平时工作也比较忙,很少进行总结性的梳理,最近准备花几个周末时间写一个流媒体系列的实践文章,也...

    汤青松
  • docker中使用源码方式搭建SRS流媒体服务

    搭建流媒体服务的方式一般会采用nginx+rtmp和srs服务两种,前者是nginx加上插件所用,而后者是专门为了为了流媒体而生,在这一节中我们将从头搭建srs...

    汤青松
  • 使用docker快速搭建xssPlatform测试平台实践

    笔者之前给一些开发团队多次做Web安全开发培训,为了让培训的学员能够理解XSS原理和XSS的危害,将xssPlatform进行了更新,之前一直放在GitHub中...

    汤青松
  • 快速搭建自己的直播服务器,完成属于你的直播服务。

    1、Windows下安装linux centos系统,版本建议 5.7-6.0 之间。安装成功后,进入 centos 系统安装其他软件,为了方便安装其他软件,建...

    热心的程序员
  • Ubuntu中使用Nginx+rtmp模块搭建流媒体视频点播服务

    不知不觉笔者来到流媒体部门已经一年半多了,积攒了不少的流媒体知识,但平时工作也比较忙,很少进行总结性的梳理,最近准备花几个周末时间写一个流媒体系列的实践文章,也...

    汤青松
  • CVPR大规模行为识别竞赛连续两年夺冠,上交大详细技术分享

    【新智元导读】近日,视频行为理解领域的ImageNet竞赛——ActivityNet Challenge 2018在CVPR 会议上落下了帷幕。来自上海交通大学...

    新智元
  • 61.Vue 结合webpack使用vue-router

    在前面的篇章,我们已经使用export default以及render函数完成的vue框架在webpack中的组件基本使用方式。

    Devops海洋的渔夫
  • emlog博客系统去除分类sort优化SEO

    分类URL网址中有个sort字样只会在开启伪静态后才显示 想去除EMLOG伪静态分类网址中的sort, include文件夹下,在lib文件夹下找到d...

    奶糖味的代言
  • 深度剖析喜茶+奈雪の茶是如何开启茶饮新时代的?

    早在几千年前,就受到中国人独有的喜爱,奶茶在消费浪潮的今天同样受到中国青年男女们的欢迎。

    庄帅
  • android: targetSdkVersion升级中Only fullscreen activities can request orientation问题的解决方法

    这几天同事跟我在升级Android target SDK和build tool版本的时候,碰到了一个非常搞笑的问题,基本可以算作是“坑”了!我在这里跟大家分享一...

    砸漏

扫码关注云+社区

领取腾讯云代金券