Docker 部署 MoonTV 影视聚合播放器 🎬
📋 目录导航
🎯 项目简介
MoonTV
是一款开箱即用的跨平台影视聚合播放器,基于现代 Web 技术栈构建,提供丰富的影视内容和优质的用户体验。它支持多资源搜索、在线播放、收藏同步和播放记录等功能,让您可以随时随地畅享海量免费影视内容。🌟
✨ 核心特性
特性类别 |
功能描述 |
优势 |
🎥 多源聚合 |
整合多个影视资源,一站式搜索和播放 |
无需切换多个应用,统一管理所有资源 |
🌐 跨平台支持 |
支持 Web、移动端等多种设备 |
随时随地享受影视内容,无缝切换设备 |
💾 数据同步 |
支持收藏列表和播放记录同步 |
多设备间保持观看进度和收藏一致性 |
🎨 现代界面 |
基于 Next.js 14 + Tailwind CSS 的现代化界面 |
美观易用,操作流畅,提升用户体验 |
🔍 智能搜索 |
多资源并行搜索,快速找到想看的内容 |
高效检索,节省寻找资源的时间 |
📱 响应式设计 |
完美适配各种屏幕尺寸 |
在手机、平板、电脑上都能获得良好体验 |
🛡️ 广告拦截 |
内置广告拦截功能,提升观看体验 |
减少干扰,专注观影内容 |
🌙 夜间模式 |
支持暗色主题,保护眼睛减少疲劳 |
长时间观看更舒适,保护视力 |
🔄 实时更新 |
资源库定期更新,持续提供最新内容 |
始终能够获取最新的影视资源 |
🐳 一、Docker 部署 MoonTV
1. 创建部署目录和 docker-compose.yml
文件 📁
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
mkdir -p /mnt/mydisk/home/moontv && cd $_ && \
cat > docker-compose.yml <<'EOF'
services:
moontv:
image: ghcr.io/senshinya/moontv:latest
container_name: moontv
restart: unless-stopped
ports:
- "3133:3000" # 🌐 主机端口:容器端口
volumes:
- ./config.json:/app/config.json:ro # ⚙️ 配置文件(只读)
- ./data:/app/data # 💾 数据持久化目录
environment:
- TZ=Asia/Shanghai # ⏰ 时区设置
- NEXT_PUBLIC_STORAGE_TYPE=localstorage # 💾 存储类型
- NEXT_PUBLIC_ENABLE_BLOCKAD=true # 🛡️ 启用广告拦截
- NEXT_PUBLIC_SEARCH_MAX_PAGE=5 # 🔍 搜索最大页数
- NEXT_PUBLIC_AGGREGATE_SEARCH_RESULT=true # 📊 聚合搜索结果
EOF
|
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
|
cat > config.json <<'EOF'
{
"siteName": "MoonTV",
"description": "开源影视聚合播放器",
"keywords": "电影,电视剧,动漫,综艺,免费观看",
"defaultSearchSource": "all",
"sources": [
{
"name": "源1",
"url": "https://example.com/api/v1",
"enabled": true
},
{
"name": "源2",
"url": "https://example.com/api/v2",
"enabled": true
}
],
"player": {
"defaultQuality": "高清",
"autoPlayNext": true,
"rememberPosition": true
},
"ui": {
"theme": "auto",
"language": "zh-CN"
}
}
EOF
|
2. 拉取镜像并启动容器 🚀
🚀 二、使用 MoonTV
1. 访问 Web 界面 💻
- 本地访问:
http://localhost:3133
- 域名访问:
https://moontv.example.com
(配置反向代理后)
2. 主要功能 🎯
-
影视搜索 🔍
- 多源并行搜索,快速获取结果
- 智能结果聚合,去除重复内容
- 分类筛选功能,按类型、年份、地区筛选
-
在线播放 ▶️
- 支持多种视频格式和流媒体协议
- 多清晰度选择(标清、高清、超清)
- 完整的播放控制(暂停、快进、音量、字幕等)
-
个人中心 👤
- 收藏管理,创建个人片单
- 播放历史,记录观看轨迹
- 观看进度同步,多设备无缝切换
-
设置选项 ⚙️
- 播放器设置(默认清晰度、自动播放等)
- 界面主题(明亮/暗黑/自动)
- 数据管理(清除缓存、导出数据)
🌐 三、Nginx 反向代理配置
访问地址示例:
https://moontv.example.com
1. 创建 Nginx 配置文件 🔧
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
mkdir -p /etc/nginx/conf.d && \
cat > /etc/nginx/conf.d/moontv.conf <<'EOF'
server {
listen 443 ssl;
listen [::]:443 ssl;
server_name moontv.example.com; # 🌐 请替换为您的实际域名
# SSL 证书配置
ssl_certificate /etc/nginx/ssl/cert.pem;
ssl_certificate_key /etc/nginx/ssl/key.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_prefer_server_ciphers on;
ssl_ciphers ECDHE-RSA-AES256-GCM-SHA512:DHE-RSA-AES256-GCM-SHA512:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES256-GCM-SHA384;
# 安全头部
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
add_header X-Content-Type-Options nosniff always;
add_header X-Frame-Options "SAMEORIGIN" always;
add_header X-XSS-Protection "1; mode=block";
# 性能优化
sendfile on;
tcp_nopush on;
# 文件大小限制
client_max_body_size 100M;
location / {
proxy_pass http://localhost:3133;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Range $http_range;
proxy_set_header If-Range $http_if_range;
# WebSocket 支持
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
# 超时设置
proxy_connect_timeout 300s;
proxy_send_timeout 300s;
proxy_read_timeout 300s;
# 缓冲设置
proxy_buffering on;
proxy_buffer_size 4k;
proxy_buffers 8 16k;
proxy_busy_buffers_size 24k;
proxy_max_temp_file_size 0;
}
# 错误页面处理
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
EOF
|
2. 测试并重载 Nginx 🔄
1
|
sudo nginx -t && sudo systemctl reload nginx
|
🔧 四、容器维护命令
1. Docker Compose 命令 🐳
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
|
# 进入项目目录
cd /mnt/mydisk/home/moontv
# 停止并删除容器
docker-compose down
# 拉取最新镜像
docker-compose pull
# 启动容器
docker-compose up -d
# 查看服务状态
docker-compose ps
# 查看服务日志
docker-compose logs
# 跟踪服务日志
docker-compose logs -f
# 完整升级流程
docker-compose down && \
docker-compose pull && \
docker-compose up -d && \
docker image prune -f
|
2. Docker 容器命令 📦
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
|
# 查看所有容器名称
docker ps -a --format "{{.Names}}"
# 查看运行中容器
docker ps
# 停止/启动/重启容器
docker stop moontv # 停止容器
docker start moontv # 启动容器
docker restart moontv # 重启容器
# 删除容器
docker rm moontv # 删除已停止容器
docker rm -f moontv # 强制删除运行中容器
# 进入容器Shell
docker exec -it moontv sh # 使用sh进入容器
docker exec -it moontv bash # 使用bash进入容器
# 查看容器详情和资源使用
docker inspect moontv # 查看详细配置
docker stats moontv # 实时资源监控
## 容器日志管理
docker logs moontv # 查看日志
docker logs -f moontv # 实时跟踪日志
docker logs --tail 100 moontv # 查看最后100行
docker logs -t moontv # 带时间戳的日志
|
3. Docker 镜像管理 📀
1
2
3
4
|
docker images # 列出所有镜像
docker rmi <image_name:tag> # 删除指定镜像
docker image prune -f # 清理悬空镜像
docker image prune -a -f # 清理所有未使用镜像
|
🌟 启航影视,畅享无限
通过本文档,你已经成功使用 Docker 部署了 MoonTV 影视聚合播放器,并借助 Nginx 反向代理实现了安全便捷的远程访问。现在,你可以:
🎬 海量资源 畅享多源聚合的影视内容,涵盖电影、电视剧、动漫等多种类型
🌐 跨屏体验 多设备无缝切换,随时随地享受优质的观影体验
📊 智能管理 个人收藏和观看记录同步,打造专属的影视库
影视之路,是一场与精彩内容相伴的休闲时光。愿 MoonTV 成为你贴心的观影伙伴,陪伴你在每一个放松和娱乐的美好时刻。
从现在开始,随心观看,畅享影视——构建你专属的私人影院吧!🎉
📌 持续迭代:建议关注
MoonTV 官方更新
,及时获取新功能与优化。
🐛 反馈与互助:使用中如有疑问或建议,可前往
GitHub Issues
提出。
祝你观影愉快,享受每一刻!🎬