跳转至

Kubespider

Kubespider logo

💥 一款全局资源编排下载系统

Python GitHub release Total Downloads GitHub stars GitHub license

我们是一群热爱生活的人,因兴趣和共同需求聚集在一起,利用空闲时间共同开发了 Kubespider。

开发Kubespider的出发点是:局域网有一台空闲的服务器,想把它作为NAS,实现自动追剧下载,本地笔记本电脑触发下载,同时适配各种网站资源(Youtube、Bilibili等)和资源类型(电视剧、电影、音乐等)。

之前接触到Terraform,惊讶于其通用性。Kubespider受到Terraform启发,旨在构建一个通用的下载编排系统,兼容各种资源平台和下载软件,兼容多种下载方式(请求触发,周期触发,更新触发),做资源下载最完美的统一解决方案。

⛵ 系统架构

为了实现一个通用的下载编排系统,需要适配各种资源网站和下载软件,所以将这两部分从核心功能中抽象出来: image

  • kubespider-core:Kubespider核心模块,接受触发下载请求,调用资源提供器provider解析(最终会解析为标准模式,如用户输入bilibili博主地址,对应资源提供器输出mp4文件地址下载列表),最后调用下载提供器provider实现下载;此模块同时也会周期调用providers(如追剧provider),下载增加的资源。
  • source-provider:各资源网站的提供器,接受通用资源地址输入,输出为标准资源地址url,如输入为某个bilibili博主的个人主页,输出为博主视频的所有mp4下载地址。配置文件在.config/source_provider.yaml
  • download-provider:各下载软件的提供器,接收kubespider-core的请求Task,调用对应的服务实现下载。配置文件在.config/download_provider.yaml

💽 安装

前提

  1. 操作电脑和你的服务器在同一局域网。(暂时还没有试过不在同一局域网的安装)
  2. 服务器为linux系统。
  3. 服务器已安装Docker。

默认安装(使用Docker部署)

Kubespider为了适配多种资源平台,提供了许多适配器,按你的需要开启或关闭这些适配器,配置文件在.config文件夹:

1.下载代码库并且安装

# 如果镜像无法下载或速度较慢请设置此环境变量
# export CHINA_MAINLAND=TRUE
git clone https://github.com/opennaslab/kubespider.git
cd kubespider
bash hack/install_kubespider.sh

输出类似:

root@cesign [09:01:34 PM] [+22.0°C] [~/git/kubespider] [main *]
-> # bash hack/install_kubespider.sh
 _          _                     _     _
| | ___   _| |__   ___  ___ _ __ (_) __| | ___ _ __
| |/ / | | | '_ \ / _ \/ __| '_ \| |/ _` |/ _ \ '__|
|   <| |_| | |_) |  __/\__ \ |_) | | (_| |  __/ |
|_|\_\\__,_|_.__/ \___||___/ .__/|_|\__,_|\___|_|
                           |_|
[INFO] Start to deploy with default configuration...
b13820946878c4f00635e7fa3db64ea83506850ebb7d07ff77b62814db1d894a
WARNING: Published ports are discarded when using host network mode
9c0aa1059f1546a4f1a2accac445ce1389f1c400b96328f3e18c8af03f0bbc70
[INFO] Deploy successful, check the information:
*******************************************
Kubespider config path: /root/kubespider/.config
Download file path: /root/kubespider/nas/
Kubespider webhook address: http://<server_ip>:3080
Aria2 server address: http://<server_ip>:6800/jsonrpc, you can use any gui or webui to connect it
Aria2 default secret is:kubespider
*******************************************
  • 此步骤会安装KubespideAria2资源下载程序,作为默认的下载器。
  • 安装后,所有下载文件会存储到 ${HOME}/kubespider/nas
  • 配置文件在 ${HOME}/kubespider/.config

2.连接aria2

为了便于查看下载任务,需要下载Chrome插件AriNg:(1)如果你能访问外网,在chrome商店下载AriaNg;(2)如果不能,在Crx4Chrome下载AriaNg

然后连接,插件配置如下(显示在脚本install_kubespider.sh执行输出最后): img

当然,非必需的,你也可以使用桌面程序连接:AriaNg

3.安装Chrome插件

Kubespider结合chrome插件,能获得更好的体验。
在步骤1下载代码后,打开Chrome,按如下步骤安装Kubespider Chrome插件并且设置(其中地址为http://<server_ip>:3080):
img

例如,我想要下载一个torrent的大文件,直接右键,发送给Kubespider即可(示例网站): img

然后,使用aria2 Chrome插件查看下载任务,你可以看见下载任务已开始:
img

4.更多(可选)

  • 安装Plex,多平台观看视频,立即安装
  • 安装Jellyfin,多平台观看视频,立即安装
  • TODO: 安装百度网盘,后台下载。

📝 配置

全局配置文件在.config/kubespider.yaml,安装后位于${HOME}/kubespider/.config/kubespider.yaml,各配置项解释如下:

配置项 是否必配 功能
proxy 请求代理,如http://192.168.1.5:1087
auth_token 认证token,用于下载触发请求认证,如果需要公网访问可以配置,以增加安全性

🔧 特性列表

资源提供器(按需配置)

如前面所述,资源提供器用于对接各种资源网站,条件触发下载相关资源:

资源提供器 是否支持 用途 配置手册
mikanani资源提供器 全自动动漫追番 link
btbtt12资源提供器 实现链接触发下载,简化下载流程 link
meijutt资源提供器 自动追美剧 link
YouTube资源提供器 触发下载YouTube视频 link
Bilibili资源提供器 触发下载Bilibili视频 link
通用rss资源提供器 自动下载rss订阅资源 link
通用xpath资源提供器 触发下载通过xpath配置的内容资源 link
ANi资源提供器 自动下载ANi项目番剧资源 link

下载提供器(按需配置)

为了充分利用开源社区已有的下载软件(如YouTube有专门的下载软件),目前支持如下下载软件:

下载软件 是否支持 配置手册
aria2 link
迅雷 link
qBittorrent link
you-get link
yt-dlp link
transmission link
yutto link

基本特性

目前支持如下文件触发下载:

下载类型 是否支持
magnet
torrent
通用文件(jpg, mp4等)

触发下载使用方法请查看 link

🙋常见问题

我们列举了使用过程中可能遇到的问题供您参考,也欢迎您记录您的问题和解决方案,共同完善文档。

🤝 参与共建 PRs Welcome

如果你有兴趣参与共同开发,欢迎 STAR/FORK/PR,Roadmap请查看 link

  • 如何开发调试Kubespider,请看 link
  • 如何编写资源网站的资源提供器,请看 link
  • 如何编写下载软件的下载提供器,请看 link
  • 如何开发调试chrome插件webhook,请看 link
  • 如何开发其他webhook触发工具, 请看 link

❤️ 赞助

感谢以下公司赞助开发工具,排名不分先后:







📃 免责声明

一切下载及使用软件时均被视为已经仔细阅读并完全同意以下条款:

  • 软件仅供个人学习与交流使用,严禁用于商业以及不良用途。
  • 如有发现任何商业行为以及不良用途,软件作者有权撤销使用权。
  • 使用本软件所存在的风险将完全由其本人承担,软件作者不承担任何责任。
  • 软件注明之服务条款外,其它因不当使用本软件而导致的任何意外、疏忽、合约毁坏、诽谤、版权或其他知识产权侵犯及其所造成的任何损失,本软件作者概不负责,亦不承担任何法律责任。
  • 对于因不可抗力或因黑客攻击、通讯线路中断等不能控制的原因造成的服务中断或其他缺陷,导致用户不能正常使用,软件作者不承担任何责任,但将尽力减少因此给用户造成的损失或影响。
  • 本声明未涉及的问题请参见国家有关法律法规,当本声明与国家有关法律法规冲突时,以国家法律法规为准。
  • 本软件相关声明版权及其修改权、更新权和最终解释权均属软件作者所有。