docker 搭建 nginx+rtmp+hls(ffmpeg) 直播服务

其他阅读: ​​​​​​​docker nginx zip_Ubuntu中使用Nginx+rtmp模块搭建流媒体视频点播服务_weixin_39822629的博客-CSDN博客1. 背景不知不觉笔者来到流媒体部门已经一年半多了,积攒了不少的流媒体知识,但平时工作也比较忙,很少进行总结性的梳理,最近准备花几个周末时间写一个流媒体系列的实践文章,也算是给自己做总结的同时帮助有需要的开发者;在这一节中我们主要是通过nginx+rtmp模块搭建一个点播服务,就是你有很多视频文件,想让其他人观看就可以参考这篇文章,和笔者之前的一篇文章 使用PHP结合Ffmpeg快速搭建流媒体服务...https://blog.csdn.net/weixin_39822629/article/details/110488219


使用nginx搭建点播和直播流媒体服务器的方法步骤 - Nginx - 服务器之家本篇文章主要介绍了使用nginx搭建点播和直播流媒体服务器的方法步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧icon-default.png?t=M4ADhttp://www.zzvips.com/article/39011.html​​​​​​​​​​​​​​

1、环境准备

docker 镜像:tiangolo/nginx-rtmp:latest

ffmpeg 本文基于版本:ffmpeg 4.4.1-static


2、制作镜像

2.1 创建目录并进入目录

mkdir rtmp && cd rtmp

2.2  编写 nginx.conf

worker_processes auto;
rtmp_auto_push on;
events { }
#直播流配置
rtmp {
  server {
    #端口
    listen 1935;
    # RTMP 直播流配置
    application rtmplive {
      # 非常重要, 设定让ngnix断开阻塞中的连接, 才能触发exec_record_done
      # 以及客户端的LFLiveKit reconnectCount自动重新连接才会好用
      drop_idle_publisher 5s;
      live on;
    }
    # HLS 直播流配置
    application hls {
      live on;
      record all;
      record_path /tmp;
      record_max_size 10485760K;
      record_unique off;
      record_append on;
      hls on;
      hls_path /tmp;
      hls_fragment 5s;
    }
  }
}
# HLS 拉流配置(vlc播放 http://127.0.0.1:8080/hls/XXX.m3u8,其中http://127.0.0.1:8080/hls/为下面location的值,XXX为具体推流的配置)
http {
  server {
    listen 8080;
    location /hls {
      types {
        application /vnd.apple.mpegurl m3u8;
        video /mp2t ts;
      }
      #访问权限开启,否则访问这个地址会报403
      autoindex on;
      #视频流存放地址,与上面的hls_path相对应,这里root和alias的区别可自行百度
      alias /tmp;
      expires -1;
      add_header Cache-Control no-cache;
      #防止跨域问题
      add_header 'Access-Control-Allow-Origin' '*';
      add_header 'Access-Control-Allow-Credentials' 'true';
      add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
      add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
    }
  }
}

2.3 编写Dockerfile文件

FROM tiangolo/nginx-rtmp
COPY nginx.conf  /etc/nginx/nginx.conf

2.4 制作镜像

docker build -t trc-nginx-rtmp .

3、运行容器

docker run -d -p 1935:1935 -p 1900:8080 -v /tmp:/tmp --privileged=true --name trc-nginx-rtmp trc-nginx-rtmp

注意:

特别需要注意/Users/taoruicheng/temp文件夹的权限设置成777。
注意这里面开启了1935推流端口1900拉流端口

4、使用ffmpeg推流

4.1 推送rtsp流

ffmpeg -rtsp_transport tcp -i rtsp://admin:root@11.122.2.143:554 -vcodec copy -f flv -an rtmp://11.122.2.143:1935/hls/abc

(vlc播放地址:http://11.122.2.143:1900/hls/abc.m3u8)

4.2 推送本地文件

ffmpeg  -re -stream_loop -1 -i /Users/taoruicheng/工作资料目录/视频素材/仓xx.mp4 -vcodec copy -acodec copy -f flv  rtmp://11.122.2.143:1935/hls/xxx

(vlc播放地址:http://11.122.2.143:1900/hls/xxx.m3u8)

5、编写HTML程序进行播放

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>videojs-contrib-hls embed</title>
 
  <link href="https://unpkg.com/video.js/dist/video-js.css" rel="stylesheet">
  <script src="https://unpkg.com/video.js/dist/video.js"></script>
  <script src="https://unpkg.com/videojs-contrib-hls/dist/videojs-contrib-hls.js"></script>
  
</head>
<body>
  <h1>Video.js Example Embed</h1>
 
  <video id="my_video_1" class="video-js vjs-default-skin" controls preload="auto" width="640" height="268" 
  data-setup='{}'>
    <source src="http://11.122.2.143:1900/hls/xxx.m3u8" type="application/x-mpegURL">
  </video>
  
  <script>
  </script>
  
</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

戴国进

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值