利用nginx搭建搭建直播平台中视频点播、直播、HLS服务器

nginx的服务器的搭建

安装nginx的依赖库

<span style="color:#000000"><code>sudo apt-get update
sudo apt-get install libpcre3 libpcre3-dev
sudo apt-get install openssl libssl-dev
</code></span>
  • 1
  • 2
  • 3

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

<span style="color:#000000"><code>./configure --add-module=../nginx-rtmp-module-master
make
sudo make install
</code></span>
  • 1
  • 2
  • 3

运行测试nginx
进入安装目录/usr/local/nginx,运行命令./sbin/nginx

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

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

点播视频服务器的配置

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

搭建直播平台

<span style="color:#000000"><code>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;}}
}
</code></span>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33

配置目录*/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)有关它的安装请参考先前我写的Ubuntu安装OBS(Open Broadcaster Software)后面的博客里我会给大家介绍如何使用手机采集视频并且推送到服务器上。

搭建直播平台

配置OBS如图:

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

我们想一想如果直播服务能够把节目录制在本地,我们不就可以直接进行回看先前的节目了吗?回看一分钟、一小时甚至一天的。想想就兴奋不用写代码有现成的可以使用。怎么用呢?继续看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;}}
}
  1. 点击红圈添加“Media Source”,会弹出一个框框,里面的内容就按照图片显示配置就可以了。点击“OK”就能在你的屏幕上播放了。
  2. 配置节目的输出流如图所示:
  3. 首先点击红圈“setting”进入设置界面。记得要正确填写要录制的服务器路径啊。配置好就可以点击OK了。退出后点击蓝圈,就开始录制节目了。
  4. 查看我们的了录制的节目,服务器有没有接收到呢?打开我的服务器地址“http://localhost/stat”查看一下 ,你的显示是否和我的相同呢?如果相同证明服务器已经接收到了录制的节目,客户端可以进行播放了。

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

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

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

已经产生切片视频文件了。其中还有一个index.m3u8。
4.播放视频,这次可是http开头的了,“http://localhost/live/test/index.m3u8”。
5.已经可以播放了,如何回看呢?其实这个index.m3u8文件仅仅是目录。想回看那个就播放那个.ts文件就可以了。

利用nginx搭建搭建直播平台中视频点播、直播、HLS服务器相关推荐

  1. 搭建直播平台中的美颜效果开源实现,从AI到美颜全流程讲解

    搭建直播平台中的美颜效果开源实现,从AI到美颜全流程讲解 美颜和短视频 美颜相关APP可以说是现在手机上的必备的软件,例如抖音,快手,拍出的"照骗"和视频不加美颜效果,估计没有人敢 ...

  2. 搭建直播平台中主播pk,如何实现无缝切换?

    搭建直播平台中主播pk,如何实现无缝切换? 今天要介绍的就是主播连麦PK方案,通过这篇文章,我们将一起来了解什么是主播连麦PK?以及怎么快速实现主播间的连麦PK? 什么是连麦PK? 连麦PK就是正在直 ...

  3. 搭建直播平台实现VR直播的关键技术

    VR是多媒体技术发展的必然趋势,人们所使用的信息载体从最早的文字.图像,到音视频,再到用VR,将事物的描述表达推向了极致,充分满足了沉浸性.互动性和构想性三大要素的需求.随着5G的商业化运营,VR有望 ...

  4. the sdk seems invalid._直播平台中必不可少的美颜SDK

    随着科技的进步, 直播系统行业快速发展,美颜SDK已经成为直播平台中不可或缺的功能,大部分开发商都会选择在系统中接入美颜SDK.现如今,美颜SDK不仅仅具有磨皮美白的基础美颜功能,还基于人脸识别的技术 ...

  5. 直播平台中的美颜SDK技术探究

    而在直播过程中,美颜技术的应用已经成为了不可或缺的一部分.美颜技术能够让主播在镜头前变得更加漂亮自信,也能够提高直播的观看体验.在直播平台中,美颜SDK技术的探究就显得尤为重要. 一.美颜SDK技术的 ...

  6. 短视频、直播平台——电商直播源码第三方SDK接入教程

    现在网络视频直播行业非常火爆,所以很多公司也希望开发直播平台,一般直播平台需要用户给主播送礼物来实现盈利,所以刷礼物的功能是必备的,另外为了增加视频的美感与炫酷等特效功能,也需要用到美颜与视频滤镜等功 ...

  7. 华为云WeLink直播平台——为企业直播保驾护航

    2019年12月,华为云发布了WeLink智能工作台,为企业搭建数字化管理运作解决方案.近日,华为云在该平台的成功基础上,进一步推出全新的线上直播系统--WeLink直播系统,旨在打造更为高效.便捷的 ...

  8. 直播平台开发,直播各个分类单例设计展示

    直播平台开发,直播各个分类单例设计展示 一. 饿汉式实现 立即加载就是使用类的时候已经将对象创建完毕(不管以后会不会使用到该实例化对象,先创建了再说.很着急的样子,故又被称为"饿汉模式&qu ...

  9. 超过一成直播平台倒闭,直播创业何去何从?

    超过一成直播平台倒闭,直播创业何去何从?(转) 文/罗超 国庆长假期间,直播平台鼻祖Meerkat正式宣告下线,这个平台在2015年声名鹊起,然而随着Facebook Live和Twitter Per ...

最新文章

  1. from developer to data scientist cros entopy
  2. 为什么创业者专注做一个产品最好?
  3. 前端与移动开发之vue-day3(4)
  4. 名字正则只能是中文英文_【R语言新书】1.5 正则表达式
  5. sqlite 服务器数据库文件,sqlite可以做服务器数据库吗
  6. 中国芝麻市场竞争规模及销售渠道分析报告2022-2028年版
  7. 2019年六项扣除 个税计算器
  8. 西藏自治区市谷歌高清卫星地图下载
  9. Redis imgrate迁移键 (error) ERR Target instance replied with error: NOAUTH Authentication required.
  10. Maven-POM.xml
  11. 微软:12代酷睿处理器,须升级win11才能发挥出最大的性能
  12. Vpp源码解读--workhandoff处理
  13. JS验证电话和传真号码格式
  14. 计算机万金油专业,为什么说自动化专业是万金油专业
  15. 如果更有效预防应力作用?PCB设计如何考虑应力作用? 应力对元器件失效问题的讨论
  16. 仪表放大器放大倍数分析-运算放大器
  17. NPDP产品经理小知识:新产品开发中的管道管理
  18. 二、CSS 精灵(雪碧图、精灵图)
  19. 如何给插画上色?怎么上色才好看?
  20. django入门操作3

热门文章

  1. 结构体测验:按时间顺序给出奥运会的获奖情况,根据获奖情况输出当前奥运金牌榜。
  2. 六项精进-箴言集总结
  3. OC 获取view相对位置_三晶变频器启动跳OC维修故障处理
  4. 网络知识扫盲,一文搞懂 DNS
  5. Qlikview里的Set 和 Let 的区别
  6. [python爬虫] Selenium定向爬取海量精美图片及搜索引擎杂谈
  7. MongoDB分片副本集搭建
  8. qcap 教程_說說 Wine + QQ 輕聊版 7.7 的安裝步驟
  9. 旋流除砂器的应用原理以及在水除砂分离中的应用优势
  10. ajax用户注册验证视频,jquery+ajax实现注册实时验证实例详解