[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-82242":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":17,"stars7d":18,"stars30d":19,"stars90d":16,"forks30d":16,"starsTrendScore":19,"compositeScore":20,"rankGlobal":10,"rankLanguage":10,"license":21,"archived":22,"fork":22,"defaultBranch":23,"hasWiki":24,"hasPages":22,"topics":25,"createdAt":10,"pushedAt":10,"updatedAt":26,"readmeContent":27,"aiSummary":28,"trendingCount":16,"starSnapshotCount":16,"syncStatus":15,"lastSyncTime":29,"discoverSource":30},82242,"MediaStationGo","ShukeBta\u002FMediaStationGo","ShukeBta","MediaStationGo 是一个面向个人、家庭 NAS 与影音爱好者的开源媒体中心。它把「媒体库管理、自动刮削、在线播放、外部客户端兼容、PT 站点检索、订阅下载、AI 推荐」放进一个轻量的 Go 服务里，配合 React 前端提供统一、简洁、漂亮的三端体验。","https:\u002F\u002Fmgo.3jzs.com\u002F",null,"Go",90,14,21,2,0,5,30,36,72.13,"Other",false,"main",true,[],"2026-06-12 04:01:37","# MediaStationGo\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"web\u002Fpublic\u002Ffavicon.svg\" width=\"96\" height=\"96\" alt=\"MediaStationGo Logo\" \u002F>\n\u003C\u002Fp>\n\n\u003Ch3 align=\"center\">轻量、漂亮、NAS 友好的私人媒体中心\u003C\u002Fh3>\n\n\u003Cp align=\"center\">\n  \u003Cstrong>Go 单二进制后端 · React 现代化前端 · Docker 一键部署 · Emby API 兼容 · 多源刮削 · PT 订阅下载\u003C\u002Fstrong>\n\u003C\u002Fp>\n\n\u003Cp align=\"center\">\n  \u003Ca href=\"README_EN.md\">English\u003C\u002Fa> ·\n  \u003Ca href=\"#quick-start\">快速开始\u003C\u002Fa> ·\n  \u003Ca href=\"#docker-compose-deploy\">Docker 部署\u003C\u002Fa> ·\n  \u003Ca href=\"#screenshots\">界面预览\u003C\u002Fa> ·\n  \u003Ca href=\"https:\u002F\u002Fmgo.3jzs.com\">在线演示\u003C\u002Fa>\n\u003C\u002Fp>\n\n\u003Cp align=\"center\">\n  \u003Cimg alt=\"Go\" src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FGo-1.25+-00ADD8?style=flat-square&logo=go&logoColor=white\" \u002F>\n  \u003Cimg alt=\"React\" src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FReact-18-61DAFB?style=flat-square&logo=react&logoColor=111827\" \u002F>\n  \u003Cimg alt=\"TypeScript\" src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FTypeScript-5-3178C6?style=flat-square&logo=typescript&logoColor=white\" \u002F>\n  \u003Cimg alt=\"Docker\" src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FDocker-ready-2496ED?style=flat-square&logo=docker&logoColor=white\" \u002F>\n  \u003Cimg alt=\"License\" src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FLicense-GPL--3.0-blue?style=flat-square\" \u002F>\n  \u003Cimg alt=\"Use\" src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FUse-Non--Commercial-orange?style=flat-square\" \u002F>\n\u003C\u002Fp>\n\n---\n\n## ✨ 项目简介\n\nMediaStationGo 是一个面向个人、家庭 NAS 与影音爱好者的开源媒体中心。它把「媒体库管理、自动刮削、在线播放、外部客户端兼容、PT 站点检索、订阅下载、AI 推荐」放进一个轻量的 Go 服务里，配合 React 前端提供统一、简洁、漂亮的三端体验。\n\n它适合这些场景：\n\n- 家里有 NAS \u002F Windows 主机 \u002F Linux 小主机，希望统一管理电影、剧集、动漫、综艺、成人内容。\n- 想使用 TMDb、豆瓣、Bangumi、TheTVDB、Fanart、JavBus\u002FJavDB 等多源元数据补全海报、简介、分季分集信息。\n- 想把 PT 站点搜索、订阅、下载器、下载后整理集中到一个 Web 面板中。\n- 想让 Infuse、VidHub、SenPlayer 等外部客户端通过 Emby 风格接口访问媒体库。\n- 想要一个部署简单、便于二次开发、不会把密钥和私有 Token 暴露到前端的开源项目。\n\n> 当前项目仍在快速迭代中，建议固定镜像版本部署，并定期备份 `\u002Fdata` 目录。\n\n---\n\n## 🌱 开源承诺\n\nMediaStationGo 采用完全开源路线，核心媒体库、刮削、播放、订阅、下载、外部客户端兼容与运维能力均在本仓库持续迭代。项目参考了 MoviePilot 等优秀开源项目在「站点聚合、订阅下载、媒体整理、Emby\u002FJellyfin 客户端兼容」上的产品思路，但本项目会保持独立实现，不直接复制不兼容代码。\n\n本项目当前基础许可证为 `GPL-3.0`，欢迎基于 GPL-3.0 协议参与改造、适配站点、提交刮削规则与优化 UI。项目作者同时倡议：本项目面向个人学习、家庭 NAS、自建影音与非商业场景使用，未经作者明确书面许可，不得将本项目或其衍生版本用于商业售卖、商业托管、付费 SaaS、预装售卖设备、闭源二次分发或其他商业化牟利用途。\n\n> 说明：GPL-3.0 是自由软件许可证，其正式授权范围以仓库 [LICENSE](LICENSE) 文件为准；上方「非商用承诺」表达项目维护者的使用边界与商业合作要求。如需商业合作、企业部署或二次发行，请先联系作者获得额外授权。\n\n### 源码开放与 Docker 部署边界\n\n- 当前公开仓库继续以 `GPL-3.0` 作为基础许可证；如果代码包含 GPL 派生实现，不能通过“只发布 Docker 镜像”规避对应源码提供义务。\n- 可以把官方部署策略收敛为 **Docker-first \u002F Docker-only support**：即项目只承诺维护 Docker Compose、GHCR 镜像和容器部署文档，裸机运行与二进制包可作为社区自助能力。\n- 若未来需要部分闭源，可能将闭源能力拆成独立插件、独立服务或私有模块，并确保该部分为作者自有或兼容许可证的干净实现；GPL 覆盖代码仍应按 GPL 公开。\n- README 中的非商用声明是维护者的使用边界与商业授权要求；正式代码授权仍以 [LICENSE](LICENSE) 为准。\n\n---\n\n## 🚀 在线演示\n\n- 演示站：[https:\u002F\u002Fmgo.3jzs.com](https:\u002F\u002Fmgo.3jzs.com)\n- 默认账号：`admin`\n- 默认密码：`admin123`\n\n> 演示环境仅用于功能体验，请勿上传真实隐私信息或配置私人 API Key。\n\n---\n\n## 🧭 功能总览\n\n| 模块 | 能力 |\n| --- | --- |\n| 媒体库 | 电影、电视剧、动漫、综艺、音乐、成人内容；支持文件夹封面、合集、季、集展示 |\n| 扫描识别 | 递归扫描、ffprobe 探测、文件名解析、季集识别、综艺节目识别、重复扫描去重 |\n| 本地元数据 | 优先读取 NFO、poster、fanart、season poster、episode image、本地成人影片图片 |\n| 在线刮削 | TMDb、TheTVDB、Bangumi、豆瓣、Fanart.tv、JavBus\u002FJavDB 页面直爬补全 |\n| 播放体验 | 直链播放、HTTP Range 拖动、HLS 转码、外挂字幕、播放进度、继续观看、外部播放器 |\n| 发现与搜索 | TMDb \u002F 豆瓣 \u002F Bangumi 多源推荐，智能搜索，详情页订阅入口 |\n| PT 站点 | 站点管理、M-Team API Token、站点搜索、种子链接解析、下载器联动 |\n| 订阅下载 | RSS \u002F 站点搜索订阅，分辨率\u002F质量\u002F特效\u002F发布组\u002F排除词规则，洗版开关与优先级 |\n| 下载中心 | qBittorrent 任务状态、速度、进度、上传下载体积、小卡片海报展示、私有 URL 脱敏 |\n| 外部兼容 | Emby\u002FJellyfin 风格 API，兼容 Infuse、VidHub、SenPlayer 等外部客户端 |\n| AI 能力 | OpenAI Compatible API 配置，AI 搜索、推荐、运维助手 |\n| 运维工具 | 运行状态、任务队列、重复文件、回收站、文件管理、存储配置、通知渠道 |\n\n---\n\n\u003Ca id=\"screenshots\">\u003C\u002Fa>\n\n## 🖼️ 界面预览\n\n> 以下截图使用 Codex 内置浏览器从当前运行实例采集，并已对个人媒体内容、本地路径、账号信息、API Key\u002FToken\u002F密钥等敏感信息做图像级打码处理。\n\n\u003Cdetails open>\n\u003Csummary>\u003Cstrong>核心体验\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n| 登录与首页 | 媒体库总览 |\n| --- | --- |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F00-login.jpg\" alt=\"登录界面\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F01-home.jpg\" alt=\"系统首页\" width=\"100%\"> |\n| 媒体库总览 | 媒体库详情 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F02-libraries.jpg\" alt=\"媒体库总览\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F03-library-detail.jpg\" alt=\"媒体库详情\" width=\"100%\"> |\n| 海报墙 | 媒体详情 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F04-poster-wall.jpg\" alt=\"海报墙\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F05-media-detail.jpg\" alt=\"媒体详情\" width=\"100%\"> |\n| 播放器 | 精彩发现 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F06-player.jpg\" alt=\"播放器\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F07-discover.jpg\" alt=\"精彩发现\" width=\"100%\"> |\n| 智能搜索 | DLNA 投屏 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F08-search.jpg\" alt=\"智能搜索\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F09-dlna.jpg\" alt=\"DLNA 投屏\" width=\"100%\"> |\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>个人空间与播放管理\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n| AI 助理 | 我的收藏 |\n| --- | --- |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F10-ai.jpg\" alt=\"AI 助理\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F11-favourites.jpg\" alt=\"我的收藏\" width=\"100%\"> |\n| 播放列表 | 观看历史 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F12-playlists.jpg\" alt=\"播放列表\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F13-history.jpg\" alt=\"观看历史\" width=\"100%\"> |\n| 账号信息 | 下载中心 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F14-profile.jpg\" alt=\"账号信息\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F15-downloads.jpg\" alt=\"下载中心\" width=\"100%\"> |\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>下载订阅与站点\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n| 下载器管理 | 订阅管理 |\n| --- | --- |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F16-download-clients.jpg\" alt=\"下载器管理\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F17-subscriptions.jpg\" alt=\"订阅管理\" width=\"100%\"> |\n| 站点检索 | 站点与下载器 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F18-site-search.jpg\" alt=\"站点检索\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F20-sites.jpg\" alt=\"站点与下载器\" width=\"100%\"> |\n\n\u003C\u002Fdetails>\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>管理与运维\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n| 媒体与用户 | 整理与维护 |\n| --- | --- |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F19-admin.jpg\" alt=\"媒体与用户\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F21-tools.jpg\" alt=\"整理与维护\" width=\"100%\"> |\n| 存储与文件 | 运行状态 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F22-storage.jpg\" alt=\"存储与文件\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F23-stats.jpg\" alt=\"运行状态\" width=\"100%\"> |\n| 系统设置 | 任务队列 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F24-settings.jpg\" alt=\"系统设置\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F25-tasks.jpg\" alt=\"任务队列\" width=\"100%\"> |\n| 重复文件 | 回收站 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F26-duplicates.jpg\" alt=\"重复文件\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F27-recycle.jpg\" alt=\"回收站\" width=\"100%\"> |\n| 调度任务 | 文件管理 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F28-scheduler.jpg\" alt=\"调度任务\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F29-files.jpg\" alt=\"文件管理\" width=\"100%\"> |\n| STRM 管理 | 存储配置 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F30-strm.jpg\" alt=\"STRM 管理\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F31-storage-config.jpg\" alt=\"存储配置\" width=\"100%\"> |\n| 通知渠道 | AI 运维助手 |\n| \u003Cimg src=\"docs\u002Fscreenshots\u002F32-notify-channels.jpg\" alt=\"通知渠道\" width=\"100%\"> | \u003Cimg src=\"docs\u002Fscreenshots\u002F33-assistant.jpg\" alt=\"AI 运维助手\" width=\"100%\"> |\n\n\u003C\u002Fdetails>\n\n---\n\n## 🧱 技术栈\n\n| 层级 | 技术 | 说明 |\n| --- | --- | --- |\n| 后端语言 | Go 1.25+ | 单二进制部署，启动快，资源占用低 |\n| Web 框架 | Gin | REST API、鉴权中间件、静态资源托管 |\n| 数据库 | SQLite + GORM | 适合个人\u002FNAS 场景，数据文件易备份 |\n| 前端框架 | React 18 + TypeScript | 组件化 UI，类型安全 |\n| 构建工具 | Vite | 前端快速开发与生产打包 |\n| 样式系统 | Tailwind CSS | 统一浅色高级视觉方案与响应式布局 |\n| 状态管理 | Zustand | 轻量全局状态与鉴权状态维护 |\n| 播放链路 | HTML5 Video \u002F HLS \u002F FFmpeg | 直链、Range、HLS 转码、字幕 |\n| 元数据 | TMDb \u002F 豆瓣 \u002F Bangumi \u002F TheTVDB \u002F Fanart \u002F JavBus \u002F JavDB | 多源补全海报、简介、评分、分季分集 |\n| 下载联动 | qBittorrent \u002F PT Site Adapter | 站点搜索、订阅、下载任务展示与脱敏 |\n| 外部兼容 | Emby-style API \u002F DLNA | 面向外部播放器与三端客户端 |\n| 部署 | Docker \u002F Docker Compose \u002F Shell \u002F PowerShell | NAS、Linux、Windows 均可部署 |\n| CI\u002FCD | GitHub Actions \u002F GHCR | 版本标签或手动 Actions 自动发布多架构镜像与 Release 包 |\n\n---\n\n\u003Ca id=\"quick-start\">\u003C\u002Fa>\n\n## 📦 快速开始\n\n\u003Ca id=\"docker-compose-deploy\">\u003C\u002Fa>\n\n### Docker Compose 部署（推荐）\n\nDocker 是最稳定、最容易迁移的部署方式。默认会创建四类目录：\n\n| 宿主机目录 | 容器目录 | 作用 |\n| --- | --- | --- |\n| `.\u002Fdata` | `\u002Fdata` | 数据库、JWT secret、运行时配置，必须备份 |\n| `.\u002Fcache` | `\u002Fcache` | 海报、背景图、刮削缓存、转码缓存 |\n| `.\u002Fmedia` | `\u002Fmedia` | 媒体库根目录，默认只读挂载 |\n| `.\u002Fdownloads` | `\u002Fdownloads` | 订阅\u002F站点下载保存目录 |\n\n#### Linux \u002F NAS 从零部署教程（不克隆源码）\n\n适合 Ubuntu、Debian、CentOS、AlmaLinux、Rocky Linux、群晖\u002F威联通类 Linux 环境。以下命令默认在服务器终端执行。\n\n> Docker 安装脚本来自第三方镜像脚本，适合国内网络快速安装；如果你是生产服务器，也可以改用 Docker 官方文档安装。\n\n1. 安装 Docker：\n\n```bash\nbash \u003C(curl -sSL https:\u002F\u002Fcdn.jsdelivr.net\u002Fgh\u002FSuperManito\u002FLinuxMirrors@main\u002FDockerInstallation.sh)\n\ndocker --version\n```\n\n2. 安装 Docker Compose：\n\n```bash\ncurl -L \"https:\u002F\u002Fgithub.com\u002Fdocker\u002Fcompose\u002Freleases\u002Flatest\u002Fdownload\u002Fdocker-compose-$(uname -s)-$(uname -m)\" -o \u002Fusr\u002Flocal\u002Fbin\u002Fdocker-compose\nchmod +x \u002Fusr\u002Flocal\u002Fbin\u002Fdocker-compose\n\ndocker-compose version\n```\n\n> 如果写入 `\u002Fusr\u002Flocal\u002Fbin\u002Fdocker-compose` 提示权限不足，请在 `curl` 和 `chmod` 前加 `sudo`。\n\n> 如果你的系统已经支持 `docker compose version`，可以继续使用 `docker compose`；如果只安装了上面的独立二进制，请把后续命令中的 `docker compose` 替换为 `docker-compose`。\n\n3. 创建部署目录：\n\n```bash\nmkdir -p ~\u002FMediaStationGo\ncd ~\u002FMediaStationGo\nmkdir -p data cache media downloads\n```\n\n4. 创建 `.env`，按你的 NAS 路径填写。推荐使用“NAS 绝对路径直读模式”，网页里就可以直接填写 `\u002Fvol1\u002F...` 原始路径：\n\n```bash\ncat > .env \u003C\u003C'EOF'\n# 固定版本；需要升级时改成新的 MediaStationGo-vX.Y.Z 后执行 docker compose pull && docker compose up -d\nMEDIASTATION_IMAGE_TAG=MediaStationGo-v0.0.32\nMEDIASTATION_HTTP_PORT=18080\n\n# 程序数据和缓存建议放在 MediaStationGo 部署目录下，便于备份和迁移。\nMEDIASTATION_DATA_DIR=.\u002Fdata\nMEDIASTATION_CACHE_DIR=.\u002Fcache\n\n# NAS \u002F 飞牛直读模式：左侧宿主机路径与右侧容器路径保持一致。\n# 这样添加媒体库时直接填写 \u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电视剧\u002F国产剧。\nMEDIASTATION_MEDIA_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\nMEDIASTATION_MEDIA_CONTAINER_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\n\n# 下载目录同样保持一致，方便 qBittorrent、MediaStationGo、站点订阅共用同一个保存路径。\nMEDIASTATION_DOWNLOAD_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\nMEDIASTATION_DOWNLOAD_CONTAINER_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\n\n# 如果 NAS 已使用 v2rayA redirect \u002F 透明代理，不要在这里额外配置 HTTP_PROXY，避免叠加代理。\n\nTZ=Asia\u002FShanghai\nPUID=1000\nPGID=1000\nEOF\n```\n\n> 重点：不要写 `.\u002Fvol1\u002F1000\u002F...`。`.\u002Fvol1` 代表当前部署目录下的 `vol1` 子目录，最终会变成类似 `\u002Fvol1\u002F1000\u002FDocker\u002FMediaStationGo\u002Fvol1\u002F...` 这种错误路径。正确写法必须以 `\u002Fvol1\u002F...` 开头。\n\n如果你只是本地测试，没有现成 NAS 媒体目录，也可以改回部署目录下的测试目录：\n\n```env\nMEDIASTATION_MEDIA_DIR=.\u002Fmedia\nMEDIASTATION_MEDIA_CONTAINER_DIR=\u002Fmedia\nMEDIASTATION_DOWNLOAD_DIR=.\u002Fdownloads\nMEDIASTATION_DOWNLOAD_CONTAINER_DIR=\u002Fdownloads\n```\n\n5. 下载默认 `docker-compose.yml`：\n\n```bash\ncurl -fsSL https:\u002F\u002Fraw.githubusercontent.com\u002FShukeBta\u002FMediaStationGo\u002Fmain\u002Fdocker-compose.yml -o docker-compose.yml\n```\n\n如果无法访问 GitHub Raw，也可以手动创建：\n\n```bash\nvi docker-compose.yml\n# 或\nvim docker-compose.yml\n```\n\n然后粘贴下面的模板。\n\n\u003Cdetails>\n\u003Csummary>\u003Cstrong>展开查看完整 docker-compose.yml 模板\u003C\u002Fstrong>\u003C\u002Fsummary>\n\n```yaml\n# MediaStationGo 默认 Docker Compose 部署文件。\n#\n# 快速开始：\n#   1. 按需修改下方 volumes 的宿主机路径。\n#   2. docker compose pull\n#   3. docker compose up -d\n#   4. 浏览器打开 http:\u002F\u002F\u003C服务器IP>:18080\n#\n# 默认账号：\n#   admin \u002F admin123\n#   首次部署后请立即到「个人资料\u002F用户管理」修改密码。\n#\n# 镜像版本：\n#   默认拉取 latest；如需固定版本，创建 .env 并写入：\n#     MEDIASTATION_IMAGE_TAG=MediaStationGo-v0.0.32\n#\n# 路径映射总览：\n#   \u002Fdata      程序数据目录。保存 SQLite 数据库、JWT secret、系统配置等，必须持久化。\n#   \u002Fcache     缓存目录。保存海报、刮削图片、转码缓存等，建议放在空间较大的磁盘。\n#   \u002Fmedia     媒体库只读挂载目录。网页中添加媒体库时填写容器内路径，例如 \u002Fmedia\u002FMovies。\n#   \u002Fdownloads 下载目录。下载器保存路径建议填写容器内路径，例如 \u002Fdownloads\u002FMovies。\n#\n# 宿主机路径建议：\n#   MEDIASTATION_DATA_DIR=.\u002Fdata\n#   MEDIASTATION_CACHE_DIR=.\u002Fcache\n#   MEDIASTATION_MEDIA_DIR=\u002Fmnt\u002Fnas\u002Fmedia\n#   MEDIASTATION_DOWNLOAD_DIR=\u002Fmnt\u002Fnas\u002Fdownloads\n#\n# NAS \u002F 飞牛路径必须使用绝对路径，例如：\n#   MEDIASTATION_MEDIA_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\n#   MEDIASTATION_DOWNLOAD_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\n# 不要写成 .\u002Fvol1\u002F...；.\u002Fvol1 会被 Docker Compose 解析为当前部署目录下的相对路径。\n#\n# 注意：\n#   1. 如果 qBittorrent\u002FTransmission\u002FAria2 不在本 compose 内，请确保它们能访问同一份\n#      下载目录；容器内保存路径和下载器实际保存路径需要保持一致或可被媒体库扫描到。\n#   2. 媒体库默认以只读方式挂载，避免误删原始媒体；如果需要整理\u002F移动文件，可将\n#      \u002Fmedia 的 :ro 改为 :rw，或把整理目标放到 \u002Fdownloads 后再手动迁移。\n#   3. PUID\u002FPGID 用于匹配 NAS\u002FLinux 宿主机用户权限，避免下载或缓存文件权限异常。\n\nservices:\n  mediastation-go:\n    image: ghcr.io\u002Fshukebta\u002Fmediastation-go:${MEDIASTATION_IMAGE_TAG:-latest}\n    # 默认只在本地没有镜像时拉取，避免每次重启都访问 GHCR。\n    # 需要升级时手动执行：docker compose pull && docker compose up -d\n    pull_policy: missing\n    container_name: mediastation-go\n    restart: unless-stopped\n\n    ports:\n      # 宿主机端口:容器端口。默认访问 http:\u002F\u002F\u003C服务器IP>:18080\n      - \"${MEDIASTATION_HTTP_PORT:-18080}:8080\"\n\n    volumes:\n      # 程序持久化数据：数据库、JWT secret、运行时配置。\n      - ${MEDIASTATION_DATA_DIR:-.\u002Fdata}:\u002Fdata\n\n      # 海报\u002F背景图\u002F转码缓存。可删除重建，但会重新下载图片和生成缓存。\n      - ${MEDIASTATION_CACHE_DIR:-.\u002Fcache}:\u002Fcache\n\n      # 媒体库根目录。添加媒体库时使用容器内路径：\n      #   电影：\u002Fmedia\u002FMovies\n      #   剧集：\u002Fmedia\u002FTV\n      #   动漫：\u002Fmedia\u002FAnime\n      #   综艺：\u002Fmedia\u002FVariety\n      # 如宿主机目录不同，请在 .env 中设置 MEDIASTATION_MEDIA_DIR。\n      # NAS \u002F 飞牛等系统请写绝对路径，例如：\n      #   MEDIASTATION_MEDIA_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\n      # 不要写 .\u002Fvol1\u002F...，否则会变成当前部署目录下的 vol1 子目录。\n      # 默认映射到容器 \u002Fmedia；如需在网页中直接填写宿主机绝对路径，可将\n      # MEDIASTATION_MEDIA_CONTAINER_DIR 设置为同一个 \u002Fvol1\u002F... 路径。\n      - ${MEDIASTATION_MEDIA_DIR:-.\u002Fmedia}:${MEDIASTATION_MEDIA_CONTAINER_DIR:-\u002Fmedia}:ro\n\n      # 下载保存目录。订阅\u002F站点下载的保存路径建议使用：\n      #   \u002Fdownloads\u002FMovies\n      #   \u002Fdownloads\u002FTV\n      #   \u002Fdownloads\u002FAnime\n      #   \u002Fdownloads\u002FVariety\n      # 如果外部下载器也运行在 Docker 中，请给下载器挂载同一个宿主机目录。\n      # NAS \u002F 飞牛等系统请写绝对路径，例如：\n      #   MEDIASTATION_DOWNLOAD_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\n      # 不要写 .\u002Fvol1\u002F...，否则下载目录会被映射到当前部署目录下面。\n      # 默认映射到容器 \u002Fdownloads；如需下载器和应用都使用宿主机绝对路径，可将\n      # MEDIASTATION_DOWNLOAD_CONTAINER_DIR 设置为同一个 \u002Fvol1\u002F... 路径。\n      - ${MEDIASTATION_DOWNLOAD_DIR:-.\u002Fdownloads}:${MEDIASTATION_DOWNLOAD_CONTAINER_DIR:-\u002Fdownloads}\n\n    environment:\n      # Web 服务监听配置。容器内固定监听 8080，对外端口由上方 ports 控制。\n      MEDIASTATION_APP_HOST: 0.0.0.0\n      MEDIASTATION_APP_PORT: 8080\n      MEDIASTATION_APP_WEB_DIR: \u002Fapp\u002Fweb\u002Fdist\n\n      # 数据与缓存目录。需与 volumes 中的容器路径一致。\n      MEDIASTATION_APP_DATA_DIR: \u002Fdata\n      MEDIASTATION_DATABASE_DB_PATH: \u002Fdata\u002Fmediastation.db\n      MEDIASTATION_CACHE_CACHE_DIR: \u002Fcache\n\n      # 宿主机到容器的路径映射提示。用于用户误填宿主机路径时自动转换为容器路径：\n      #   \u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电视剧 -> \u002Fmedia\u002F电视剧\n      #   \u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\u002F国产剧 -> \u002Fdownloads\u002F国产剧\n      MEDIASTATION_MEDIA_DIR: ${MEDIASTATION_MEDIA_DIR:-.\u002Fmedia}\n      MEDIASTATION_MEDIA_CONTAINER_DIR: ${MEDIASTATION_MEDIA_CONTAINER_DIR:-\u002Fmedia}\n      MEDIASTATION_DOWNLOAD_DIR: ${MEDIASTATION_DOWNLOAD_DIR:-.\u002Fdownloads}\n      MEDIASTATION_DOWNLOAD_CONTAINER_DIR: ${MEDIASTATION_DOWNLOAD_CONTAINER_DIR:-\u002Fdownloads}\n\n      # 日志级别：debug \u002F info \u002F warn \u002F error。\n      MEDIASTATION_LOGGING_LEVEL: ${MEDIASTATION_LOGGING_LEVEL:-info}\n\n      # 转码配置。留空表示自动\u002F软件转码；硬件加速见下方 Intel\u002FNVIDIA 示例。\n      MEDIASTATION_TRANSCODER_ENABLED: ${MEDIASTATION_TRANSCODER_ENABLED:-true}\n      MEDIASTATION_TRANSCODER_HARDWARE_ACCEL: ${MEDIASTATION_TRANSCODER_HARDWARE_ACCEL:-false}\n      MEDIASTATION_TRANSCODER_ENCODER: ${MEDIASTATION_TRANSCODER_ENCODER:-}\n      MEDIASTATION_TRANSCODER_MAX_HEIGHT: ${MEDIASTATION_TRANSCODER_MAX_HEIGHT:-1080}\n      MEDIASTATION_TRANSCODER_REALTIME: ${MEDIASTATION_TRANSCODER_REALTIME:-true}\n      MEDIASTATION_TRANSCODER_THREADS: ${MEDIASTATION_TRANSCODER_THREADS:-2}\n      MEDIASTATION_TRANSCODER_MAX_CONCURRENT: ${MEDIASTATION_TRANSCODER_MAX_CONCURRENT:-1}\n      MEDIASTATION_TRANSCODER_IDLE_TIMEOUT_SECONDS: ${MEDIASTATION_TRANSCODER_IDLE_TIMEOUT_SECONDS:-120}\n\n      # 跨域来源。通常无需设置；反向代理或三端客户端异常时再按需填写。\n      MEDIASTATION_APP_CORS_ORIGINS: ${MEDIASTATION_APP_CORS_ORIGINS:-}\n\n      # 宿主机文件权限映射。Linux\u002FNAS 常用 1000:1000，可用 id 命令查看。\n      PUID: ${PUID:-1000}\n      PGID: ${PGID:-1000}\n      TZ: ${TZ:-Asia\u002FShanghai}\n\n    # Intel QSV \u002F VAAPI 硬件加速示例：\n    #   1. Linux\u002FNAS 宿主机存在 \u002Fdev\u002Fdri。\n    #   2. 在 .env 中设置 MEDIASTATION_TRANSCODER_HARDWARE_ACCEL=true\n    #      和 MEDIASTATION_TRANSCODER_ENCODER=vaapi。\n    #   3. 取消下方 devices\u002Fgroup_add 注释。\n    # devices:\n    #   - \u002Fdev\u002Fdri:\u002Fdev\u002Fdri\n    # group_add:\n    #   - \"${RENDER_GID:-989}\"\n\n    # NVIDIA NVENC 硬件加速示例：\n    #   1. 宿主机安装 NVIDIA Container Toolkit。\n    #   2. 在 .env 中设置 MEDIASTATION_TRANSCODER_HARDWARE_ACCEL=true\n    #      和 MEDIASTATION_TRANSCODER_ENCODER=nvenc。\n    #   3. 取消下方 gpus 注释。\n    # gpus: all\n\n    healthcheck:\n      test: [\"CMD-SHELL\", \"wget -qO- http:\u002F\u002F127.0.0.1:8080\u002Fapi\u002Fhealth || exit 1\"]\n      interval: 30s\n      timeout: 10s\n      retries: 5\n      start_period: 30s\n```\n\n\u003C\u002Fdetails>\n\n6. 启动服务：\n\n```bash\n# Docker Compose v2\ndocker compose pull\ndocker compose up -d\n\n# 如果你的系统只有 docker-compose 命令，则使用：\n# docker-compose pull\n# docker-compose up -d\n```\n\n如果是升级已有部署，建议使用仓库提供的更新脚本。它会先拉取并重建容器，再只清理 `ghcr.io\u002Fshukebta\u002Fmediastation-go` 的旧镜像和 dangling 层，避免 NAS 磁盘被历史镜像占满：\n\n```bash\ncurl -fsSL https:\u002F\u002Fcdn.jsdelivr.net\u002Fgh\u002FShukeBta\u002FMediaStationGo@main\u002Fscripts\u002Fdocker-compose-update.sh -o docker-compose-update.sh\nchmod +x docker-compose-update.sh\n.\u002Fdocker-compose-update.sh\n```\n\n7. 查看状态与日志：\n\n```bash\ndocker compose ps\ndocker compose logs -f mediastation-go\n\n# 或：\n# docker-compose ps\n# docker-compose logs -f mediastation-go\n```\n\n8. 浏览器访问：\n\n```text\nhttp:\u002F\u002F\u003C服务器IP>:18080\n```\n\n默认账号：\n\n```text\n用户名：admin\n密码：admin123\n```\n\n> 首次登录后请立即修改管理员密码。如果局域网无法访问，请检查服务器防火墙、安全组、NAS 防火墙，以及 `18080:8080` 端口映射是否生效。\n\n#### 已有源码仓库的快速启动\n\n如果你是开发者或已经克隆源码，也可以直接使用仓库内置的 `docker-compose.yml`：\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002FShukeBta\u002FMediaStationGo.git\ncd MediaStationGo\n\ndocker compose pull\ndocker compose up -d\n```\n\n后续升级建议在部署目录执行：\n\n```bash\n.\u002Fdocker-compose-update.sh\n```\n\n### 固定版本部署\n\n建议生产环境固定版本，避免 `latest` 自动变化。NAS 直读推荐 `.env`：\n\n```bash\ncat > .env \u003C\u003C'EOF'\nMEDIASTATION_IMAGE_TAG=MediaStationGo-v0.0.32\nMEDIASTATION_HTTP_PORT=18080\nMEDIASTATION_DATA_DIR=.\u002Fdata\nMEDIASTATION_CACHE_DIR=.\u002Fcache\nMEDIASTATION_MEDIA_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\nMEDIASTATION_MEDIA_CONTAINER_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\nMEDIASTATION_DOWNLOAD_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\nMEDIASTATION_DOWNLOAD_CONTAINER_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\nTZ=Asia\u002FShanghai\nPUID=1000\nPGID=1000\nEOF\n\ndocker compose pull\ndocker compose up -d\n```\n\n### 媒体库路径怎么填\n\n#### 宿主机路径与容器路径的关系\n\nDocker Compose 左侧是宿主机真实目录，右侧是容器内目录。宿主机绝对路径会直接读取 NAS 原目录，不会复制到部署目录，也不会多套一层 `MediaStationGo\u002Fvol1`。\n\n```yaml\n# 宿主机真实路径                     # 容器内路径\n- \u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia:\u002Fmedia:ro\n- \u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads:\u002Fdownloads\n```\n\n容器内只需要使用 `\u002Fmedia` 和 `\u002Fdownloads`。如果你看到 `\u002Fvol1\u002F1000\u002FDocker\u002FMediaStationGo\u002Fvol1\u002F...`，说明 `.env` 或 compose 里把路径写成了 `.\u002Fvol1\u002F...`，需要去掉前面的点，改为 `\u002Fvol1\u002F...`。\n\n> 如果你在添加媒体库时填写了 `\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电视剧\u002F国产剧` 并提示不可访问，原因是应用在容器内运行，默认只能看到 `\u002Fmedia\u002F电视剧\u002F国产剧`。新版 compose 会把宿主机路径作为映射提示传入容器，尽量自动纠正；但最推荐、最稳定的填写方式仍然是容器路径 `\u002Fmedia\u002F...`。\n\n如果你更希望“页面里直接填写 NAS 绝对路径”，可以把宿主机路径和容器路径设置成完全一致，这不会复制文件，也不会多占空间：\n\n```env\nMEDIASTATION_MEDIA_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\nMEDIASTATION_MEDIA_CONTAINER_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\nMEDIASTATION_DOWNLOAD_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\nMEDIASTATION_DOWNLOAD_CONTAINER_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\n```\n\n对应 compose 实际效果等价于：\n\n```yaml\n- \u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia:\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia:ro\n- \u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads:\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\n```\n\n这样添加媒体库时就可以直接填写 `\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电视剧\u002F国产剧`。\n\n推荐添加媒体库路径示例：\n\n| 媒体库 | 页面填写路径 | 类型 |\n| --- | --- | --- |\n| 华语电影 \u002F 外语电影 \u002F 动画电影 | `\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电影` | 电影 |\n| 国产剧 \u002F 欧美剧 \u002F 日韩剧 \u002F 国漫 \u002F 日番 \u002F 综艺 | `\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电视剧` | 电视剧 \u002F 动漫 \u002F 综艺 |\n| 下载根目录 | `\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads` | 下载器保存路径 |\n\n如果你只想添加更细的分类目录，也可以填 `\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电视剧\u002F国产剧`；系统会直接扫描这个目录，不会复制、不搬家。\n\n> 安全策略：扫描和播放只读取原目录；“整理整个库”不会再搬动已经位于媒体库目录内的文件，避免本地 NFO、海报、字幕等元数据被迁移后丢失。下载完成后的自动整理仍然默认关闭，只有你手动打开后才会移动下载目录中的新文件。\n\n如果 compose 中这样挂载：\n\n```yaml\n- \u002Fmnt\u002Fnas\u002Fmedia:\u002Fmedia:ro\n- \u002Fmnt\u002Fnas\u002Fdownloads:\u002Fdownloads\n```\n\n那么在 Web 管理页面中添加媒体库时应填写容器内路径，例如：\n\n| 类型 | 推荐路径 |\n| --- | --- |\n| 电影媒体库 | `\u002Fmedia\u002F电影` |\n| 剧集\u002F动漫\u002F综艺媒体库 | `\u002Fmedia\u002F电视剧` |\n| 成人内容 | `\u002Fmedia\u002FAdult` |\n| 下载根目录 | `\u002Fdownloads` |\n\n#### NAS 绝对路径写法\n\nNAS、飞牛、绿联、群晖、威联通等系统里，媒体目录通常是系统绝对路径。compose 中必须写 `\u002Fvol1\u002F...`、`\u002Fvolume1\u002F...`、`\u002Fmnt\u002F...` 这类从根目录开始的路径，不要写成 `.\u002Fvol1\u002F...`。\n\n```yaml\n# 正确：宿主机绝对路径\n- \u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia:\u002Fmedia:ro\n- \u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads:\u002Fdownloads\n\n# 错误：这是相对当前 compose 目录的路径\n- .\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia:\u002Fmedia:ro\n- .\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads:\u002Fdownloads\n```\n\n也可以放到 `.env` 里统一管理：\n\n```env\nMEDIASTATION_MEDIA_DIR=\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\nMEDIASTATION_DOWNLOAD_DIR=\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\n```\n\n容器内媒体库建议添加 `\u002Fmedia\u002F电影` 和 `\u002Fmedia\u002F电视剧` 两个根目录；整理后会自动进入 `\u002Fmedia\u002F电影\u002F动画电影`、`\u002Fmedia\u002F电视剧\u002F国产剧` 等分类目录。下载器保存根目录填写 `\u002Fdownloads`，订阅下载会自动落到 `\u002Fdownloads\u002F动画电影`、`\u002Fdownloads\u002F国产剧` 等分类目录。\n\n### 外网访问与 v2rayA 说明\n\n如果 NAS 已经开启 v2rayA 的 `redirect` \u002F 透明代理，并使用大陆白名单分流，MediaStationGo 通常不需要额外配置 `HTTP_PROXY` \u002F `HTTPS_PROXY`。\n\n不建议在 `docker-compose.yml` 或 `.env` 中重复配置代理环境变量，因为这会让容器网络和 Docker 拉镜像路径叠加代理，反而可能导致 GHCR、M-Team、TMDB 等访问异常。\n\n排查外网链路时，先从容器内直接测试：\n\n```bash\ndocker exec -it mediastation-go sh -lc 'wget -S -O- --timeout=20 https:\u002F\u002Fapi.m-team.cc\u002Fapi\u002Ftorrent\u002Fsearch'\n```\n\n如果这里仍然卡在 TLS 阶段，应优先检查 v2rayA 的 redirect 规则、Docker 网桥流量是否被透明代理接管，而不是给 Docker daemon 或 compose 叠加 `HTTP_PROXY`。\n\n### qBittorrent 连接怎么填\n\n如果 qBittorrent 运行在同一台 NAS\u002F宿主机上，MediaStationGo 容器里不要优先填 `127.0.0.1`；`127.0.0.1` 代表 MediaStationGo 容器自己。推荐在「下载器管理」中填写：\n\n```text\nhttp:\u002F\u002Fhost.docker.internal:8085\n```\n\n仓库默认 `docker-compose.yml` 已配置：\n\n```yaml\nextra_hosts:\n  - \"host.docker.internal:host-gateway\"\n```\n\n如果你填写 `http:\u002F\u002F你的IP:8085` 超时，但 `http:\u002F\u002F172.17.0.?(使用了代理):8085` 返回 403，通常表示：\n\n- Docker 容器到局域网 IP 存在防火墙、路由或 hairpin 限制，建议改用 `host.docker.internal`。\n- qBittorrent WebUI 已经能被容器访问，但登录被拒绝。请检查用户名\u002F密码、IP 封禁、CSRF\u002FHost Header 校验。\n- qBittorrent WebUI 设置里建议确认：监听地址为 `0.0.0.0` 或所有地址；端口为 `8085`；解除\u002F关闭连续失败后的 IP 封禁；必要时把 `host.docker.internal`、`172.17.0.1`、NAS 局域网 IP 加入允许域名\u002F白名单，或关闭 Host Header 校验。\n\n可在 NAS 上用下面命令快速验证 qBittorrent 登录：\n\n```bash\ndocker exec -it mediastation-go sh -lc 'wget -S -O- --post-data=\"username=你的用户名&password=你的密码\" http:\u002F\u002Fhost.docker.internal:8085\u002Fapi\u002Fv2\u002Fauth\u002Flogin'\n```\n\n返回 `Ok.` 才表示账号和 qBittorrent WebUI 配置都正常。返回 `Forbidden` \u002F `403` 时先去 qBittorrent WebUI 解除封禁和检查安全设置。\n\n### 下载器路径怎么填\n\n如果 qBittorrent 也运行在 Docker 中，必须让 qBittorrent 与 MediaStationGo 看到同一份下载目录。\n\n建议统一约定：\n\n```text\n宿主机：\u002Fmnt\u002Fnas\u002Fdownloads\nMediaStationGo 容器：\u002Fdownloads\nqBittorrent 容器：\u002Fdownloads\n```\n\n订阅保存根目录建议填写：\n\n```text\n\u002Fdownloads\n```\n\n启用智能分类后，订阅或站点搜索下载会根据媒体类别自动进入：\n\n```text\n\u002Fdownloads\u002F动画电影\n\u002Fdownloads\u002F华语电影\n\u002Fdownloads\u002F外语电影\n\u002Fdownloads\u002F国产剧\n\u002Fdownloads\u002F国漫\n\u002Fdownloads\u002F日番\n\u002Fdownloads\u002F欧美剧\n\u002Fdownloads\u002F日韩剧\n\u002Fdownloads\u002F综艺\n```\n\n---\n\n## 🐳 Docker Compose 配置示例\n\n项目已内置详细注释版 `docker-compose.yml`，可直接使用。常用变量如下：\n\n| 变量 | 默认值 | 说明 |\n| --- | --- | --- |\n| `MEDIASTATION_IMAGE_TAG` | `latest` | 镜像标签，建议固定为 Release 版本 |\n| `MEDIASTATION_HTTP_PORT` | `18080` | 宿主机访问端口 |\n| `MEDIASTATION_DATA_DIR` | `.\u002Fdata` | 数据持久化目录 |\n| `MEDIASTATION_CACHE_DIR` | `.\u002Fcache` | 图片和转码缓存目录 |\n| `MEDIASTATION_MEDIA_DIR` | `.\u002Fmedia` | 媒体库宿主机目录；NAS 建议写 `\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia` 这种绝对路径 |\n| `MEDIASTATION_MEDIA_CONTAINER_DIR` | `\u002Fmedia` | 容器内媒体路径；如想页面直接填写 `\u002Fvol1\u002F...`，可设置成与 `MEDIASTATION_MEDIA_DIR` 相同 |\n| `MEDIASTATION_DOWNLOAD_DIR` | `.\u002Fdownloads` | 下载保存宿主机目录；NAS 建议写 `\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads` 这种绝对路径 |\n| `MEDIASTATION_DOWNLOAD_CONTAINER_DIR` | `\u002Fdownloads` | 容器内下载路径；如想下载器保存路径直接使用 `\u002Fvol1\u002F...`，可设置成与 `MEDIASTATION_DOWNLOAD_DIR` 相同 |\n| `PUID` \u002F `PGID` | `1000` \u002F `1000` | Linux\u002FNAS 文件权限映射 |\n| `TZ` | `Asia\u002FShanghai` | 容器时区 |\n\n查看日志：\n\n```bash\ndocker logs -f mediastation-go\n```\n\n更新镜像：\n\n```bash\ncurl -fsSL https:\u002F\u002Fcdn.jsdelivr.net\u002Fgh\u002FShukeBta\u002FMediaStationGo@main\u002Fscripts\u002Fdocker-compose-update.sh -o docker-compose-update.sh\nchmod +x docker-compose-update.sh\n.\u002Fdocker-compose-update.sh\n```\n\n说明：普通 `docker compose pull && docker compose up -d` 只会切换到新镜像，不会自动删除旧镜像；上面的脚本会保留当前正在运行的 MediaStationGo 镜像，删除同仓库未使用的旧镜像，并执行 `docker image prune -f` 清理 dangling 层。如需进一步清理所有未使用镜像，可临时执行 `PRUNE_ALL_UNUSED=1 .\u002Fdocker-compose-update.sh`。\n\n停止服务：\n\n```bash\ndocker compose down\n```\n\n备份数据：\n\n```bash\ntar -czf mediastationgo-data-backup.tgz .\u002Fdata\n```\n\n---\n\n## 🖥️ 一键脚本部署\n\n如果不想使用 Docker，也可以裸机运行。脚本会自动构建前端、编译后端、启动服务并检查健康状态。\n\n### Linux \u002F macOS\n\n```bash\ngit clone https:\u002F\u002Fgithub.com\u002FShukeBta\u002FMediaStationGo.git\ncd MediaStationGo\nchmod +x scripts\u002Fdeploy.sh\nPORT=18080 DATA_DIR=\u002Fopt\u002Fmediastation\u002Fdata CACHE_DIR=\u002Fopt\u002Fmediastation\u002Fcache .\u002Fscripts\u002Fdeploy.sh\n```\n\n### Windows PowerShell\n\n```powershell\ngit clone https:\u002F\u002Fgithub.com\u002FShukeBta\u002FMediaStationGo.git\ncd MediaStationGo\n.\\scripts\\deploy.ps1 -Port 18080 -DataDir D:\\MediaStationGo\\data -CacheDir D:\\MediaStationGo\\cache\n```\n\n脚本执行内容：\n\n1. 安装前端依赖并构建 `web\u002Fdist`\n2. 编译 Go 服务端到 `bin\u002F`\n3. 创建数据目录和缓存目录\n4. 停止旧进程并启动新进程\n5. 请求 `\u002Fapi\u002Fhealth` 验证服务状态\n\n---\n\n## 🧩 Release 包部署\n\n每个 Release 会提供多平台压缩包：\n\n| 平台 | 包名示例 |\n| --- | --- |\n| Linux x86_64 | `MediaStationGo-v0.0.32-linux-amd64.tar.gz` |\n| Linux ARM64 | `MediaStationGo-v0.0.32-linux-arm64.tar.gz` |\n| Windows x86_64 | `MediaStationGo-v0.0.32-windows-amd64.zip` |\n| macOS Intel | `MediaStationGo-v0.0.32-darwin-amd64.tar.gz` |\n| macOS Apple Silicon | `MediaStationGo-v0.0.32-darwin-arm64.tar.gz` |\n\n部署步骤：\n\n```bash\n# Linux 示例\ntar -xzf MediaStationGo-v0.0.32-linux-amd64.tar.gz\ncd MediaStationGo-v0.0.32-linux-amd64\nMEDIASTATION_APP_PORT=18080 .\u002Fmediastation-go\n```\n\nWindows：\n\n```powershell\nExpand-Archive .\\MediaStationGo-v0.0.32-windows-amd64.zip\ncd .\\MediaStationGo-v0.0.32-windows-amd64\n$env:MEDIASTATION_APP_PORT = \"18080\"\n.\\mediastation-go.exe\n```\n\n> Release 二进制默认监听 `8080`，如果希望和 Docker 示例保持一致，请按上方设置 `MEDIASTATION_APP_PORT=18080`。\n\n---\n\n## 🛠️ 本地开发\n\n### 环境要求\n\n| 组件 | 版本 | 用途 |\n| --- | --- | --- |\n| Go | 1.25+ | 后端编译与测试 |\n| Node.js | 20+ | 前端构建 |\n| FFmpeg \u002F ffprobe | 推荐安装 | 媒体探测与转码 |\n| Docker | 可选 | 容器部署与多架构镜像 |\n| qBittorrent | 可选 | 下载器联动测试 |\n\n### 本地构建\n\n```bash\ncp config.example.yaml config.yaml\ncd web\nnpm ci\nnpm run build\ncd ..\ngo build -o bin\u002Fmediastation-go .\u002Fcmd\u002Fserver\n.\u002Fbin\u002Fmediastation-go\n```\n\nWindows：\n\n```powershell\nCopy-Item config.example.yaml config.yaml\nSet-Location web\nnpm ci\nnpm run build\nSet-Location ..\ngo build -o bin\\mediastation-go.exe .\\cmd\\server\n.\\bin\\mediastation-go.exe\n```\n\n### 常用命令\n\n```bash\nmake build       # 构建前后端\nmake test        # 运行 Go 测试\nmake smoke       # 冒烟测试\nmake docker      # docker compose up -d\nmake deploy      # Linux 一键部署\nmake docker-push # buildx 多架构推送\n```\n\n---\n\n## 🏗️ 项目结构\n\n```text\nMediaStationGo\u002F\n├── cmd\u002Fserver\u002F                 # 服务入口\n├── internal\u002F\n│   ├── config\u002F                  # 配置加载与默认值\n│   ├── database\u002F                # SQLite 初始化与迁移\n│   ├── handler\u002F                 # HTTP API \u002F Emby API \u002F 管理接口\n│   ├── middleware\u002F              # 鉴权、权限、日志中间件\n│   ├── model\u002F                   # GORM 数据模型\n│   ├── repository\u002F              # 数据访问层\n│   └── service\u002F                 # 扫描、刮削、播放、下载、订阅等业务逻辑\n├── web\u002F\n│   ├── public\u002F                  # favicon 等静态资源\n│   ├── src\u002F                     # React 页面、组件、API、状态管理\n│   └── dist\u002F                    # 前端构建产物，默认不入库\n├── scripts\u002F                     # 部署、打包、Docker 构建脚本\n├── docs\u002F                        # 设计文档、截图与架构说明\n├── docker-compose.yml           # 默认 Docker Compose 部署文件\n├── Dockerfile                   # 多阶段镜像构建\n├── config.example.yaml          # 配置模板\n└── README.md \u002F README_EN.md     # 项目文档\n```\n\n---\n\n## ⚙️ 配置说明\n\n配置优先级从低到高：\n\n1. 内置默认值\n2. `config.yaml`\n3. `config\u002F*.yaml`\n4. `MEDIASTATION_` 环境变量\n5. 后台数据库运行时配置\n\n常用环境变量：\n\n| 变量 | 默认值 | 说明 |\n| --- | --- | --- |\n| `MEDIASTATION_APP_HOST` | `0.0.0.0` | 服务监听地址 |\n| `MEDIASTATION_APP_PORT` | `8080` | 服务监听端口 |\n| `MEDIASTATION_APP_WEB_DIR` | `.\u002Fweb\u002Fdist` | 前端静态资源目录 |\n| `MEDIASTATION_APP_DATA_DIR` | `.\u002Fdata` | 程序数据目录 |\n| `MEDIASTATION_DATABASE_DB_PATH` | `.\u002Fdata\u002Fmediastation.db` | SQLite 数据库路径 |\n| `MEDIASTATION_CACHE_CACHE_DIR` | `.\u002Fcache` | 图片\u002F转码缓存目录 |\n| `MEDIASTATION_SECRETS_JWT_SECRET` | 自动生成 | JWT 和敏感配置加密种子 |\n| `MEDIASTATION_APP_CORS_ORIGINS` | 空 | 额外允许的跨域来源 |\n| `MEDIASTATION_TELEGRAM_API_BASE_URL` | `https:\u002F\u002Fapi.telegram.org` | Telegram Bot API 地址；网络受限时可填写反代地址 |\n| `MEDIASTATION_TELEGRAM_PROXY_URL` | 空 | Telegram 出站代理，例如 `http:\u002F\u002F172.17.0.1:7890` 或 `socks5:\u002F\u002F172.17.0.1:1080` |\n\n后台可运行时配置：\n\n- API Key：TMDb、Bangumi、TheTVDB、Fanart、OpenAI Compatible 等。\n- 站点：M-Team、NexusPHP、Unit3D、自定义 RSS 等。\n- 下载器：qBittorrent、Transmission、Aria2。\n- 通知渠道：Telegram、Bark、Webhook、Email 等。Telegram 渠道支持单独配置 API 反代与代理地址，测试通知失败时错误信息会自动隐藏 Bot Token。\n- 播放配置、权限配置、调度任务、存储配置。\n\n---\n\n## 👥 用户与权限策略\n\n- 默认管理员由系统首次启动创建，默认账号为 `admin \u002F admin123`；该默认管理员可以改用户名，但不能删除，也不能降级，始终拥有最高权限。\n- 开源版默认最多允许 20 个用户，避免家庭 NAS 或公开测试环境被滥用；绑定私有授权服务后可按授权策略提升用户额度。\n- 管理后台新增用户默认为“观看用户”：允许登录 Web 与 Emby 兼容客户端、浏览媒体库、播放媒体、使用外部播放器、收藏与记录观看历史。\n- 普通观看用户默认不能扫描媒体库、重新刮削、删除媒体、探测媒体轨、写出 NFO、管理文件、管理 STRM、管理下载器、创建下载任务或订阅下载。\n- 由于视频流播放本身需要向客户端传输媒体数据，系统可以禁止“下载任务”和管理型下载入口，但无法从协议层完全阻止外部播放器或浏览器保存已授权播放的数据流。\n\n---\n\n## 🔐 私有授权服务\n\nMediaStationGo 已预留并接入私有独立的 `MediaStationLicenseServer`：\n\n- 授权服务器：`ShukeBta\u002FMediaStationLicenseServer`，本地备份路径示例为 `C:\\Users\\Administrator\\WorkBuddy\\license_server_backup`。\n- 主项目后端提供 `\u002Fapi\u002Flicense\u002Factivate`、`\u002Fapi\u002Flicense\u002Fstatus`、`\u002Fapi\u002Flicense\u002Fheartbeat`，由服务端代理调用 License Server，不在浏览器暴露 HMAC 密钥。\n- License Server 公共接口使用 `\u002Fapi\u002Fv1\u002Factivate`、`\u002Fapi\u002Fv1\u002Fstatus\u002F:fingerprint`、`\u002Fapi\u002Fv1\u002Fheartbeat`。\n- 在「系统设置 → 授权服务」填写 `license.server_url` 与 `license.hmac_secret`，然后在「授权许可」页面绑定授权码。\n- 未绑定或授权失效时保持开源版能力；授权有效时当前实现将用户额度提升到授权版额度。\n\n环境变量示例：\n\n```bash\nMEDIASTATION_LICENSE_SERVER_URL=http:\u002F\u002F127.0.0.1:8001\nMEDIASTATION_LICENSE_HMAC_SECRET=与 License Server 的 LICENSE_HMAC_SECRET 一致\n```\n\n---\n\n## 🎞️ FFmpeg \u002F ffprobe 按需运行\n\nMediaStationGo 不会把 `ffmpeg` 或 `ffprobe` 作为常驻守护进程启动。它们只在以下场景被临时调用：\n\n- 扫描或手动探测媒体轨时调用 `ffprobe`。\n- 浏览器无法直放、需要 HLS 转码时调用 `ffmpeg`。\n- 管理后台手动检测工具状态或手动安装工具时短暂调用版本检测\u002F安装逻辑。\n\n播放停止、转码任务取消或服务退出时，后台会结束对应转码任务。空闲状态下如果没有扫描、探测或转码，`ffmpeg\u002Fffprobe` 不应持续占用 CPU。\n\n默认 HLS 转码使用 NAS 友好的低负载策略：`MEDIASTATION_TRANSCODER_ENABLED=true` 是总开关，关闭后不会启动 ffmpeg 转码；`MEDIASTATION_TRANSCODER_HARDWARE_ACCEL=false` 是硬件加速总开关，只有开启后才会使用 `MEDIASTATION_TRANSCODER_ENCODER=nvenc\u002Fqsv\u002Fvaapi`；`MEDIASTATION_TRANSCODER_REALTIME=true` 按播放速度处理输入，`MEDIASTATION_TRANSCODER_THREADS=2` 限制软件编码线程，`MEDIASTATION_TRANSCODER_MAX_CONCURRENT=1` 限制同时转码数量，`MEDIASTATION_TRANSCODER_IDLE_TIMEOUT_SECONDS=120` 在播放器停止请求分片后自动结束 ffmpeg。\n\n---\n\n## 🔍 刮削与元数据策略\n\nMediaStationGo 的刮削顺序尽量避免重复请求和错误覆盖：\n\n1. 优先读取本地 NFO、poster、fanart、season poster、episode image。\n2. 根据文件名识别电影、剧集、动漫、综艺、成人内容。\n3. 使用 TMDb \u002F TheTVDB \u002F Bangumi \u002F 豆瓣补全缺失元数据。\n4. 使用 Fanart.tv 补充更高清的艺术图。\n5. 成人内容优先读取本地 NFO 与图片，再通过 JavBus\u002FJavDB 等公开页面补全。\n6. 已有本地元数据不会被无意义重复刮削覆盖。\n\n推荐目录结构：\n\n```text\n\u002Fmedia\u002FMovies\u002FInception (2010)\u002FInception (2010).mkv\n\u002Fmedia\u002FTV\u002FSome Show\u002FSeason 01\u002FSome Show S01E01.mkv\n\u002Fmedia\u002FAnime\u002FAnime Title\u002FSeason 01\u002FAnime Title S01E01.mkv\n\u002Fmedia\u002FVariety\u002FShow Name\u002FSeason 2026\u002FShow Name S2026E01.mkv\n\u002Fmedia\u002FAdult\u002FABCD-123\u002FABCD-123.mp4\n```\n\n本地图片常见命名：\n\n```text\nposter.jpg\nfanart.jpg\nfolder.jpg\nseason01-poster.jpg\nS01E01-thumb.jpg\nmovie.nfo\ntvshow.nfo\nepisode.nfo\n```\n\n### 智能分类目录规则\n\nMediaStationGo 的智能分类分为两个阶段：\n\n1. 下载阶段：根据订阅类型、搜索结果分类和标题特征，把任务保存到下载器根目录下的分类子目录。\n2. 整理阶段：用户可选择手动整理，或开启自动整理；整理时先进入媒体库一级目录，再进入二级分类目录。\n\n推荐宿主机目录：\n\n```text\n\u002Fvol1\u002F1000\u002FqBittorrent\u002Fdownloads\n\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电影\n\u002Fvol1\u002F1000\u002FDocker\u002Fmoviepilot-v2\u002Fmedia\u002F电视剧\n```\n\n对应容器内目录：\n\n```text\n\u002Fdownloads\n\u002Fmedia\u002F电影\n\u002Fmedia\u002F电视剧\n```\n\n下载器智能分类示例：\n\n```text\n\u002Fdownloads\u002F动画电影\n\u002Fdownloads\u002F国产剧\n\u002Fdownloads\u002F国漫\n\u002Fdownloads\u002F华语电影\n\u002Fdownloads\u002F日番\n\u002Fdownloads\u002F外语电影\n\u002Fdownloads\u002F综艺\n```\n\n整理后媒体库示例：\n\n```text\n\u002Fmedia\u002F电视剧\u002F国产剧\u002F剧名 (2026)\u002FSeason 01\u002F剧名 - S01E01 - 第 1 集.mkv\n\u002Fmedia\u002F电视剧\u002F国漫\u002F动画名 (2026)\u002FSeason 01\u002F动画名 - S01E01 - 第 1 集.mkv\n\u002Fmedia\u002F电视剧\u002F欧美剧\u002F剧名 (2026)\u002FSeason 01\u002F剧名 - S01E01 - 第 1 集.mkv\n\u002Fmedia\u002F电视剧\u002F日番\u002F番剧名 (2026)\u002FSeason 01\u002F番剧名 - S01E01 - 第 1 集.mkv\n\u002Fmedia\u002F电视剧\u002F日韩剧\u002F剧名 (2026)\u002FSeason 01\u002F剧名 - S01E01 - 第 1 集.mkv\n\u002Fmedia\u002F电视剧\u002F综艺\u002F综艺名 (2026)\u002FSeason 2026\u002F综艺名 - S2026E01 - 第 1 集.mp4\n\u002Fmedia\u002F电影\u002F动画电影\u002F电影名 (2026)\u002F电影名 (2026) - 1080p.mkv\n\u002Fmedia\u002F电影\u002F华语电影\u002F电影名 (2026)\u002F电影名 (2026) - 1080p.mkv\n\u002Fmedia\u002F电影\u002F外语电影\u002F电影名 (2026)\u002F电影名 (2026) - 1080p.mkv\n```\n\n如果媒体库根目录直接设置为 `\u002Fmedia`，整理器会在启用智能分类时自动补上 `电影\u002F` 或 `电视剧\u002F` 一级目录；如果你已经把媒体库设置为 `\u002Fmedia\u002F电影` 或 `\u002Fmedia\u002F电视剧`，则不会重复追加一级目录。\n\n自动整理与手动整理是两件事：\n\n- `organizer.smart_classify`：只控制是否使用智能分类目录。\n- `organizer.auto_after_download` \u002F `organize.auto`：控制下载完成后是否自动整理。\n- 未开启自动整理时，可以在「整理与维护」页面手动整理媒体库或单个媒体。\n\n### 整理与刮削命名模板\n\n整理规则建议按媒体类型拆分。剧集、动漫、综艺都属于连续剧集类，应保留剧名、年份、季目录、季集号和分集标题；电影类则保留片名、年份、分段和视频规格。\n\n剧集 \u002F 动漫 \u002F 综艺推荐模板（参考MPV2模板）：\n\n```jinja\n{{title}}{% if year %} ({{year}}){% endif %}\u002FSeason {{season}}\u002F{{title}} - {{season_episode}}{% if part %}-{{part}}{% endif %}{% if episode %} - 第 {{episode}} 集{% endif %}{{fileExt}}\n```\n\n输出示例：\n\n```text\n孤独的美食家 (2024)\u002FSeason 01\u002F孤独的美食家 - S01E01 - 第 1 集.mkv\n某动画 (2025)\u002FSeason 02\u002F某动画 - S02E03 - 第 3 集.mkv\n某综艺 (2026)\u002FSeason 2026\u002F某综艺 - S2026E01 - 第 1 集.mp4\n```\n\n电影推荐模板：\n\n```jinja\n{{title}}{% if year %} ({{year}}){% endif %}\u002F{{title}}{% if year %} ({{year}}){% endif %}{% if part %}-{{part}}{% endif %}{% if videoFormat %} - {{videoFormat}}{% endif %}{{fileExt}}\n```\n\n输出示例：\n\n```text\n盗梦空间 (2010)\u002F盗梦空间 (2010) - 1080p.mkv\n沙丘 (2021)\u002F沙丘 (2021)-CD1 - 2160p.mkv\n```\n\n常用变量说明：\n\n| 变量 | 说明 |\n| --- | --- |\n| `title` | 媒体标题，优先使用本地 NFO \u002F 在线元数据识别后的标题 |\n| `year` | 年份，存在时追加到目录和文件名中 |\n| `season` | 季号，剧集\u002F动漫\u002F综艺用于生成 `Season 01` 等目录 |\n| `season_episode` | 季集号，例如 `S01E01`、`S2026E01` |\n| `episode` | 分集序号，用于中文分集标题 |\n| `part` | 分段标记，例如 `CD1`、`Part1` |\n| `videoFormat` | 视频规格，例如 `1080p`、`2160p`、`WEB-DL` |\n| `fileExt` | 原始文件扩展名，例如 `.mkv`、`.mp4` |\n\n---\n\n## 🔎 发现、搜索与订阅下载\n\n### 多源发现\n\n精彩发现支持：\n\n- TMDb：趋势、热门电影、热门剧集、高分电影。\n- 豆瓣：热门电影、高分电影、热门剧集。\n- Bangumi：每日放送、动漫条目。\n\n### 智能搜索\n\n智能搜索会同时考虑：\n\n- 本地媒体库已有内容。\n- TMDb \u002F 豆瓣 \u002F Bangumi 等在线结果。\n- 可订阅关键词与媒体类型。\n\n### 订阅规则\n\n订阅支持以下规则：\n\n| 规则 | 说明 |\n| --- | --- |\n| 媒体类型 | 电影、剧集、动漫、综艺，支持自动识别 |\n| 搜索模式 | 标题关键词或 IMDB ID |\n| 分辨率 | 自动择优、2160p、1080p、720p |\n| 质量 | REMUX、BluRay、WEB-DL、HDTV 等 |\n| 特效 | HDR、Dolby Vision、Atmos 等 |\n| 发布组 | 白名单发布组 |\n| 排除词 | 排除 CAM、TS、枪版等低质资源 |\n| 洗版 | 默认关闭，可按分辨率、质量、特效、做种数优先 |\n\n下载与订阅卡片只展示安全标题、海报、进度、速度、体积等信息，不展示原始种子 URL，避免多用户场景泄露私人 Tracker Token。\n\n---\n\n## 🔌 外部客户端与 Emby 兼容\n\n项目提供 Emby\u002FJellyfin 风格 API，用于外部客户端连接：\n\n```text\nhttp:\u002F\u002F\u003C服务器IP>:18080\n```\n\n可尝试的客户端：\n\n- Infuse\n- VidHub\n- SenPlayer\n- 其他支持 Emby\u002FJellyfin 服务器的播放器\n\n建议检查：\n\n1. Docker 端口是否映射为 `18080:8080`。\n2. 防火墙是否允许局域网访问 `18080`。\n3. 账号密码是否正确。\n4. 反向代理是否正确转发 `\u002Fapi`、视频流和 Range 请求。\n\n### 与 MoviePilot 的功能参考关系\n\nMediaStationGo 在外部客户端兼容与媒体生态联动上参考了 MoviePilot 的成熟产品路径：通过统一媒体库、订阅下载、下载后整理和 Emby\u002FJellyfin 兼容接口，把 Web 管理端与 Infuse、VidHub、SenPlayer 等客户端串起来。本项目的目标不是替代 Emby\u002FJellyfin，而是在最极少的资源占用的轻量 Go 服务中提供足够常用的媒体浏览、播放、海报墙、剧集分季分集、播放进度和外部客户端访问能力。\n\n当前兼容重点：\n\n- 媒体库、合集、季、集的层级输出。\n- 海报、背景图、简介、年份、评分等基础元数据输出。\n- 视频流地址、HTTP Range、播放进度与继续观看。\n- 外部客户端登录、媒体浏览和播放所需的 Emby\u002FJellyfin 风格接口。\n\n仍在持续补齐：\n\n- 更完整的 Emby\u002FJellyfin 设备能力协商。\n- 更细的转码 Profile 与字幕能力声明。\n- 多用户权限、媒体库过滤与播放历史同步。\n- 与订阅下载、自动整理、洗版规则之间的闭环联动。\n\n> MoviePilot 项目使用 GPL-3.0 许可，本项目只参考其公开产品思路与交互路径，不复制私有数据、密钥、站点账号或不兼容实现。\n\n---\n\n## 🧠 AI 与外部服务配置\n\n在后台「外部 API 配置」中可配置：\n\n| 服务 | 作用 |\n| --- | --- |\n| TMDb | 电影、剧集、海报、背景图、简介 |\n| Bangumi | 动漫、番剧、中文条目 |\n| TheTVDB | 剧集季集补充 |\n| Fanart.tv | 高清 Logo、背景图、艺术图 |\n| 豆瓣 | 中文影视搜索与推荐补充 |\n| OpenAI Compatible | AI 搜索、推荐、运维助手 |\n\nM-Team 建议使用 API Access Token：\n\n```text\n控制台 → 实验室 → 存取令牌\nHTTP Header: x-api-key\n```\n\n不建议使用 Cookie 调用开放 API，避免账号风险。\n\n---\n\n## 🔐 隐私与安全\n\n默认不会提交以下数据：\n\n- `data\u002F`、`cache\u002F`、`logs\u002F`\n- `.tmp-deploy-data\u002F`、`.tmp-deploy-server.*`\n- `.mediastation.pid`\n- `config.yaml`、`.env*`\n- `*.db`、`*.db-wal`、`*.log`\n- `web\u002Fdist\u002F`、`node_modules\u002F`、`bin\u002F`\n- API Key、Cookie、Token、密码、证书等敏感文件\n\n提交前建议检查：\n\n```bash\ngit status --short\ngit ls-files | grep -E 'data\u002F|cache\u002F|\\.db|\\.log|jwt_secret|config.yaml|\\.env|token|apikey|password' || true\n```\n\n---\n\n## ❓ 常见问题\n\n### Q: 拉取 GHCR 镜像时出现 `EOF` 怎么办？\n\n`EOF` 通常表示服务器到 GHCR 的网络连接中途断开，不是 compose 文件语法错误。建议按顺序处理：\n\n```bash\n# 1. 清理可能异常的 GHCR 登录状态\ndocker logout ghcr.io || true\n\n# 2. 单独拉取镜像，确认是网络\u002F registry 问题还是 compose 问题\ndocker pull ghcr.io\u002Fshukebta\u002Fmediastation-go:latest\n\n# 3. 如果是 x86_64\u002FAMD64 主机，也可以显式指定平台重试\ndocker pull --platform linux\u002Famd64 ghcr.io\u002Fshukebta\u002Fmediastation-go:latest\n\n# 4. 拉取成功后再启动\ndocker compose up -d\n```\n\n如果服务器在国内网络或 NAS 网络环境中，建议为 Docker daemon 配置可访问 GHCR 的代理；仅设置终端代理通常不一定会被 Docker 服务进程继承。默认 compose 已使用 `pull_policy: missing`，避免容器重启时反复访问 GHCR。\n\n另外，你示例中的路径如果是 NAS 绝对路径，建议写成 `\u002Fvol1\u002F...`，不要写 `.\u002Fvol1\u002F...`；前者是系统根目录路径，后者是当前 compose 目录下面的相对路径。\n\n### Q: Docker 部署后浏览器打不开？\n\n检查容器状态和端口：\n\n```bash\ndocker ps\ndocker logs -f mediastation-go\n```\n\n确认访问的是宿主机端口，例如 `http:\u002F\u002F你的IP:18080`。\n\n### Q: 外部客户端提示服务器未响应？\n\n优先检查防火墙、Docker 端口映射、反向代理和局域网 IP。容器内监听 `8080`，宿主机默认映射为 `18080`。\n\n### Q: 媒体库没有海报？\n\n请确认：\n\n1. 本地是否有 `poster.jpg`、`fanart.jpg`、NFO。\n2. TMDb \u002F Bangumi \u002F 豆瓣是否可连接。\n3. 代理是否正确配置。\n4. 媒体文件名是否包含清晰标题、年份、季集信息。\n\n### Q: 下载任务为什么不显示原始链接？\n\nPT 下载 URL 常包含私有 Token。下载中心和订阅管理会主动隐藏原始 URL，只显示安全标题、海报、速度、进度、体积等信息。\n\n\n\n## 🗺️ 路线图\n\n- 更完整的 Emby\u002FJellyfin 客户端兼容。\n- 更强的成人内容本地元数据和公开页面补全。\n- 更细粒度的订阅洗版和下载后整理规则。\n- 更完善的移动端\u002F电视端交互。\n- 插件化站点适配器和通知渠道。\n- 更完整的端到端测试与截图自动化。\n\n---\n\n## 🤝 贡献\n\n欢迎提交 Issue、Pull Request、站点适配、刮削规则、UI 改进与文档修正。\n\n建议贡献前先运行：\n\n```bash\ngo test .\u002F...\ncd web && npm run build\n```\n\n---\n\n## 👥 开发群组\n\n- Telegram：\u003Chttps:\u002F\u002Ft.me\u002FMediaStationGo>\n\n---\n\n## 🍜 赞赏\n\n如果这个项目节省了你的时间，欢迎请作者吃桶泡面。\n\n\u003Cimg width=\"200\" height=\"200\" alt=\"微信赞赏码\" src=\"https:\u002F\u002Fgithub.com\u002Fuser-attachments\u002Fassets\u002Fd6077de5-8305-400d-8b82-470ef05d926e\" \u002F>\n\n---\n\n## ⭐ Star History\n\n\u003Ca href=\"https:\u002F\u002Fwww.star-history.com\u002F?repos=ShukeBta%2FMediaStationGo&type=date&legend=top-left\">\n \u003Cpicture>\n   \u003Csource media=\"(prefers-color-scheme: dark)\" srcset=\"https:\u002F\u002Fapi.star-history.com\u002Fchart?repos=ShukeBta\u002FMediaStationGo&type=date&theme=dark&legend=top-left\" \u002F>\n   \u003Csource media=\"(prefers-color-scheme: light)\" srcset=\"https:\u002F\u002Fapi.star-history.com\u002Fchart?repos=ShukeBta\u002FMediaStationGo&type=date&legend=top-left\" \u002F>\n   \u003Cimg alt=\"Star History Chart\" src=\"https:\u002F\u002Fapi.star-history.com\u002Fchart?repos=ShukeBta\u002FMediaStationGo&type=date&legend=top-left\" \u002F>\n \u003C\u002Fpicture>\n\u003C\u002Fa>\n\n---\n\n## 📄 许可证与非商用声明\n\n本项目基础许可证遵循 `GPL-3.0`，详见 [LICENSE](LICENSE)。项目维护者同时声明并倡议：\n\n- 本项目主要面向个人学习、家庭 NAS、自建影音、非商业研究与社区共建场景。\n- 未经作者明确书面许可，不得将本项目或衍生版本用于商业售卖、商业托管、付费 SaaS、预装售卖设备、闭源二次分发或其他商业化牟利用途。\n- 如需商业合作、企业内部部署、定制开发、集成发行或商业授权，请先联系作者确认授权边界。\n- 若 README 的非商用声明与 `GPL-3.0` 正式许可文本存在解释差异，代码授权以 [LICENSE](LICENSE) 文件为准，商业使用请额外取得作者许可。\n\n---\n\n\u003Cp align=\"center\">Made with ❤️ by ShukeBta\u003C\u002Fp>\n","MediaStationGo 是一个面向个人、家庭 NAS 与影音爱好者的开源媒体中心。它集成了媒体库管理、自动刮削、在线播放、外部客户端兼容、PT 站点检索、订阅下载和 AI 推荐等功能，通过轻量级的 Go 后端服务和现代化的 React 前端提供统一且美观的用户体验。项目支持多源元数据补全（如 TMDb、豆瓣等），并可通过 Docker 一键部署，简化了安装和维护流程。此外，它还兼容 Emby API，方便 Infuse、VidHub 等第三方客户端访问。MediaStationGo 特别适合拥有 NAS 或其他存储设备的家庭用户，以及希望集中管理和播放多媒体内容的影音爱好者使用。","2026-06-11 04:08:09","CREATED_QUERY"]