news 2026/6/3 19:30:38

基于Docker部署M3U8流媒体

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于Docker部署M3U8流媒体

本方案基于Docker + Nginx-RTMP + Nginx,实现将本地 MP4 文件转换为 24/7 循环播放的 HLS (M3U8) 直播流。

一、 环境准备

1、操作系统

  • 已安装宝塔面板的 Linux 服务器(推荐 CentOS 7+ 或 Ubuntu 20.04+)。

2、基础软件

  • 宝塔面板内已安装Nginx
  • 系统已安装Docker(可在宝塔“软件商店”一键安装)。
  • 系统已安装FFmpeg(支持libx264的版本)

下载支持 libx264 的 FFmpeg:

https://johnvansickle.com/ffmpeg/releases/ffmpeg-release-amd64-static.tar.xz

解压后,将 ffmpeg 和 ffprobe 复制到 /usr/bin 目录下。

二、启动 Docker 容器

在终端执行以下命令,启动 RTMP 转流服务器。需要将 Docker 内部的流文件目录映射到宝塔的站点目录下,方便直接访问。

注意:先创建/hls文件夹。

docker run -d --name nginx-rtmp \ -p 1935:1935 \ -p 8088:8080 \ -v /projects/nginx.conf:/etc/nginx/nginx.conf \ -v /projects/hls:/opt/data/hls \ alfg/nginx-rtmp

启动后会生成 /projects/nginx.conf

里面包含推流的链接示例:

rtmp://localhost:1935/stream/$name

查看 docker 输出:

docker logs --tail 200 nginx-rtmp

三、设置 hls 目录权限

用 ACL 的“默认权限(default ACL)”,让将来新生成的所有文件/目录自动拥有权限,后面nginx访问不会再报错403/Permission denied

# 安装 ACL yum -y install acl # 永久读写执行权限 setfacl -R -m u:www:rwx /projects/hls # 保证新文件也有权限 setfacl -R -d -m u:www:rwx /projects/hls # 验证 getfacl /projects/hls | sed -n '1,20p'

四、启动 FFmpeg 循环推流

使用 FFmpeg 对视频裁剪+转码:

ffmpeg -i video.mp4 -t 00:15:00 -c:v libx264 -c:a aac output.mp4

启动循环推流:

nohup ffmpeg -re -stream_loop -1 -i /projects/input.mp4 -c:v libx264 -preset veryfast -tune zerolatency -profile:v baseline -level 3.1 -g 60 -keyint_min 60 -sc_threshold 0 -c:a aac -b:a 128k -ar 44100 -f flv "rtmp://127.0.0.1:1935/stream/test" > /tmp/log1.txt 2>&1 &

性能优化建议:

如果服务器 CPU 较弱,且 MP4 已经是 H.264 编码,可以将 -c:v libx264 改为 -c:v copy,这样可以极大降低 CPU 占用。

查看 /projects/hls 目录,看是否有生成 M3U8 文件和 ts 文件。

五、宝塔 Nginx 配置(HTTP / HTTPS 播放)

在 宝塔 → 网站 → 你的站点 → 配置文件 中加入:

location ^~ /hls/ { alias /projects/hls/; types { application/vnd.apple.mpegurl m3u8; video/mp2t ts; } add_header Cache-Control no-cache; add_header Access-Control-Allow-Origin * always; if ($request_method = OPTIONS) { return 204; } disable_symlinks off; }

查看 nginx 错误输出:

tail -n 30 /www/wwwlogs/my.domain.com.error.log

六、 播放与验证

直播流生成的地址如下,您可以使用 VLC 播放器或网页 HLS 播放器测试:

  • 视频流http://你的域名/hls/test_****/index.m3u8

在服务器上使用CURL指令测试视频流链接是否返回200

curl -I http://my.domain.com/hls/test_240p264kbs/index.m3u8

前端HTML嵌入视频流:

<video controls autoplay muted loop playsinline> <source src="http://my.domain.com/hls/test_720p2628kbs/index.m3u8" type="application/x-mpegURL"> 您的浏览器不支持 HLS 原生播放。 </video>
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 8:40:16

零碳园区:政策驱动下的智慧能源转型之路

在“双碳”目标引领下&#xff0c;园区作为产业集聚与能源消耗的重要载体&#xff0c;正面临绿色化、智慧化转型的迫切需求。近年来&#xff0c;国家陆续出台多项政策推动园区循环化改造与能源结构优化。例如&#xff0c;2021年《关于加快建立健全绿色低碳循环发展经济体系的指…

作者头像 李华
网站建设 2026/5/1 8:57:35

从0构建WAV文件:读懂计算机文件的本质

从0构建WAV文件&#xff1a;读懂计算机文件的本质 虽然接触计算机有一段时间了&#xff0c;但是我的视野一直局限于一个较小的范围之内&#xff0c;往往只能看到于算法竞赛相关的内容&#xff0c;计算机各种文件在我看来十分复杂&#xff0c;认为构建他们并能达到目的是一件困…

作者头像 李华
网站建设 2026/5/29 3:46:15

为什么程序员,越来越排斥面试时做题?

HR问&#xff1a;“以前线下笔试各种被程序员排斥&#xff0c;现在我用了线上测评&#xff0c;效果好多了&#xff0c;程序员会接受吗&#xff1f;”最近在知乎上发现这么一个话题&#xff1a;为什么程序员越来越排斥面试时做题&#xff1f;其中有几个回答挺有意思的&#xff0…

作者头像 李华
网站建设 2026/5/21 23:55:47

手绘贴图画断手?“AI 炼金术”3分钟量产风格化材质

对于场景地编来说&#xff0c;“风格化 PBR 材质” 是最耗时的。 手绘一张无缝贴图至少半天&#xff0c;还得要在 PS 里反复做“位移&#xff08;Offset&#xff09;”去修接缝。想把手绘图转成法线贴图&#xff1f;传统的 CrazyBump 效果太糙&#xff0c;在 Substance Designe…

作者头像 李华
网站建设 2026/5/31 6:06:29

机械制造领域网页,JAVA如何实现大文件的分块与秒传?

大文件传输系统技术方案 一、技术选型与架构设计 作为项目负责人&#xff0c;我主导设计了基于现有技术栈的混合架构方案&#xff1a; 前端架构&#xff1a;采用Vue2 CLI框架兼容模式&#xff0c;通过Webpack配置同时支持Vue2/Vue3组件&#xff0c;通过条件编译实现React项目…

作者头像 李华