https://github.com/franklioxygen/MyTube
Self-hosted downloader and player for YouTube, Bilibili, Twitch, MissAV, and yt-dlp sites. Features channel subscriptions, auto-downloads, and local storage for media. Organize your library into collections with a sleek UI. Includes built-in Cloudflare Tunnel support for secure remote access without port forwarding. Docker-ready deployment.
https://github.com/franklioxygen/MyTube
bilibili bilibili-download cloudflare-tunnel docker downloader expressjs missav mui nas sqlite tanstack-query twitch typescript video-hosting video-player youtube youtube-downloader yt-dlp
Last synced: 15 days ago
JSON representation
Self-hosted downloader and player for YouTube, Bilibili, Twitch, MissAV, and yt-dlp sites. Features channel subscriptions, auto-downloads, and local storage for media. Organize your library into collections with a sleek UI. Includes built-in Cloudflare Tunnel support for secure remote access without port forwarding. Docker-ready deployment.
- Host: GitHub
- URL: https://github.com/franklioxygen/MyTube
- Owner: franklioxygen
- License: mit
- Created: 2025-03-09T03:33:55.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2026-05-04T19:34:54.000Z (16 days ago)
- Last Synced: 2026-05-04T21:27:52.301Z (16 days ago)
- Topics: bilibili, bilibili-download, cloudflare-tunnel, docker, downloader, expressjs, missav, mui, nas, sqlite, tanstack-query, twitch, typescript, video-hosting, video-player, youtube, youtube-downloader, yt-dlp
- Language: TypeScript
- Homepage: https://mytube-demo.vercel.app
- Size: 16 MB
- Stars: 972
- Watchers: 4
- Forks: 83
- Open Issues: 8
-
Metadata Files:
- Readme: README-zh.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-selfhosted - MyTube - Downloader and player for yt-dlp-supported sites with channel subscriptions, cloud upload support, and local library organization. ([Demo](https://mytube-demo.vercel.app)) `MIT` `Nodejs/Docker` (Software / Media Management)
- awesome-selfhosted - MyTube - Downloader and player for yt-dlp-supported sites with channel subscriptions, cloud upload support, and local library organization. ([Demo](https://mytube-demo.vercel.app)) `MIT` `Nodejs/Docker` (Software / Media Management)
- fucking-awesome-selfhosted - MyTube - Downloader and player for yt-dlp-supported sites with channel subscriptions, cloud upload support, and local library organization. ([Demo](https://mytube-demo.vercel.app)) `MIT` `Nodejs/Docker` (Software / Media Management)
README
# MyTube
支持 YouTube、Bilibili、Twitch、MissAV 及 [yt-dlp 站点](https://github.com/yt-dlp/yt-dlp/blob/master/supportedsites.md) 的自托管视频下载器与播放器。具备频道订阅、自动下载、本地化存储以及面向外部阅读器的私密 RSS 订阅链接。UI 设计精美,支持收藏集分类管理。内置 Cloudflare Tunnel 支持,无需端口映射即可实现安全远程访问。支持 Docker 一键部署。
🚀 100% 提示工程构建,零人工介入代码。
[](https://github.com/franklioxygen/mytube)

[](https://discord.gg/dXn4u9kQGN)


[](https://github.com/franklioxygen/MyTube/actions/workflows/lighthouse.yml)
[](https://app.codacy.com/gh/franklioxygen/MyTube/dashboard?utm_source=gh&utm_medium=referral&utm_content=&utm_campaign=Badge_grade)
[](https://app.codacy.com/gh/franklioxygen/MyTube/dashboard?utm_source=gh&utm_medium=referral&utm_content=&utm_campaign=Badge_coverage)
[](https://github.com/franklioxygen/mytube)
[English](README.md) | [更新日志](CHANGELOG.md)
## 在线演示
🌐 **访问在线演示(只读): [https://mytube-demo.vercel.app](https://mytube-demo.vercel.app)**
[](https://www.youtube.com/watch?v=0_5ZpgsWTp0)
## 功能特点
- **视频下载**:通过简单的 URL 输入下载 YouTube、Bilibili、Twitch、MissAV 以及其他 yt-dlp 支持的视频。
- **视频上传**:直接上传本地视频文件到您的库,并自动生成缩略图。
- **TMDB 元数据抓取**:基于文件名自动从 TMDB 抓取电影和电视剧元数据(标题、描述、封面、导演、年份、评分)。支持根据站点语言获取本地化内容。
- **并行下载**:支持队列下载,可同时追踪多个下载任务的进度。
- **批量下载**:一次性添加多个视频链接到下载队列。
- **并发下载限制**:设置同时下载的数量限制以管理带宽。
- **云存储集成**:下载后自动将视频和缩略图上传到云存储(OpenList/Alist)。
- **字幕**:自动下载 YouTube / Bilibili 默认语言字幕。
- **收藏夹**:创建自定义收藏夹以整理您的视频。
- **订阅功能**:管理 YouTube、Bilibili 和 Twitch 频道订阅,并在新内容发布后自动下载。
- **RSS 订阅**:为外部 RSS 阅读器创建私密订阅链接,并可按频道、作者、标签、来源、最近时间范围和条目上限分别配置过滤条件。
- **登录保护**:支持密码登录并可选使用通行密钥 (WebAuthn)。
- **访客用户**:启用只读角色,便于分享但不允许修改。
- **国际化**:支持多种语言,包括英语、中文、西班牙语、法语、德语、日语、韩语、阿拉伯语、葡萄牙语和俄语。
- **移动端优化**:移动端友好的标签菜单和针对小屏幕优化的布局。
- **Cookie 管理**:支持上传 `cookies.txt` 以启用年龄限制或会员内容的下载。
- **yt-dlp 配置**: 通过用户界面自定义全局 `yt-dlp` 参数、网络代理及其他高级设置。
- **TMDB 集成**:在设置中配置您的 TMDB API 密钥,即可为本地视频文件启用自动元数据抓取。抓取器会智能解析文件名以提取标题并与 TMDB 数据库匹配。
- **Cloudflare Tunnel 集成**: 内置 Cloudflare Tunnel 支持,无需端口转发即可轻松将本地 MyTube 实例暴露到互联网。
- **任务钩子**: 在下载任务的各个阶段(开始、成功、失败、取消)执行自定义 Shell 脚本,以实现集成和自动化。详见 [任务钩子指南](documents/zh/hooks-guide.md)。
- **Telegram 通知**: 当下载任务成功或失败时,通过 Telegram 机器人接收即时通知。
- **浏览器扩展**: 提供 Chrome 扩展,支持直接从浏览器下载视频。支持所有 yt-dlp 支持的站点。
## 浏览器扩展
有关安装和使用说明,请参阅 [浏览器扩展](documents/zh/chrome-extension.md)。
## MikMok
[MikMok](https://github.com/franklioxygen/MikMok) 是 MyTube 的短视频 Web 客户端,可通过 API 连接 MyTube,提供更适合短视频浏览的流式观看体验。
## 目录结构
有关项目结构的详细说明,请参阅 [目录结构](documents/zh/directory-structure.md)。
## 开始使用
有关安装和设置说明,请参阅 [开始使用](documents/zh/getting-started.md)。
## 部署安全模型
有关管理员三档信任边界与部署安全模型的说明,请参阅 [部署安全模型](documents/zh/deployment-security-model.md)。
## API 端点
有关可用 API 端点的列表,请参阅 [API 端点](documents/zh/api-endpoints.md)。
## 技术栈
### 后端
- **运行时**: Node.js with TypeScript
- **框架**: Express.js
- **数据库**: SQLite with Drizzle ORM
- **测试**: Vitest
- **架构**: 分层架构 (路由 → 控制器 → 服务 → 数据库)
### 前端
- **框架**: React 19 with TypeScript
- **构建工具**: Vite
- **UI 库**: Material-UI (MUI)
- **状态管理**: React Context API
- **路由**: React Router v7
- **HTTP 客户端**: Axios with React Query
### 关键架构特性
- **模块化存储服务**: 拆分为专注的模块以提高可维护性
- **下载器模式**: 用于平台特定实现的抽象基类
- **数据库迁移**: 使用 Drizzle Kit 自动更新模式
- **下载队列管理**: 支持队列的并发下载
- **视频下载跟踪**: 防止跨会话重复下载
## 环境变量
该应用使用环境变量进行配置。
### 前端 (`frontend/.env`)
```env
VITE_API_URL=/api
VITE_BACKEND_URL=
```
### 后端 (`backend/.env`)
```env
PORT=5551
# 可选:声明当前部署中管理员的信任边界。
# 可选值:application | container | host
# 默认值:container
# MYTUBE_ADMIN_TRUST_LEVEL=container
```
默认数据与上传路径位于 `backend/data` 和 `backend/uploads`(相对于后端工作目录)。
将 `backend/.env.example` 复制为 `backend/.env` 并按需调整。前端已提供 `frontend/.env`,可使用 `frontend/.env.local` 覆盖默认值。
## 数据库
MyTube 使用 **SQLite** 和 **Drizzle ORM** 进行数据持久化。数据库在首次启动时自动创建和迁移:
- **位置**: `backend/data/mytube.db`
- **迁移**: 在服务器启动时自动运行
- **模式**: 通过 Drizzle Kit 迁移管理
- **旧版支持**: 提供迁移工具以从基于 JSON 的存储转换
关键数据库表:
- `videos`: 视频元数据和文件路径
- `collections`: 视频收藏夹/播放列表
- `subscriptions`: 频道/创作者订阅
- `rss_tokens`: 私密 RSS 订阅链接、过滤条件、启停状态和访问统计
- `downloads`: 活动下载队列
- `download_history`: 完成的下载历史
- `video_downloads`: 跟踪已下载的视频以防止重复
- `settings`: 应用程序配置
## 贡献
我们欢迎贡献!请参阅 [CONTRIBUTING.md](CONTRIBUTING.md) 了解如何开始、我们的开发工作流程以及代码质量指南。
## 部署
有关 Docker 部署的详细说明(包括 GitHub 官方容器镜像 `ghcr.io/franklioxygen/mytube:latest` 与单容器 `stacks/docker-compose.single-container.yml`),请参阅 [Docker 部署指南](documents/zh/docker-guide.md).
有关 `application` / `container` / `host` 三档管理员信任边界,请参阅 [部署安全模型](documents/zh/deployment-security-model.md)。
## 星标历史
## 免责声明
- 使用目的与限制 本软件(及相关代码、文档)仅供个人学习、研究及技术交流使用。严禁将本软件用于任何形式的商业用途,或利用本软件进行违反国家法律法规的犯罪活动。
- 责任界定 开发者对用户使用本软件的具体行为概不知情,亦无法控制。因用户非法或不当使用本软件(包括但不限于侵犯第三方版权、下载违规内容等)而产生的任何法律责任、纠纷或损失,均由用户自行承担,开发者不承担任何直接、间接或连带责任。
- 二次开发与分发 本项目代码开源,任何个人或组织基于本项目代码进行修改、二次开发时,应遵守开源协议。 特别声明: 若第三方人为修改代码以规避、去除本软件原有的用户认证机制/安全限制,并进行公开分发或传播,由此引发的一切责任事件及法律后果,需由该代码修改发布者承担全部责任。我们强烈不建议用户规避或篡改任何安全验证机制。
- 非盈利声明 本项目为完全免费的开源项目。开发者从未在任何平台发布捐赠信息,本软件本身不收取任何费用,亦不提供任何形式的付费增值服务。任何声称代表本项目收取费用、销售软件或寻求捐赠的信息均为虚假信息,请用户仔细甄别,谨防上当受骗。
## 许可证
MIT