feat: 更新 README,重构部署教程,优化 Docker 部署说明和配置示例

main
katelya 2025-09-01 23:14:26 +08:00
parent dc336af4da
commit d639bbe415
1 changed files with 320 additions and 86 deletions

406
README.md
View File

@ -25,135 +25,369 @@
本项目自「MoonTV」演进而来为其二创/继承版本,持续维护与改进功能与体验。保留并致谢原作者与社区贡献者;如有授权或版权问题请联系以处理。目标:在原作基础上提供更易部署、更友好、更稳定的体验。
## 🚀 部署(概览 + 实操)
## 🚀 部署教程
支持 3 大路径:**Docker推荐生产 / Vercel免服务器 / Cloudflare Pages + Workers适合 D1**。
> **💡 推荐方案**:新手优先选择 **Docker 单容器**(最简单),需要多用户再升级到 **Docker + Redis**
### 1. 选型快速指引
| 你的需求 | 推荐方案 | 存储模式 | 说明 |
| -------- | -------- | -------- | ---- |
| 个人本机 / NAS / VPS 一条命令跑起来 | Docker 单容器 | localstorage | 无账号体系,仅本设备浏览器保存记录 |
| 多用户 / 同步观看记录 / 简单可维护 | Docker + Redis (Compose) | redis | 稳定高性能,可控数据 |
| 免费托管 + 轻度使用 | Vercel | localstorage / upstash | localstorage 无多用户Upstash 提供云 Redis |
| 需要使用 Cloudflare D1 | Cloudflare Pages + D1 | d1 | 使用 Cloudflare 边缘与 D1 数据库 |
| 不方便自建 Redis 又要同步 | Vercel + Upstash / Docker + Upstash | upstash | Upstash 提供 HTTP API |
<div align="center">
### 2. 存储支持矩阵
| | Docker | Vercel | Cloudflare |
| :-----------: | :----: | :----: | :--------: |
| localstorage | ✅ | ✅ | ✅ |
| 原生 redis | ✅ | | |
| Cloudflare D1 | | | ✅ |
| Upstash Redis | ✅ | ✅ | ☑️ |
### 📋 部署方式对比
说明:非 localstorage 模式才有多账户、云同步、管理后台 `/admin`
| 方式 | 难度 | 成本 | 多用户 | 推荐场景 |
|------|------|------|--------|----------|
| 🐳 **Docker 单容器** | ⭐ | 需服务器 | ❌ | 个人使用,最简单 |
| 🐳 **Docker + Redis** | ⭐⭐ | 需服务器 | ✅ | 家庭/团队,功能完整 |
| ☁️ **Vercel** | ⭐ | 免费 | ❌ | 临时体验,无服务器 |
| 🌐 **Cloudflare** | ⭐⭐⭐ | 免费 | ✅ | 技术爱好者 |
</div>
---
### 3. Docker 最小启动
## 🎯 方案一Docker 单容器(推荐新手)
> **适合场景**:个人使用,有服务器/NAS/电脑,想要最简单的部署方式
### 🔧 前置要求
- 一台能联网的设备(服务器/NAS/Windows/Mac/Linux 都行)
- 已安装 Docker[Docker 官网下载](https://www.docker.com/get-started/)
### 📝 详细步骤
#### 第一步:拉取镜像
```bash
# 下载最新版本镜像(支持 ARM 和 x86 架构)
docker pull ghcr.io/katelya77/katelyatv:latest
```
#### 第二步:启动容器
```bash
# 一键启动(请把 your_password 改成你的密码)
docker run -d \
--name katelyatv \
-p 3000:3000 \
--env PASSWORD=替换为你的访问密码 \
--env PASSWORD=your_password \
--restart unless-stopped \
ghcr.io/katelya77/katelyatv:latest
```
访问http://服务器IP:3000 (首次输入 PASSWORD
挂载自定义源:
> **Windows 用户注意**:在 PowerShell 中运行上述命令
#### 第三步:访问应用
1. 打开浏览器,访问:`http://你的服务器IP:3000`
2. 如果是本机安装,访问:`http://localhost:3000`
3. 输入你在第二步设置的密码即可进入
#### 第四步:自定义资源站(可选)
如果你有自己的资源站配置,可以挂载 `config.json` 文件:
```bash
docker run -d --name katelyatv -p 3000:3000 \
-v $(pwd)/config.json:/app/config.json:ro \
--env PASSWORD=你的密码 \
# 先停止并删除旧容器
docker stop katelyatv && docker rm katelyatv
# 重新运行并挂载配置文件
docker run -d \
--name katelyatv \
-p 3000:3000 \
--env PASSWORD=your_password \
-v /path/to/your/config.json:/app/config.json:ro \
--restart unless-stopped \
ghcr.io/katelya77/katelyatv:latest
```
PowerShell 可用:`-v C:/data/katelya/config.json:/app/config.json:ro`
需要多用户:请看下文 Docker Compose Redis。
> **路径说明**:把 `/path/to/your/config.json` 替换成你的配置文件完整路径
> **Windows 示例**`-v C:/Users/你的用户名/Desktop/config.json:/app/config.json:ro`
---
### 4. Vercel 部署
#### 4.1 localstorage
1. Fork 仓库 → Import 到 Vercel
2. 添加环境变量:`PASSWORD=你的访问密码`
3. Deploy
4. (可选)修改 `config.json` 后 Push 自动重建
#### 4.2 Upstash 模式
1. 完成 4.1
2. Upstash 创建 Redis 获取 HTTPS Endpoint & REST Token
3. 添加变量:`UPSTASH_URL` / `UPSTASH_TOKEN` / `NEXT_PUBLIC_STORAGE_TYPE=upstash` / `USERNAME` / `PASSWORD`
4. Redeploy → 登录 admin → `/admin`
---
### 5. Cloudflare Pages
输出目录:`.vercel/output/static`;启用:`nodejs_compat`。
构建命令三选一:
### 🛠️ 常用管理命令
```bash
npm install && npm run pages:build
corepack enable && pnpm install --frozen-lockfile && pnpm run pages:build
npm i -g pnpm@8 && pnpm install --frozen-lockfile && pnpm run pages:build
# 查看运行状态
docker ps
# 查看日志
docker logs katelyatv
# 重启应用
docker restart katelyatv
# 停止应用
docker stop katelyatv
# 删除容器
docker rm katelyatv
```
#### 5.1 localstorage
1. Fork → Pages 导入
2. 设置构建命令 & 输出目录
3. 首次构建后添加 `PASSWORD`
4. 重新部署
#### 5.2 D1
1. 完成 5.1 可访问
2. 创建 D1 数据库并执行 `D1初始化.md` 里的 SQL
3. Pages 绑定 D1 变量名 `DB`
4. 添加:`NEXT_PUBLIC_STORAGE_TYPE=d1`、`USERNAME`、`PASSWORD`
5. 重新部署 → admin 登录配置
#### 5.3 常见问题
| 问题 | 现象 | 解决 |
| ---- | ---- | ---- |
| 未找到静态输出 | 404 | 确认构建命令正确执行 & 日志无报错 |
| 访问被拒 | 403 | 检查是否设置 PASSWORD |
| D1 失败 | 500/绑定错误 | 确认绑定名 `DB` 且 SQL 初始化完成 |
---
### 6. RedisDocker Compose快速示例
```yaml
## 🎯 方案二Docker + Redis推荐进阶
> **适合场景**:多人使用,需要账号系统、观看记录同步、收藏功能
### 🔧 前置要求
- 已完成方案一,确认单容器版本能正常运行
- 了解基本的 Docker Compose 概念
### 📝 详细步骤
#### 第一步:创建配置文件
在你的服务器上创建一个文件夹,比如 `/opt/katelyatv`
```bash
# 创建目录
mkdir -p /opt/katelyatv
cd /opt/katelyatv
# 创建 docker-compose.yml 文件
cat > docker-compose.yml << 'EOF'
version: '3.8'
services:
# KatelyaTV 主应用
katelyatv:
image: ghcr.io/katelya77/katelyatv:latest
container_name: katelyatv
ports:
- "3000:3000"
environment:
# 管理员账号(请修改)
- USERNAME=admin
- PASSWORD=强密码
- PASSWORD=your_strong_password
# 启用 Redis 存储
- NEXT_PUBLIC_STORAGE_TYPE=redis
- REDIS_URL=redis://katelyatv-redis:6379
# 允许用户注册(可选)
- NEXT_PUBLIC_ENABLE_REGISTER=true
depends_on:
katelyatv-redis:
condition: service_healthy
restart: unless-stopped
# 可选:挂载自定义配置
# volumes:
# - ./config.json:/app/config.json:ro
# Redis 数据库
katelyatv-redis:
image: redis:7-alpine
container_name: katelyatv-redis
command: redis-server --appendonly yes --maxmemory 256mb --maxmemory-policy allkeys-lru
volumes:
- katelyatv-redis-data:/data
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 3s
retries: 3
restart: unless-stopped
volumes:
katelyatv-redis-data:
EOF
```
#### 第二步:修改配置
编辑 `docker-compose.yml` 文件,**必须修改**以下内容:
- `PASSWORD=your_strong_password` 改成你的强密码
- `USERNAME=admin` 可以改成你喜欢的管理员用户名
#### 第三步:启动服务
```bash
# 启动所有服务
docker compose up -d
# 查看启动状态
docker compose ps
```
#### 第四步:验证部署
1. 访问 `http://你的服务器IP:3000`
2. 使用你设置的用户名和密码登录
3. 登录后访问 `http://你的服务器IP:3000/admin` 进入管理后台
4. 在管理后台可以配置资源站、管理用户等
### 🛠️ 管理命令
```bash
# 查看所有服务状态
docker compose ps
# 查看日志
docker compose logs -f
# 重启所有服务
docker compose restart
# 停止所有服务
docker compose down
# 更新到最新版本
docker compose pull
docker compose up -d
```
### 💾 备份数据
```bash
# 备份 Redis 数据
docker run --rm -v katelyatv-redis-data:/data -v $(pwd):/backup alpine tar czf /backup/redis-backup-$(date +%Y%m%d).tar.gz /data
# 恢复数据(如果需要)
docker run --rm -v katelyatv-redis-data:/data -v $(pwd):/backup alpine tar xzf /backup/redis-backup-20241201.tar.gz -C /
```
启动:`docker compose up -d`
---
### 7. 环境变量最小清单
| 场景 | 必填 | 说明 |
| ---- | ---- | ---- |
| localstorage | PASSWORD | 全站访问密码 |
| redis | USERNAME / PASSWORD / NEXT_PUBLIC_STORAGE_TYPE=redis / REDIS_URL | 多用户 + 同步 |
| upstash | USERNAME / PASSWORD / NEXT_PUBLIC_STORAGE_TYPE=upstash / UPSTASH_URL / UPSTASH_TOKEN | 云 Redis |
| d1 | USERNAME / PASSWORD / NEXT_PUBLIC_STORAGE_TYPE=d1 / DB | 需预初始化 |
## 🎯 方案三Vercel 部署(免服务器)
> **适合场景**:没有服务器,想要快速体验,个人使用
### 🔧 前置要求
- GitHub 账号
- Vercel 账号(可用 GitHub 登录)
### 📝 详细步骤
#### 第一步Fork 仓库
1. 打开 [KatelyaTV GitHub 页面](https://github.com/katelya77/KatelyaTV)
2. 点击右上角 **Fork** 按钮
3. 等待 Fork 完成
#### 第二步:部署到 Vercel
1. 访问 [Vercel](https://vercel.com/),用 GitHub 账号登录
2. 点击 **Add New... → Project**
3. 找到你刚才 Fork 的 `KatelyaTV` 仓库,点击 **Import**
4. 在 **Environment Variables** 部分添加:
- Key: `PASSWORD`
- Value: `你的访问密码`(这是进入网站的密码)
5. 点击 **Deploy** 开始部署
#### 第三步:等待部署完成
- 通常需要 2-3 分钟
- 部署成功后会显示域名,比如 `https://your-project.vercel.app`
#### 第四步:访问和使用
1. 点击 Vercel 提供的域名链接
2. 输入你在第二步设置的密码
3. 开始使用!
### 🔧 自定义资源站
如果你想添加自己的资源站:
1. 在你 Fork 的仓库中找到 `config.json` 文件
2. 点击编辑按钮(铅笔图标)
3. 修改配置内容
4. 点击 **Commit changes**
5. Vercel 会自动重新部署
### ⚠️ 注意事项
- Vercel 版本不支持用户注册和账号系统
- 观看记录保存在浏览器本地,换设备会丢失
- 如果需要多用户功能,请考虑 Docker + Redis 方案
---
### 8. 升级 / 备份
| 操作 | Docker | Compose |
| ---- | ------ | ------- |
| 升级 | 拉新镜像重建容器 | pull + up -d |
| 备份 | 复制 config.json | 备份 Redis 卷 |
| 日志 | docker logs -f | docker compose logs -f |
到这里你已经可以完成部署;继续阅读下方获取更全面的 Docker / Compose 说明。
## 🎯 方案四Cloudflare Pages进阶用户
> **适合场景**:技术爱好者,想要全球 CDN 加速,免费但配置复杂
### 🔧 前置要求
- GitHub 账号
- Cloudflare 账号
- 对前端构建有基本了解
### 📝 详细步骤
#### 第一步Fork 仓库并连接
1. Fork [KatelyaTV 仓库](https://github.com/katelya77/KatelyaTV)
2. 登录 [Cloudflare](https://cloudflare.com)
3. 进入 **Workers 和 Pages** → 点击 **创建应用程序**
4. 选择 **Pages****连接到 Git**
5. 选择你 Fork 的仓库
#### 第二步:配置构建设置
在构建设置页面填写:
- **构建命令**: `npm install && npm run pages:build`
- **构建输出目录**: `.vercel/output/static`
- **Root directory**: `./`(默认)
#### 第三步:设置兼容性
1. 点击 **保存并部署**
2. 等待首次构建完成(可能会失败,没关系)
3. 进入项目 **设置** → **兼容性标志**
4. 添加标志: `nodejs_compat`
#### 第四步:添加环境变量
**设置** → **环境变量** 中添加:
- `PASSWORD`: 你的访问密码
#### 第五步:重新部署
1. 进入 **部署** 页面
2. 点击最新部署旁的 **...** → **重试部署**
3. 等待部署成功
### 🗄️ 启用 D1 数据库(可选,支持多用户)
如果你想要用户系统和数据同步:
#### 第一步:创建 D1 数据库
1. 在 Cloudflare Dashboard 进入 **存储和数据库** → **D1 SQL 数据库**
2. 点击 **创建数据库**,名称随意(比如 `katelyatv-db`
#### 第二步:初始化数据库
1. 进入刚创建的数据库
2. 点击 **Explore Data**
3. 打开项目中的 `D1初始化.md` 文件,复制所有 SQL 语句
4. 粘贴到查询窗口,点击 **Run All**
#### 第三步:绑定数据库
1. 回到 Pages 项目设置
2. 进入 **绑定** → **添加绑定**
3. 选择 **D1 数据库**
4. 变量名: `DB`
5. 选择你刚创建的数据库
#### 第四步:添加环境变量
在环境变量中追加:
- `NEXT_PUBLIC_STORAGE_TYPE`: `d1`
- `USERNAME`: 管理员用户名
- `PASSWORD`: 管理员密码
#### 第五步:重新部署
重新部署后,你就可以:
- 使用管理员账号登录
- 访问 `/admin` 管理后台
- 支持用户注册和数据同步
---
## 🆙 升级和维护
### Docker 升级
```bash
# 单容器版本
docker stop katelyatv
docker rm katelyatv
docker pull ghcr.io/katelya77/katelyatv:latest
# 然后重新运行启动命令
# Compose 版本
docker compose pull
docker compose up -d
```
### Vercel 升级
- 自动升级:当原仓库更新时,你的 Fork 仓库会收到更新提示
- 手动升级:在你的 Fork 仓库点击 **Sync fork** 按钮
### Cloudflare 升级
- 同 Vercel通过 Git 同步自动触发重新构建
### 🚨 常见问题排查
| 问题 | 现象 | 解决方法 |
|------|------|----------|
| 无法访问 | 浏览器显示无法连接 | 检查端口 3000 是否开放,防火墙设置 |
| 403 Forbidden | 显示访问被拒绝 | 检查 PASSWORD 环境变量是否设置正确 |
| Docker 启动失败 | 容器无法启动 | 查看日志 `docker logs katelyatv` |
| Redis 连接失败 | 无法登录或保存数据 | 检查 Redis 容器是否正常运行 |
| 构建失败 | Vercel/Cloudflare 部署失败 | 查看构建日志,检查环境变量设置 |
需要帮助?可以在 [GitHub Issues](https://github.com/katelya77/KatelyaTV/issues) 提问。
## 🐳 Docker
推荐方式。镜像多架构 (`linux/amd64`,`linux/arm64`),基于 Alpine体积小启动快。