Go 单二进制后端 · React 现代化前端 · Docker 一键部署 · Emby API 兼容 · 多源刮削 · PT 订阅下载
English · 快速开始 · Docker 部署 · 界面预览 · 在线演示
NodeSeek:NodeSeek
LINUX DO:LINUX DO
MediaStationGo 是一个面向个人、家庭 NAS 与影音爱好者的开源媒体中心。它把「媒体库管理、自动刮削、在线播放、外部客户端兼容、PT 站点检索、订阅下载、AI 推荐」放进一个轻量的 Go 服务里,配合 React 前端提供统一、简洁、漂亮的三端体验。
它适合这些场景:
- 家里有 NAS / Windows 主机 / Linux 小主机,希望统一管理电影、剧集、动漫、综艺、成人内容。
- 想使用 TMDb、豆瓣、Bangumi、TheTVDB、Fanart、JavBus/JavDB 等多源元数据补全海报、简介、分季分集信息。
- 想把 PT 站点搜索、订阅、下载器、下载后整理集中到一个 Web 面板中。
- 想让 Infuse、VidHub、SenPlayer 等外部客户端通过 Emby 风格接口访问媒体库。
- 想要一个部署简单、便于二次开发、不会把密钥和私有 Token 暴露到前端的开源项目。
当前项目仍在快速迭代中,建议固定镜像版本部署,并定期备份
/data目录。
MediaStationGo 采用完全开源路线,核心媒体库、刮削、播放、订阅、下载、外部客户端兼容与运维能力均在本仓库持续迭代。项目参考了 MoviePilot 等优秀开源项目在「站点聚合、订阅下载、媒体整理、Emby/Jellyfin 客户端兼容」上的产品思路,但本项目会保持独立实现,不直接复制不兼容代码。
本项目当前基础许可证为 GPL-3.0,欢迎基于 GPL-3.0 协议参与改造、适配站点、提交刮削规则与优化 UI。项目作者同时倡议:本项目面向个人学习、家庭 NAS、自建影音与非商业场景使用,未经作者明确书面许可,不得将本项目或其衍生版本用于商业售卖、商业托管、付费 SaaS、预装售卖设备、闭源二次分发或其他商业化牟利用途。
说明:GPL-3.0 是自由软件许可证,其正式授权范围以仓库 LICENSE 文件为准;上方「非商用承诺」表达项目维护者的使用边界与商业合作要求。如需商业合作、企业部署或二次发行,请先联系作者获得额外授权。
- 当前公开仓库继续以
GPL-3.0作为基础许可证;如果代码包含 GPL 派生实现,不能通过“只发布 Docker 镜像”规避对应源码提供义务。 - 可以把官方部署策略收敛为 Docker-first / Docker-only support:即项目只承诺维护 Docker Compose、GHCR 镜像和容器部署文档,裸机运行与二进制包可作为社区自助能力。
- 若未来需要部分闭源,可能将闭源能力拆成独立插件、独立服务或私有模块,并确保该部分为作者自有或兼容许可证的干净实现;GPL 覆盖代码仍应按 GPL 公开。
- README 中的非商用声明是维护者的使用边界与商业授权要求;正式代码授权仍以 LICENSE 为准。
- 演示站:https://mgo.3jzs.com
- 默认账号:
admin - 默认密码:
admin123
演示环境仅用于功能体验,请勿上传真实隐私信息或配置私人 API Key。
| 模块 | 能力 |
|---|---|
| 媒体库 | 电影、电视剧、动漫、综艺、音乐、成人内容;支持文件夹封面、合集、季、集展示 |
| 扫描识别 | 递归扫描、ffprobe 探测、文件名解析、季集识别、综艺节目识别、重复扫描去重 |
| 本地元数据 | 优先读取 NFO、poster、fanart、season poster、episode image、本地成人影片图片 |
| 在线刮削 | TMDb、TheTVDB、Bangumi、豆瓣、Fanart.tv、JavBus/JavDB 页面直爬补全 |
| 播放体验 | 直链播放、HTTP Range 拖动、HLS 转码、外挂字幕、播放进度、继续观看、外部播放器 |
| 发现与搜索 | TMDb / 豆瓣 / Bangumi 多源推荐,智能搜索,详情页订阅入口 |
| PT 站点 | 站点管理、M-Team API Token、站点搜索、种子链接解析、下载器联动 |
| 订阅下载 | RSS / 站点搜索订阅,分辨率/质量/特效/发布组/排除词规则,洗版开关与优先级 |
| 下载中心 | qBittorrent 任务状态、速度、进度、上传下载体积、小卡片海报展示、私有 URL 脱敏 |
| 外部兼容 | Emby/Jellyfin 风格 API,兼容 Infuse、VidHub、SenPlayer 等外部客户端 |
| AI 能力 | OpenAI Compatible API 配置,AI 搜索、推荐、运维助手 |
| 运维工具 | 运行状态、任务队列、重复文件、回收站、文件管理、存储配置、通知渠道 |
以下截图使用 Codex 内置浏览器从当前运行实例采集,并已对个人媒体内容、本地路径、账号信息、API Key/Token/密钥等敏感信息做图像级打码处理。
| 层级 | 技术 | 说明 |
|---|---|---|
| 后端语言 | Go 1.25+ | 单二进制部署,启动快,资源占用低 |
| Web 框架 | Gin | REST API、鉴权中间件、静态资源托管 |
| 数据库 | SQLite + GORM | 适合个人/NAS 场景,数据文件易备份 |
| 前端框架 | React 18 + TypeScript | 组件化 UI,类型安全 |
| 构建工具 | Vite | 前端快速开发与生产打包 |
| 样式系统 | Tailwind CSS | 统一浅色高级视觉方案与响应式布局 |
| 状态管理 | Zustand | 轻量全局状态与鉴权状态维护 |
| 播放链路 | HTML5 Video / HLS / FFmpeg | 直链、Range、HLS 转码、字幕 |
| 元数据 | TMDb / 豆瓣 / Bangumi / TheTVDB / Fanart / JavBus / JavDB | 多源补全海报、简介、评分、分季分集 |
| 下载联动 | qBittorrent / PT Site Adapter | 站点搜索、订阅、下载任务展示与脱敏 |
| 外部兼容 | Emby-style API / DLNA | 面向外部播放器与三端客户端 |
| 部署 | Docker / Docker Compose / Shell / PowerShell | NAS、Linux、Windows 均可部署 |
| CI/CD | GitHub Actions / GHCR | 版本标签或手动 Actions 自动发布多架构镜像与 Release 包 |
默认部署主线改为直接编辑 docker-compose.yml:把 NAS/服务器真实目录写进 compose 文件里,路径最直观,也最适合刚接触 NAS、VPS 或 Docker 的用户。
mkdir -p ~/MediaStationGo
cd ~/MediaStationGo
mkdir -p data cache media downloadscurl -fsSL https://raw.githubusercontent.com/ShukeBta/MediaStationGo/main/docker-compose.yml -o docker-compose.yml如果 GitHub Raw 访问慢,可以手动创建 docker-compose.yml,内容以仓库根目录的 docker-compose.yml 为准。
打开 compose:
vi docker-compose.yml先找到 volumes 里的媒体库和下载目录,把左边改成你的 NAS/服务器真实路径,例如:
volumes:
- ./data:/data
- ./cache:/cache
- /vol1/1000/Docker/moviepilot-v2/media:/media:ro
- /vol1/1000/qBittorrent/downloads:/downloads再找到 environment 里的路径提示,把同样的真实路径写进去:
environment:
MEDIASTATION_MEDIA_DIR: /vol1/1000/Docker/moviepilot-v2/media
MEDIASTATION_MEDIA_CONTAINER_DIR: /media
MEDIASTATION_DOWNLOAD_DIR: /vol1/1000/qBittorrent/downloads
MEDIASTATION_DOWNLOAD_CONTAINER_DIR: /downloads路径怎么理解:
| 位置 | 填什么 |
|---|---|
volumes 左侧媒体路径 |
NAS/服务器上的真实媒体目录,例如 /volume1/media、/mnt/media、/vol1/1000/Docker/moviepilot-v2/media |
volumes 左侧下载路径 |
NAS/服务器上的真实下载目录,例如 /volume1/downloads、/mnt/downloads、/vol1/1000/qBittorrent/downloads |
MEDIASTATION_MEDIA_DIR |
和媒体库 volumes 左侧保持一致 |
MEDIASTATION_DOWNLOAD_DIR |
和下载目录 volumes 左侧保持一致 |
不要写成
./vol1/...。带./是相对路径,会变成当前部署目录下面的文件夹。
docker compose pull
docker compose up -d如果你的系统只有旧版命令:
docker-compose pull
docker-compose up -dhttp://<服务器IP>:18080
默认账号:
admin / admin123
首次登录后请立即修改管理员密码。
默认 compose 会把你的宿主机目录映射为容器路径:
| 宿主机真实目录 | 容器内路径 | 页面里建议填写 |
|---|---|---|
MEDIASTATION_MEDIA_DIR |
/media |
/media/电影、/media/电视剧、/media/电视剧/国产剧 |
MEDIASTATION_DOWNLOAD_DIR |
/downloads |
下载器保存根目录填 /downloads |
这只是 Docker 绑定挂载,不会复制文件,不会占用双倍空间。MediaStationGo 读取的是原目录内容,只是在容器里显示成 /media 和 /downloads。
推荐使用仓库脚本,它会更新容器并清理本项目旧镜像,避免 NAS 磁盘被旧镜像占满:
curl -fsSL https://cdn.jsdelivr.net/gh/ShukeBta/MediaStationGo@main/scripts/docker-compose-update.sh -o docker-compose-update.sh
chmod +x docker-compose-update.sh
./docker-compose-update.shdocker compose ps
docker compose logs -f mediastation-go默认文件只保留新手必需项。需要让容器内也显示宿主机原始路径、Telegram 代理、硬件加速、更多转码环境变量时,参考仓库中的高级示例:
docker-compose.advanced.yml
如果你已经熟悉 Docker Compose,或者同一份 compose 要在多台机器复用,也可以把路径写进 .env。这是可选玩法,不是新手主线:
cat > .env <<'EOF'
MEDIASTATION_MEDIA_DIR=/vol1/1000/Docker/moviepilot-v2/media
MEDIASTATION_DOWNLOAD_DIR=/vol1/1000/qBittorrent/downloads
MEDIASTATION_HTTP_PORT=18080
TZ=Asia/Shanghai
PUID=1000
PGID=1000
EOF使用 .env 时,docker-compose.yml 中保持默认变量写法即可:
- ${MEDIASTATION_MEDIA_DIR:-./media}:/media:ro
- ${MEDIASTATION_DOWNLOAD_DIR:-./downloads}:/downloads生产环境可以固定镜像版本,避免 latest 自动变化。不使用 .env 时,直接把 compose 里的镜像改成固定版本:
image: ghcr.io/shukebta/mediastation-go:MediaStationGo-v0.0.32如果使用 .env,也可以写:
MEDIASTATION_IMAGE_TAG=MediaStationGo-v0.0.32然后执行:
docker compose pull
docker compose up -d如果 NAS 已经开启 v2rayA 的 redirect / 透明代理,并使用大陆白名单分流,MediaStationGo 通常不需要额外配置 HTTP_PROXY / HTTPS_PROXY。
不建议在 docker-compose.yml 或 .env 中重复配置代理环境变量,因为这会让容器网络和 Docker 拉镜像路径叠加代理,反而可能导致 GHCR、M-Team、TMDB 等访问异常。
如果 qBittorrent 运行在同一台 NAS/宿主机上,MediaStationGo 容器里不要填 127.0.0.1;推荐在「下载器管理」中填写:
http://host.docker.internal:8085
如果 qBittorrent 也运行在 Docker 中,建议让 qBittorrent 和 MediaStationGo 都把同一个宿主机下载目录映射为 /downloads。订阅保存根目录填写:
/downloads
启用智能分类后,下载会自动进入 /downloads/动画电影、/downloads/国产剧、/downloads/综艺 等分类目录。
MediaStationGo 内置 OpenList、Alist、WebDAV、115、夸克和 CloudDrive2 外部存储配置。推荐新手优先使用 OpenList、CloudDrive2 或 Alist 作为桥接层:它们可以对接 115、123、阿里、夸克等多种网盘,项目通过 OpenList/Alist API 或 WebDAV 入口即可完成浏览、挂载媒体库、本地媒体转存和反代播放。
OpenList 推荐用法:
- 在 OpenList 中挂载你的 115 / 123 / 阿里 / 夸克等网盘。
- 在 MediaStationGo 的「外部存储」中选择
OpenList。 OpenList Server URL填管理/API 地址,例如http://NAS-IP:5244。WebDAV URL填 WebDAV 地址,例如http://NAS-IP:5244/dav/。- 如果 OpenList 没有配置 HTTPS 反向代理,不要填写
https://。Propfind "https://...": http: server gave HTTP response to HTTPS client表示你把 HTTP 服务误填成了 HTTPS。
CloudDrive2 推荐用法:
- 在 CloudDrive2 中挂载你的 115 / 123 / 阿里 / 夸克等网盘。
- 在 MediaStationGo 的「外部存储」中选择
CloudDrive2。 - 填写 CloudDrive2 WebDAV 地址,例如
http://host.docker.internal:19798/dav或http://NAS-IP:19798/dav。 - 保存后可直接浏览网盘目录,或挂载为媒体库进行扫描播放。
115 原生接口保留 Cookie / 扫码登录、目录浏览和 302 播放能力;本地文件上传建议优先走 OpenList / CloudDrive2 / Alist 桥接,避免在项目内维护各网盘私有分片上传协议。
项目默认内置极简 docker-compose.yml。新手推荐直接在 volumes 左侧写真实路径,并让 MEDIASTATION_MEDIA_DIR、MEDIASTATION_DOWNLOAD_DIR 与左侧路径保持一致;.env 变量适合进阶用户复用配置:
| 变量 | 默认值 | 说明 |
|---|---|---|
MEDIASTATION_IMAGE_TAG |
latest |
镜像标签,建议固定为 Release 版本 |
MEDIASTATION_HTTP_PORT |
18080 |
宿主机访问端口 |
MEDIASTATION_DATA_DIR |
./data |
数据持久化目录 |
MEDIASTATION_CACHE_DIR |
./cache |
图片和转码缓存目录 |
MEDIASTATION_MEDIA_DIR |
./media |
媒体库宿主机目录;NAS 建议写 /your-nas/media 这种绝对路径 |
MEDIASTATION_DOWNLOAD_DIR |
./downloads |
下载保存宿主机目录;NAS 建议写 /your-nas/downloads 这种绝对路径 |
PUID / PGID |
1000 / 1000 |
Linux/NAS 文件权限映射 |
TZ |
Asia/Shanghai |
容器时区 |
查看日志:
docker logs -f mediastation-go更新镜像:
curl -fsSL https://cdn.jsdelivr.net/gh/ShukeBta/MediaStationGo@main/scripts/docker-compose-update.sh -o docker-compose-update.sh
chmod +x docker-compose-update.sh
./docker-compose-update.sh说明:普通 docker compose pull && docker compose up -d 只会切换到新镜像,不会自动删除旧镜像;上面的脚本会保留当前正在运行的 MediaStationGo 镜像,删除同仓库未使用的旧镜像,并执行 docker image prune -f 清理 dangling 层。如需进一步清理所有未使用镜像,可临时执行 PRUNE_ALL_UNUSED=1 ./docker-compose-update.sh。
停止服务:
docker compose down备份数据:
tar -czf mediastationgo-data-backup.tgz ./data如果不想使用 Docker,也可以裸机运行。脚本会自动构建前端、编译后端、启动服务并检查健康状态。
git clone https://github.com/ShukeBta/MediaStationGo.git
cd MediaStationGo
chmod +x scripts/deploy.sh
PORT=18080 DATA_DIR=/opt/mediastation/data CACHE_DIR=/opt/mediastation/cache ./scripts/deploy.shgit clone https://github.com/ShukeBta/MediaStationGo.git
cd MediaStationGo
.\scripts\deploy.ps1 -Port 18080 -DataDir D:\MediaStationGo\data -CacheDir D:\MediaStationGo\cache脚本执行内容:
- 安装前端依赖并构建
web/dist - 编译 Go 服务端到
bin/ - 创建数据目录和缓存目录
- 停止旧进程并启动新进程
- 请求
/api/health验证服务状态
每个 Release 会提供多平台压缩包:
| 平台 | 包名示例 |
|---|---|
| Linux x86_64 | MediaStationGo-v0.0.32-linux-amd64.tar.gz |
| Linux ARM64 | MediaStationGo-v0.0.32-linux-arm64.tar.gz |
| Windows x86_64 | MediaStationGo-v0.0.32-windows-amd64.zip |
| macOS Intel | MediaStationGo-v0.0.32-darwin-amd64.tar.gz |
| macOS Apple Silicon | MediaStationGo-v0.0.32-darwin-arm64.tar.gz |
部署步骤:
# Linux 示例
tar -xzf MediaStationGo-v0.0.32-linux-amd64.tar.gz
cd MediaStationGo-v0.0.32-linux-amd64
MEDIASTATION_APP_PORT=18080 ./mediastation-goWindows:
Expand-Archive .\MediaStationGo-v0.0.32-windows-amd64.zip
cd .\MediaStationGo-v0.0.32-windows-amd64
$env:MEDIASTATION_APP_PORT = "18080"
.\mediastation-go.exeRelease 二进制默认监听
8080,如果希望和 Docker 示例保持一致,请按上方设置MEDIASTATION_APP_PORT=18080。
| 组件 | 版本 | 用途 |
|---|---|---|
| Go | 1.25+ | 后端编译与测试 |
| Node.js | 20+ | 前端构建 |
| FFmpeg / ffprobe | 推荐安装 | 媒体探测与转码 |
| Docker | 可选 | 容器部署与多架构镜像 |
| qBittorrent | 可选 | 下载器联动测试 |
cp config.example.yaml config.yaml
cd web
npm ci
npm run build
cd ..
go build -o bin/mediastation-go ./cmd/server
./bin/mediastation-goWindows:
Copy-Item config.example.yaml config.yaml
Set-Location web
npm ci
npm run build
Set-Location ..
go build -o bin\mediastation-go.exe .\cmd\server
.\bin\mediastation-go.exemake build # 构建前后端
make test # 运行 Go 测试
make smoke # 冒烟测试
make docker # docker compose up -d
make deploy # Linux 一键部署
make docker-push # buildx 多架构推送MediaStationGo/
├── cmd/server/ # 服务入口
├── internal/
│ ├── config/ # 配置加载与默认值
│ ├── database/ # SQLite 初始化与迁移
│ ├── handler/ # HTTP API / Emby API / 管理接口
│ ├── middleware/ # 鉴权、权限、日志中间件
│ ├── model/ # GORM 数据模型
│ ├── repository/ # 数据访问层
│ └── service/ # 扫描、刮削、播放、下载、订阅等业务逻辑
├── web/
│ ├── public/ # favicon 等静态资源
│ ├── src/ # React 页面、组件、API、状态管理
│ └── dist/ # 前端构建产物,默认不入库
├── scripts/ # 部署、打包、Docker 构建脚本
├── docs/ # 设计文档、截图与架构说明
├── docker-compose.yml # 默认 Docker Compose 部署文件
├── Dockerfile # 多阶段镜像构建
├── config.example.yaml # 配置模板
└── README.md / README_EN.md # 项目文档
配置优先级从低到高:
- 内置默认值
config.yamlconfig/*.yamlMEDIASTATION_环境变量- 后台数据库运行时配置
常用环境变量:
| 变量 | 默认值 | 说明 |
|---|---|---|
MEDIASTATION_APP_HOST |
0.0.0.0 |
服务监听地址 |
MEDIASTATION_APP_PORT |
8080 |
服务监听端口 |
MEDIASTATION_APP_WEB_DIR |
./web/dist |
前端静态资源目录 |
MEDIASTATION_APP_DATA_DIR |
./data |
程序数据目录 |
MEDIASTATION_DATABASE_DB_PATH |
./data/mediastation.db |
SQLite 数据库路径 |
MEDIASTATION_CACHE_CACHE_DIR |
./cache |
图片/转码缓存目录 |
MEDIASTATION_SECRETS_JWT_SECRET |
自动生成 | JWT 和敏感配置加密种子 |
MEDIASTATION_APP_CORS_ORIGINS |
空 | 额外允许的跨域来源 |
MEDIASTATION_TELEGRAM_API_BASE_URL |
https://api.telegram.org |
Telegram Bot API 地址;网络受限时可填写反代地址 |
MEDIASTATION_TELEGRAM_PROXY_URL |
空 | Telegram 出站代理,例如 http://172.17.0.1:7890 或 socks5://172.17.0.1:1080 |
后台可运行时配置:
- API Key:TMDb、Bangumi、TheTVDB、Fanart、OpenAI Compatible 等。
- 站点:M-Team、NexusPHP、Unit3D、自定义 RSS 等。
- 下载器:qBittorrent、Transmission、Aria2。
- 通知渠道:Telegram、Bark、Webhook、Email 等。Telegram 渠道支持单独配置 API 反代与代理地址,测试通知失败时错误信息会自动隐藏 Bot Token。
- 播放配置、权限配置、调度任务、存储配置。
- 默认管理员由系统首次启动创建,默认账号为
admin / admin123;该默认管理员可以改用户名,但不能删除,也不能降级,始终拥有最高权限。 - 开源版默认最多允许 20 个用户,避免家庭 NAS 或公开测试环境被滥用;绑定私有授权服务后可按授权策略提升用户额度。
- 管理后台新增用户默认为“观看用户”:允许登录 Web 与 Emby 兼容客户端、浏览媒体库、播放媒体、使用外部播放器、收藏与记录观看历史。
- 普通观看用户默认不能扫描媒体库、重新刮削、删除媒体、探测媒体轨、写出 NFO、管理文件、管理 STRM、管理下载器、创建下载任务或订阅下载。
- 由于视频流播放本身需要向客户端传输媒体数据,系统可以禁止“下载任务”和管理型下载入口,但无法从协议层完全阻止外部播放器或浏览器保存已授权播放的数据流。
MediaStationGo 已预留并接入私有独立的 MediaStationLicenseServer:
- 授权服务器:
ShukeBta/MediaStationLicenseServer,本地备份路径示例为C:\Users\Administrator\WorkBuddy\license_server_backup。 - 主项目后端提供
/api/license/activate、/api/license/status、/api/license/heartbeat,由服务端代理调用 License Server,不在浏览器暴露 HMAC 密钥。 - License Server 公共接口使用
/api/v1/activate、/api/v1/status/:fingerprint、/api/v1/heartbeat。 - 在「系统设置 → 授权服务」填写
license.server_url与license.hmac_secret,然后在「授权许可」页面绑定授权码。 - 未绑定或授权失效时保持开源版能力;授权有效时当前实现将用户额度提升到授权版额度。
环境变量示例:
MEDIASTATION_LICENSE_SERVER_URL=http://127.0.0.1:8001
MEDIASTATION_LICENSE_HMAC_SECRET=与 License Server 的 LICENSE_HMAC_SECRET 一致MediaStationGo 不会把 ffmpeg 或 ffprobe 作为常驻守护进程启动。它们只在以下场景被临时调用:
- 扫描或手动探测媒体轨时调用
ffprobe。 - 浏览器无法直放、需要 HLS 转码时调用
ffmpeg。 - 管理后台手动检测工具状态或手动安装工具时短暂调用版本检测/安装逻辑。
播放停止、转码任务取消或服务退出时,后台会结束对应转码任务。空闲状态下如果没有扫描、探测或转码,ffmpeg/ffprobe 不应持续占用 CPU。
默认 HLS 转码使用 NAS 友好的低负载策略:MEDIASTATION_TRANSCODER_ENABLED=true 是总开关,关闭后不会启动 ffmpeg 转码;MEDIASTATION_TRANSCODER_HARDWARE_ACCEL=false 是硬件加速总开关,只有开启后才会使用 MEDIASTATION_TRANSCODER_ENCODER=nvenc/qsv/vaapi;MEDIASTATION_TRANSCODER_REALTIME=true 按播放速度处理输入,MEDIASTATION_TRANSCODER_THREADS=2 限制软件编码线程,MEDIASTATION_TRANSCODER_MAX_CONCURRENT=1 限制同时转码数量,MEDIASTATION_TRANSCODER_IDLE_TIMEOUT_SECONDS=120 在播放器停止请求分片后自动结束 ffmpeg。
默认 Docker 镜像使用精简运行层,不再内置 Intel VAAPI / mesa 驱动依赖,以降低 Docker Hub 漏洞扫描暴露面。需要自构建 Intel VAAPI/QSV 镜像时,可使用 docker buildx build --build-arg WITH_VAAPI=true ...;NVIDIA NVENC 仍主要依赖宿主机安装 NVIDIA Container Toolkit 并在运行容器时启用 GPU。
MediaStationGo 的刮削顺序尽量避免重复请求和错误覆盖:
- 优先读取本地 NFO、poster、fanart、season poster、episode image。
- 根据文件名识别电影、剧集、动漫、综艺、成人内容。
- 使用 TMDb / TheTVDB / Bangumi / 豆瓣补全缺失元数据。
- 使用 Fanart.tv 补充更高清的艺术图。
- 成人内容优先读取本地 NFO 与图片,再通过 JavBus/JavDB 等公开页面补全。
- 已有本地元数据不会被无意义重复刮削覆盖。
推荐目录结构:
/media/Movies/Inception (2010)/Inception (2010).mkv
/media/TV/Some Show/Season 01/Some Show S01E01.mkv
/media/Anime/Anime Title/Season 01/Anime Title S01E01.mkv
/media/Variety/Show Name/Season 2026/Show Name S2026E01.mkv
/media/Adult/ABCD-123/ABCD-123.mp4
本地图片常见命名:
poster.jpg
fanart.jpg
folder.jpg
season01-poster.jpg
S01E01-thumb.jpg
movie.nfo
tvshow.nfo
episode.nfo
MediaStationGo 的智能分类分为两个阶段:
- 下载阶段:根据订阅类型、搜索结果分类和标题特征,把任务保存到下载器根目录下的分类子目录。
- 整理阶段:用户可选择手动整理,或开启自动整理;整理时先进入媒体库一级目录,再进入二级分类目录。
推荐宿主机目录:
/your-nas/downloads
/your-nas/media/电影
/your-nas/media/电视剧
对应容器内目录:
/downloads
/media/电影
/media/电视剧
下载器智能分类示例:
/downloads/动画电影
/downloads/国产剧
/downloads/国漫
/downloads/华语电影
/downloads/日番
/downloads/外语电影
/downloads/综艺
整理后媒体库示例:
/media/电视剧/国产剧/剧名 (2026)/Season 01/剧名 - S01E01 - 第 1 集.mkv
/media/电视剧/国漫/动画名 (2026)/Season 01/动画名 - S01E01 - 第 1 集.mkv
/media/电视剧/欧美剧/剧名 (2026)/Season 01/剧名 - S01E01 - 第 1 集.mkv
/media/电视剧/日番/番剧名 (2026)/Season 01/番剧名 - S01E01 - 第 1 集.mkv
/media/电视剧/日韩剧/剧名 (2026)/Season 01/剧名 - S01E01 - 第 1 集.mkv
/media/电视剧/综艺/综艺名 (2026)/Season 2026/综艺名 - S2026E01 - 第 1 集.mp4
/media/电影/动画电影/电影名 (2026)/电影名 (2026) - 1080p.mkv
/media/电影/华语电影/电影名 (2026)/电影名 (2026) - 1080p.mkv
/media/电影/外语电影/电影名 (2026)/电影名 (2026) - 1080p.mkv
如果媒体库根目录直接设置为 /media,整理器会在启用智能分类时自动补上 电影/ 或 电视剧/ 一级目录;如果你已经把媒体库设置为 /media/电影 或 /media/电视剧,则不会重复追加一级目录。
自动整理与手动整理是两件事:
downloads.smart_classify:控制订阅下载 / 站点搜索下载是否自动按媒体分类写入下载目录和 qB 分类,默认开启。organizer.smart_classify:只控制是否使用智能分类目录。organizer.auto_after_download/organize.auto:控制下载完成后是否自动整理。- 未开启自动整理时,可以在「整理与维护」页面手动整理媒体库或单个媒体。
整理规则建议按媒体类型拆分。剧集、动漫、综艺都属于连续剧集类,应保留剧名、年份、季目录、季集号和分集标题;电影类则保留片名、年份、分段和视频规格。
剧集 / 动漫 / 综艺推荐模板(参考MPV2模板):
{{title}}{% if year %} ({{year}}){% endif %}/Season {{season}}/{{title}} - {{season_episode}}{% if part %}-{{part}}{% endif %}{% if episode %} - 第 {{episode}} 集{% endif %}{{fileExt}}输出示例:
孤独的美食家 (2024)/Season 01/孤独的美食家 - S01E01 - 第 1 集.mkv
某动画 (2025)/Season 02/某动画 - S02E03 - 第 3 集.mkv
某综艺 (2026)/Season 2026/某综艺 - S2026E01 - 第 1 集.mp4
电影推荐模板:
{{title}}{% if year %} ({{year}}){% endif %}/{{title}}{% if year %} ({{year}}){% endif %}{% if part %}-{{part}}{% endif %}{% if videoFormat %} - {{videoFormat}}{% endif %}{{fileExt}}输出示例:
盗梦空间 (2010)/盗梦空间 (2010) - 1080p.mkv
沙丘 (2021)/沙丘 (2021)-CD1 - 2160p.mkv
常用变量说明:
| 变量 | 说明 |
|---|---|
title |
媒体标题,优先使用本地 NFO / 在线元数据识别后的标题 |
year |
年份,存在时追加到目录和文件名中 |
season |
季号,剧集/动漫/综艺用于生成 Season 01 等目录 |
season_episode |
季集号,例如 S01E01、S2026E01 |
episode |
分集序号,用于中文分集标题 |
part |
分段标记,例如 CD1、Part1 |
videoFormat |
视频规格,例如 1080p、2160p、WEB-DL |
fileExt |
原始文件扩展名,例如 .mkv、.mp4 |
精彩发现支持:
- TMDb:趋势、热门电影、热门剧集、高分电影。
- 豆瓣:热门电影、高分电影、热门剧集。
- Bangumi:每日放送、动漫条目。
智能搜索会同时考虑:
- 本地媒体库已有内容。
- TMDb / 豆瓣 / Bangumi 等在线结果。
- 可订阅关键词与媒体类型。
订阅支持以下规则:
| 规则 | 说明 |
|---|---|
| 媒体类型 | 电影、剧集、动漫、综艺,支持自动识别 |
| 搜索模式 | 标题关键词或 IMDB ID |
| 分辨率 | 自动择优、2160p、1080p、720p |
| 质量 | REMUX、BluRay、WEB-DL、HDTV 等 |
| 特效 | HDR、Dolby Vision、Atmos 等 |
| 发布组 | 白名单发布组 |
| 排除词 | 排除 CAM、TS、枪版等低质资源 |
| 洗版 | 默认关闭,可按分辨率、质量、特效、做种数优先 |
下载与订阅卡片只展示安全标题、海报、进度、速度、体积等信息,不展示原始种子 URL,避免多用户场景泄露私人 Tracker Token。
项目提供 Emby/Jellyfin 风格 API,用于外部客户端连接:
http://<服务器IP>:18080
可尝试的客户端:
- Infuse
- VidHub
- SenPlayer
- 其他支持 Emby/Jellyfin 服务器的播放器
建议检查:
- Docker 端口是否映射为
18080:8080。 - 防火墙是否允许局域网访问
18080。 - 账号密码是否正确。
- 反向代理是否正确转发
/api、视频流和 Range 请求。
MediaStationGo 在外部客户端兼容与媒体生态联动上参考了 MoviePilot 的成熟产品路径:通过统一媒体库、订阅下载、下载后整理和 Emby/Jellyfin 兼容接口,把 Web 管理端与 Infuse、VidHub、SenPlayer 等客户端串起来。本项目的目标不是替代 Emby/Jellyfin,而是在最极少的资源占用的轻量 Go 服务中提供足够常用的媒体浏览、播放、海报墙、剧集分季分集、播放进度和外部客户端访问能力。
当前兼容重点:
- 媒体库、合集、季、集的层级输出。
- 海报、背景图、简介、年份、评分等基础元数据输出。
- 视频流地址、HTTP Range、播放进度与继续观看。
- 外部客户端登录、媒体浏览和播放所需的 Emby/Jellyfin 风格接口。
仍在持续补齐:
- 更完整的 Emby/Jellyfin 设备能力协商。
- 更细的转码 Profile 与字幕能力声明。
- 多用户权限、媒体库过滤与播放历史同步。
- 与订阅下载、自动整理、洗版规则之间的闭环联动。
MoviePilot 项目使用 GPL-3.0 许可,本项目只参考其公开产品思路与交互路径,不复制私有数据、密钥、站点账号或不兼容实现。
在后台「外部 API 配置」中可配置:
| 服务 | 作用 |
|---|---|
| TMDb | 电影、剧集、海报、背景图、简介 |
| Bangumi | 动漫、番剧、中文条目 |
| TheTVDB | 剧集季集补充 |
| Fanart.tv | 高清 Logo、背景图、艺术图 |
| 豆瓣 | 中文影视搜索与推荐补充 |
| OpenAI Compatible | AI 搜索、推荐、运维助手 |
M-Team 建议使用 API Access Token:
控制台 → 实验室 → 存取令牌
HTTP Header: x-api-key
不建议使用 Cookie 调用开放 API,避免账号风险。
默认不会提交以下数据:
data/、cache/、logs/.tmp-deploy-data/、.tmp-deploy-server.*.mediastation.pidconfig.yaml、.env**.db、*.db-wal、*.logweb/dist/、node_modules/、bin/- API Key、Cookie、Token、密码、证书等敏感文件
提交前建议检查:
git status --short
git ls-files | grep -E 'data/|cache/|\.db|\.log|jwt_secret|config.yaml|\.env|token|apikey|password' || trueEOF 通常表示服务器到 GHCR 的网络连接中途断开,不是 compose 文件语法错误。建议按顺序处理:
# 1. 清理可能异常的 GHCR 登录状态
docker logout ghcr.io || true
# 2. 单独拉取镜像,确认是网络/ registry 问题还是 compose 问题
docker pull ghcr.io/shukebta/mediastation-go:latest
# 3. 如果是 x86_64/AMD64 主机,也可以显式指定平台重试
docker pull --platform linux/amd64 ghcr.io/shukebta/mediastation-go:latest
# 4. 拉取成功后再启动
docker compose up -d如果服务器在国内网络或 NAS 网络环境中,建议为 Docker daemon 配置可访问 GHCR 的代理;仅设置终端代理通常不一定会被 Docker 服务进程继承。默认 compose 已使用 pull_policy: missing,避免容器重启时反复访问 GHCR。
另外,你示例中的路径如果是 NAS 绝对路径,建议写成 /your-nas/...,不要写 ./your-nas/...;前者是系统根目录路径,后者是当前 compose 目录下面的相对路径。
检查容器状态和端口:
docker ps
docker logs -f mediastation-go确认访问的是宿主机端口,例如 http://你的IP:18080。
优先检查防火墙、Docker 端口映射、反向代理和局域网 IP。容器内监听 8080,宿主机默认映射为 18080。
请确认:
- 本地是否有
poster.jpg、fanart.jpg、NFO。 - TMDb / Bangumi / 豆瓣是否可连接。
- 代理是否正确配置。
- 媒体文件名是否包含清晰标题、年份、季集信息。
PT 下载 URL 常包含私有 Token。下载中心和订阅管理会主动隐藏原始 URL,只显示安全标题、海报、速度、进度、体积等信息。
- 更完整的 Emby/Jellyfin 客户端兼容。
- 更强的成人内容本地元数据和公开页面补全。
- 更细粒度的订阅洗版和下载后整理规则。
- 更完善的移动端/电视端交互。
- 插件化站点适配器和通知渠道。
- 更完整的端到端测试与截图自动化。
欢迎提交 Issue、Pull Request、站点适配、刮削规则、UI 改进与文档修正。
建议贡献前先运行:
go test ./...
cd web && npm run build- Telegram:https://t.me/MediaStationGo
如果这个项目节省了你的时间,欢迎请作者吃桶泡面。
本项目基础许可证遵循 GPL-3.0,详见 LICENSE。项目维护者同时声明并倡议:
- 本项目主要面向个人学习、家庭 NAS、自建影音、非商业研究与社区共建场景。
- 未经作者明确书面许可,不得将本项目或衍生版本用于商业售卖、商业托管、付费 SaaS、预装售卖设备、闭源二次分发或其他商业化牟利用途。
- 如需商业合作、企业内部部署、定制开发、集成发行或商业授权,请先联系作者确认授权边界。
- 若 README 的非商用声明与
GPL-3.0正式许可文本存在解释差异,代码授权以 LICENSE 文件为准,商业使用请额外取得作者许可。
Made with ❤️ by ShukeBta

































