注意: 32位ARM构建已停止支持(在其他主要参与者之后整整一年),因为新版本的Node不支持它们,而持续的安全更新和依赖项需要新的Node版本。请迁移到64位操作系统以继续接收MeTube升级。
youtube-dl的Web图形界面(使用yt-dlp分支),支持播放列表功能。允许您从YouTube和其他数十个网站下载视频。

docker run -d -p 8081:8081 -v /path/to/downloads:/downloads ghcr.io/alexta69/metube
version: "3" services: metube: image: ghcr.io/alexta69/metube container_name: metube restart: unless-stopped ports: - "8081:8081" volumes: - /path/to/downloads:/downloads
某些值可以通过环境变量设置,使用 docker 命令行的 -e 参数,或 docker-compose 中的 environment: 部分。
1000。1000。022。light、dark 或 auto。默认为 auto。/downloads,其他情况下默认为 .。DOWNLOAD_DIR 值相同。true,下载目录(DOWNLOAD_DIR 和 AUDIO_DOWNLOAD_DIR)在网络服务器上可索引。默认为 false。true。true。/downloads/.metube,其他情况下默认为 .。/downloads,其他情况下默认为 .。tmpfs)以获得更好的性能true,当从界面的"已完成"部分将文件移至垃圾桶时,服务器上的下载文件将被删除。默认为 false。/。%(title)s.%(ext)s。%(title)s - %(section_number)s %(section_title)s.%(ext)s。--recode-video 必须通过 postprocessors 指定。另请注意,破折号替换为下划线。YTDL_OPTIONS 的 JSON 文件路径。请注意,如果同时指定了 YTDL_OPTIONS_FILE 和 YTDL_OPTIONS,YTDL_OPTIONS 中的选项优先。以下 YTDL_OPTIONS 示例值嵌入英语字幕和章节标记(对于有章节的视频),并更改下载视频的权限,将文件修改时间戳设置为下载日期:
environment: - 'YTDL_OPTIONS={"writesubtitles":true,"subtitleslangs":["en","-live_chat"],"updatetime":false,"postprocessors":[{"key":"Exec","exec_cmd":"chmod 0664","when":"after_move"},{"key":"FFmpegEmbedSubtitle","already_have_subtitle":false},{"key":"FFmpegMetadata","add_chapters":true}]}'
以下 OUTPUT_TEMPLATE 示例值设置:
environment: - 'OUTPUT_TEMPLATE=%(playlist_title&Playlist |)S%(playlist_title|)S%(playlist_uploader& by |)S%(playlist_uploader|)S%(playlist_autonumber& - |)S%(playlist_autonumber|)S%(playlist_count& of |)S%(playlist_count|)S%(playlist_autonumber& - |)S%(uploader,creator|UNKNOWN_AUTHOR)S - %(title|UNKNOWN_TITLE)S - %(release_date>%Y-%m-%d,upload_date>%Y-%m-%d|UNKNOWN_DATE)S.%(ext)s'
如果您需要在 MeTube 中使用浏览器的 cookies,例如下载受限制或私密视频:
volumes: - /path/to/cookies:/cookies environment: - YTDL_OPTIONS={"cookiefile":"/cookies/cookies.txt"}
在您的浏览器中安装一个提取 cookies 的扩展:
使用扩展提取所需的 cookies,并将文件重命名为 cookies.txt
将该文件放入您在上面 docker-compose.yml 中配置的文件夹
重启容器
浏览器扩展允许右键点击视频并直接将其发送到MeTube。请注意,如果您在HTTPS页面上,您的MeTube实例必须位于HTTPS反向代理(见下文)之后,扩展才能正常工作。
__Chrome:__由Rpsl贡献。您可以从Google Chrome网上应用店安装,或使用开发者模式从源代码安装。
__Firefox:__由nanocortex贡献。您可以从Firefox附加组件安装,或从这里获取源代码。
rithask创建了一个iOS快捷指令,可以从Safari浏览器将网址发送到MeTube。首次使用时,你需要输入服务器地址和端口,之后这些信息会被保存,你就可以直接在Safari的分享菜单中运行这个快捷指令。地址应包括协议(http/https)和端口(如果不是默认的80/443端口)。例如:https://metube.example.com或http://192.168.1.1:8081。你可以在这里找到这个快捷指令。
iOS对视频文件有严格的要求,必须使用MP4容器中的h264或h265视频编解码器和aac音频编解码器。这有时可能会导致质量低于可用的最佳质量。为了满足iOS的要求,在下载MP4格式时,你可以选择"最佳(iOS)"选项,以获得尽可能符合iOS要求的最佳质量格式。
kushfest 创建了一个Chrome书签小工具,用于将当前打开的网页发送到MeTube。请注意,如果您在HTTPS页面上,您的MeTube实例必须位于HTTPS反向代理后面(见下文),才能使书签小工具正常工作。
GitHub不允许将JavaScript嵌入为链接,因此必须通过将以下代码复制到您在书签栏上创建的新书签中来手动创建书签小工具。请将下面URL 中的主机名更改为指向您的MeTube实例。
javascript:!function(){xhr=new XMLHttpRequest();xhr.open("POST","https://metube.domain.com/add");xhr.withCredentials=true;xhr.send(JSON.stringify({"url":document.location.href,"quality":"best"}));xhr.onload=function(){if(xhr.status==200){alert("已发送到metube!")}else{alert("发送到metube失败。请查看JavaScript控制台以获取线索。")}}}();
shoonya75 贡献了Firefox版本:
javascript:(function(){xhr=new XMLHttpRequest();xhr.open("POST","https://metube.domain.com/add");xhr.send(JSON.stringify({"url":document.location.href,"quality":"best"}));xhr.onload=function(){if(xhr.status==200){alert("已发送到metube!")}else{alert("发送到metube失败。请查看JavaScript控制台以获取线索。")}}})();
上述书签小工具使用alert()作为成功/失败通知。以下将显示一个toast消息:
Chrome:
javascript:!function(){function notify(msg) {var sc = document.scrollingElement.scrollTop; var text = document.createElement('span');text.innerHTML=msg;var ts = text.style;ts.all = 'revert';ts.color = '#000';ts.fontFamily = 'Verdana, sans-serif';ts.fontSize = '15px';ts.backgroundColor = 'white';ts.padding = '15px';ts.border = '1px solid gainsboro';ts.boxShadow = '3px 3px 10px';ts.zIndex = '100';document.body.appendChild(text);ts.position = 'absolute'; ts.top = 50 + sc + 'px'; ts.left = (window.innerWidth / 2)-(text.offsetWidth / 2) + 'px'; setTimeout(function () { text.style.visibility = "hidden"; }, 1500);}xhr=new XMLHttpRequest();xhr.open("POST","https://metube.domain.com/add");xhr.send(JSON.stringify({"url":document.location.href,"quality":"best"}));xhr.onload=function() { if(xhr.status==200){notify("已发送到metube!")}else {notify("发送到metube失败。请查看JavaScript控制台以获取线索。")}}}();
Firefox:
javascript:(function(){function notify(msg) {var sc = document.scrollingElement.scrollTop; var text = document.createElement('span');text.innerHTML=msg;var ts = text.style;ts.all = 'revert';ts.color = '#000';ts.fontFamily = 'Verdana, sans-serif';ts.fontSize = '15px';ts.backgroundColor = 'white';ts.padding = '15px';ts.border = '1px solid gainsboro';ts.boxShadow = '3px 3px 10px';ts.zIndex = '100';document.body.appendChild(text);ts.position = 'absolute'; ts.top = 50 + sc + 'px'; ts.left = (window.innerWidth / 2)-(text.offsetWidth / 2) + 'px'; setTimeout(function () { text.style.visibility = "hidden"; }, 1500);}xhr=new XMLHttpRequest();xhr.open("POST","https://metube.domain.com/add");xhr.send(JSON.stringify({"url":document.location.href,"quality":"best"}));xhr.onload=function() { if(xhr.status==200){notify("已发送到metube!")}else {notify("发送到metube失败。请查看JavaScript控制台以获取线索。")}}})();
建议在反向代理后运行MeTube,如果需要身份验证和/或HTTPS支持。
当在重新映射URL的反向代理后运行时(即在子目录而不是根目录下提供MeTube服务),别忘了将URL_PREFIX环境变量设置为正确的值。
如果你使用linuxserver/swag镜像来满足反向代理需求(我强烈推荐),它已经包含了现成的代码片段,可以在子文件夹和子域名模式下代理MeTube。这些代码片段位于配置卷的nginx/proxy-confs目录下。它还包括Authelia,可用于身份验证。
location /metube/ { proxy_pass http://metube:8081; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_set_header Host $host; }
注意:额外的proxy_set_header指令是为了使WebSocket正常工作。
# 放在Apache站点的site.conf中 # 在/metube/子目录下提供MeTube服务(http://yourdomain.com/metube/) <Location /metube/> ProxyPass http://localhost:8081/ retry=0 timeout=30 ProxyPassReverse http://localhost:8081/ </Location> <Location /metube/socket.io> RewriteEngine On RewriteCond %{QUERY_STRING} transport=websocket [NC] RewriteRule /(.*) ws://localhost:8081/socket.io/$1 [P,L] ProxyPass http://localhost:8081/socket.io retry=0 timeout=30 ProxyPassReverse http://localhost:8081/socket.io </Location>
以下是一个示例Caddyfile,用于在caddy后面设置反向代理。
example.com { route /metube/* { uri strip_prefix metube reverse_proxy metube:8081 } }
MeTube 实际视频下载功能的核心引擎是 yt-dlp。由于视频网站经常更改其布局,因此需要频繁更新 yt-dlp 以保持功能正常。
MeTube 有一个自动的每日构建,它会检查 yt-dlp 是否有新版本。如果有新版本,构建过程会拉取新版本并发布更新后的 docker 镜像。因此,为了跟上这些变化,建议您定期使用最新镜像更新 MeTube 容器。
我建议安装并设置 watchtower 来实现这一目的。
在询问问题或提交MeTube相关问题之前,请记住MeTube只是yt-dlp的一个用户界面。任何你可能遇到的与视频网站认证、后处理、权限、其他YTDL_OPTIONS配置似乎不起作用,或任何其他涉及底层yt-dlp库运作的问题,都不需要在MeTube项目上提出。为了调试和排除这些问题,建议先直接使用yt-dlp二进制文件,绕过用户界面,一旦成功运行,再将有效的选项导入YTDL_OPTIONS。
为了直接测试yt-dlp命令,你可以下载并在本地运行它,或者为了更好地模拟实际条件,你可以在MeTube容器内运行它。假设你的MeTube容器名为metube,在Docker主机上运行以下命令以获取容器内的shell:
docker exec -ti metube sh cd /downloads
进入后,你就可以自由使用yt-dlp命令了。
确保已安装 node.js 和 Python 3.11。
cd metube/ui # 安装 Angular 并构建用户界面 npm install node_modules/.bin/ng build # 安装 Python 依赖 cd .. pip3 install pipenv pipenv install # 运行 pipenv run python3 app/main.py
可以在本地构建 Docker 镜像(这也会构建用户界面):
docker build -t metube .


全球首个AI音乐社区
音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。


阿里Qoder团队推出的桌面端AI智能体
QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。


一站式搞定所有学习需求
不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。


为AI短剧协作而生
专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。


能听懂你表达的视频模型
Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。


国内直接访问,限时3折
输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动


职场AI,就用扣子
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!


多风格AI绘画神器
堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。


零代码AI应用开发平台
零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。


免费创建高清无水印Sora视频
Vora是一个免费创建高清无水印Sora视频的AI工具
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号