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

简介:

一、背景

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

二、配置rtmp直播服务

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

vim  /usr/local/nginx/conf/nginx.conf
AI 代码解读

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;                          #嵌套模式。

        }
AI 代码解读

添加后,如下图所示
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/;
   }
AI 代码解读

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

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

/usr/local/nginx/sbin/nginx -s reload
AI 代码解读

命令执行之后,返回的信息如下图所示
image
在上图中可以看到重启没有报错,说明我们的配置没有出现语法错误,并且重启已经成功了。

三、OBS推流

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

https://obsproject.com/
AI 代码解读

在官网首页有下载地址,如下图所示
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
AI 代码解读

浏览器打开监控页面,返回的信息如下图所示
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
AI 代码解读

命令执行之后,返回的文件列表信息如下图所示
image
在上图中可以看到TS片,到此我们通过nginx+rtmp搭建直播服务已经完成了,下一篇我们将通过SRS搭建流媒体服务器。


作者:汤青松

日期:2019-12-04

目录
打赏
0
0
0
0
15
分享
相关文章
大数据-172 Elasticsearch 索引操作 与 IK 分词器 自定义停用词 Nginx 服务
大数据-172 Elasticsearch 索引操作 与 IK 分词器 自定义停用词 Nginx 服务
146 5
nginx修改网站默认根目录及发布(linux、centos、ubuntu)openEuler软件源repo站点
通过合理配置 Nginx,我们可以高效地管理和发布软件源,为用户提供稳定可靠的服务。
350 13
Nginx 实现一个端口代理多个前后端服务
【10月更文挑战第19天】Nginx 的强大功能不仅限于此,它还可以与其他技术和工具相结合,为我们的应用提供更强大的支持和保障。在不断发展的互联网时代,掌握 Nginx 的使用技巧将为我们的工作和生活带来更多的便利和效益。
使用Nginx搭建流媒体服务器
本文介绍了流媒体服务器的特性及各种流媒体传输协议的适用场景,并详细阐述了使用 nginx-http-flv-module 扩展Nginx作为流媒体服务器的详细步骤,并提供了在VLC,flv.js,hls.js下的流媒体拉流播放示例。
551 3
Nginx 代理多服务
以上是 Nginx 代理多服务的几种常见方式,在实际应用中,可以根据具体的业务需求和系统架构选择合适的代理方式,并结合其他 Nginx 的功能和配置来优化和完善系统的性能和功能。
大数据-54 Kafka 安装配置 环境变量配置 启动服务 Ubuntu配置 ZooKeeper
大数据-54 Kafka 安装配置 环境变量配置 启动服务 Ubuntu配置 ZooKeeper
214 3
大数据-54 Kafka 安装配置 环境变量配置 启动服务 Ubuntu配置 ZooKeeper
k8s基础使用--使用k8s部署nginx服务
本文介绍了Kubernetes中核心概念Deployment、Pod与Service的基本原理及应用。Pod作为最小调度单元,用于管理容器及其共享资源;Deployment则负责控制Pod副本数量,确保其符合预期状态;Service通过标签选择器实现Pod服务的负载均衡与暴露。此外,还提供了具体操作步骤,如通过`kubectl`命令创建Deployment和Service,以及如何验证其功能。实验环境包括一台master节点和两台worker节点,均已部署k8s-1.27。
475 1