Skip to content

Latest commit

 

History

History
210 lines (134 loc) · 6.83 KB

File metadata and controls

210 lines (134 loc) · 6.83 KB

在青龙中运行

原理是,利用青龙的拉库命令,拉取本仓库源码,自动添加cron定时任务,然后在青龙容器中安装dotnet环境或bilitool的二进制包,定时运行相应的Task。

开始前,请先确保你的青龙面板是运行正常的。

1. 步骤

1.1. 登录青龙面板并修改配置

青龙面板,配置文件页。

修改 RepoFileExtensions="js py"RepoFileExtensions="js py sh"

保存配置。

1.2. 在青龙面板中添加拉库定时任务

两种方式,任选其一即可:

1.2.1. 方式一:订阅管理

名称:Bilibili
类型:公开仓库
链接:https://github.com/RayWangQvQ/BiliBiliToolPro.git
定时类型:crontab
定时规则:2 2 28 * *
白名单:bili_task_.+\.sh
文件后缀:sh

没提到的不要动。

保存后,点击运行按钮,运行拉库。

1.2.2. 方式二:定时任务拉库

青龙面板,定时任务页,右上角添加任务,填入以下信息:

名称:拉取Bili库
命令:ql repo https://github.com/RayWangQvQ/BiliBiliToolPro.git "bili_task_"
定时规则:2 2 28 * *

点击确定。

保存成功后,找到该定时任务,点击运行按钮,运行拉库。

1.3. 检查定时任务

如果正常,拉库成功后,会自动添加bilibili相关的task任务。

qinglong-tasks.png

1.4. 配置青龙Client Secret(可选)

扫码登录Bili后,需要有权限向青龙的环境变量中持久化Cookie,所以需要添加一个鉴权。

青龙官方说明:https://qinglong.online/api/preparation

1.4.1. 新建 Application

青龙 -> 系统设置 -> 应用设置,点击新建。

qinglong-application

1.4.2. 密钥配置到环境变量

将上面2个值添加到环境变量中即可。

Name分别为:

  • Ray_QingLongConfig__ClientId
  • Ray_QingLongConfig__ClientSecret

qinglong-app-env

1.5. Bili登录

在青龙定时任务中,点击运行bili扫码登录任务,查看运行日志,扫描日志中的二维码进行登录。 qinglong-login.png

登录成功后,如果已配置了上述的Application,会将cookie保存到青龙的环境变量中:

qinglong-env.png

如果未配置Application,会打印出cookie,请手动自己到环境变量中添加。

首次运行会自动安装环境,时间可能长一点,之后就不需要重复安装了。

2. 先行版

青龙拉库时可以指定分支,develop分支的代码会超前于默认的main分支,包含当前正在开发的新功能。

想提前体验新功能,或想要Bug能快速得到解决的朋友,可以尝试切换先行版,但同时也意味着稳定性会相应降低(其实可以忽略不计~🤨)。

分支:develop
白名单:bili_dev_task_.+\.sh

其他选项同上。

3. GitHub加速

拉库时,如果服务器在国内,访问GitHub速度慢,可在仓库地址前加上加速代理进行加速。

如:

https://github.moeyy.xyz/https://github.com/RayWangQvQ/BiliBiliToolPro.git
https://gh-proxy.com/https://github.com/RayWangQvQ/BiliBiliToolPro.git
...

加速代理地址通常不能保证长期稳定,请自行查找使用。

4. 常见问题

4.1. 安装dotnet失败怎么办法

首先,青龙有两个版本的镜像:

  • alpine:whyour/qinglong:latest
  • debian:whyour/qinglong:debian

安装dotnet失败的情况,几乎全发生在alpine版上。。。

所以,如果你“执迷不悟”,就是一定要用alpine版,那请先通过日志自行排查,不行就根据微软官方文档,进入qinglong容器后,手动安装。

如果还不行,那么可以切换到基于bilitool的二进制包运行方式,该方式不需要安装dotnet,方式:

编辑青龙面板的配置文件,新增如下两行:

export BILI_MODE="bilitool" # bili运行模式,dotnet或bilitool
export BILI_GITHUB_PROXY="https://github.moeyy.xyz/" # 下载二进制包时使用的加速代理,不要的话则置空

qinglong-login.png

bilitool没有先行版的概念,因为只有main分支才会打包,更新会稍慢一点。

另外,alpine版的问题,我不建议来提交issue,因为已经大大超出本项目的scope了,建议可以去给alpine官方或微软的dotnet官方提交issue。

4.2. Couldn't find a valid ICU package installed on the system

如 #266 ,需要在青龙面板的环境变量添加如下环境变量:

名称:DOTNET_SYSTEM_GLOBALIZATION_INVARIANT
值:1

4.3. 提示文件不存在或路径异常,怎么排查

需要docker exec -it qinglong bash后,查看几个常用路径:

/ql
    /data
        /repo
    /scripts
    /shell
  • /ql/dada/repo目录下存储了拉库后,bilitool的源代码
  • /ql/scripts目录下存储了bilitool的定时运行脚本
  • /ql/shell目录下是青龙的基础脚本

请cd到相应目录,查看该目录下文件是否存在,状态是否正常。

4.4. The configured user limit (128) on the number of inotify instances has been reached

报错:

Asp.Net Core - The configured user limit (128) on the number of inotify instances has been reached

可以尝试添加如下环境变量解决:

DOTNET_USE_POLLING_FILE_WATCHER=1

添加后,对配置变更事件的监听,会从监听 Linux 系统的 inotify 事件,变成定时轮询。