news 2026/4/25 22:28:50

基于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/4/25 17:44:11

从夯到拉,锐评13个JavaWeb框架

先叠个甲 以下评价基于技术特性、生态成熟度、市场采用情况等客观维度&#xff0c;不代表对任何框架的贬低。 技术选型应根据具体场景&#xff0c;没有银弹。 不同项目有不同需求&#xff0c;合适的才是最好的。 评价维度说明 性能表现&#xff1a;吞吐量、响应时间、资源占…

作者头像 李华
网站建设 2026/4/17 3:53:23

国外的文献资料在哪里查?实用查询途径与方法指南

刚开始做科研的时候&#xff0c;我一直以为&#xff1a; 文献检索就是在知网、Google Scholar 里反复换关键词。 直到后来才意识到&#xff0c;真正消耗精力的不是“搜不到”&#xff0c;而是—— 你根本不知道最近这个领域发生了什么。 生成式 AI 出现之后&#xff0c;学术检…

作者头像 李华
网站建设 2026/4/25 21:11:04

互联网大厂Java求职面试实战:Spring Boot、微服务与AI技术全方位解析

互联网大厂Java求职面试实战&#xff1a;Spring Boot、微服务与AI技术全方位解析 场景背景 在一家大型互联网公司&#xff0c;严肃的面试官对求职者谢飞机进行了Java开发岗位面试。谢飞机是个幽默的程序员&#xff0c;面对简单问题能够顺利回答&#xff0c;复杂问题则回答略显…

作者头像 李华
网站建设 2026/4/24 1:19:48

Java版LeetCode热题100之下一个排列:深入解析与实战应用

Java版LeetCode热题100之下一个排列&#xff1a;深入解析与实战应用 本文目标&#xff1a;全面、系统地讲解 LeetCode 第31题「下一个排列」&#xff08;Next Permutation&#xff09;&#xff0c;从题目理解、算法推导、代码实现到面试技巧和实际应用场景&#xff0c;帮助你真…

作者头像 李华
网站建设 2026/4/16 12:12:20

飞凌嵌入式ElfBoard-系统信息与资源之休眠

在编写应用程序时多多少少会遇到需要程序等待一会&#xff0c;再执行下面的程序&#xff0c;这时候就需要延时函数来实现这个功能&#xff0c;本节就来介绍延时函数的使用。 一、sleep 用于使程序暂停执行一段时间&#xff0c;通常是以秒为单位。 1.头文件 #include <un…

作者头像 李华
网站建设 2026/4/25 18:54:57

基于YOLOv8的校园安全隐患识别系统研究与实现(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

基于YOLOv8的校园安全隐患识别系统研究与实现 本文提出并实现了一种基于YOLOv8目标检测算法的校园安全隐患识别系统&#xff0c;可对校园场景中6类典型安全隐患(人员摔倒、交通事故、物品破坏、斗殴行为、火灾、盗窃行为)进行自动识别与实时预警 研究过程中&#xff0c;首先构建…

作者头像 李华