Skip to content

Latest commit

 

History

History
 
 

helm

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

BiliBili Tool

BiliBiliTool 是一个自动执行任务的工具,当我们忘记做某项任务时,它会像一个贴心小助手,按照我们预先吩咐它的命令,在指定频率、时间范围内帮助我们完成计划的任务。

Overview of BiliBili Tool

TL;DR

在集群中通过本地代码直接部署

$ git clone https://github.com/RayWangQvQ/BiliBiliToolPro.git
$ cd ${local_code_repo}/helm/bilibili-tool
$ vim values.yaml # provides your cookie and cron
$ helm install <my_release_name> .

在集群中通过chart部署

$ git clone https://github.com/RayWangQvQ/BiliBiliToolPro.git
$ cd ${local_code_repo}/helm/bilibili-tool
$ helm cm-push . <your_chart_repo>

Then on the cluster control plane

$ mkdir /tmp/bilibili-tool && cd /tmp/bilibili-tool
$ helm repo add <your_chart_repo> <your_chart_repo_url>
$ helm update && helm pull <your_chart_repo>/bilibili-tool
$ tar -zvxf <tar> -C . && cd <chart_name>
$ vim values.yaml # provides your cookie and cron
$ helm install <my_release_name> .

Introduction

这个chart通过HelmKubernetes集群上拉起一个BiliBiliToolProdeployment

Prerequisites

  • Kubernetes
  • Helm

或者

  • Kind
  • Helm

安装Chart

安装Chart并命名为 my-release:

$ helm repo add my-repo <my_chart_repo>
$ helm install my-release my-repo/bilibili-tool(:0.2.1)

上述命令需要用户在values.yaml里提供cookie等必须信息 Parameters 部分列出了所有可供自定义的值

Tip: helm list 可以列出当前已经列出的所有的release

卸载 Chart

卸载 my-release deployment:

$ helm delete my-release

上述命令卸载掉所有的release相关资源

Parameters

Name Description Value Required
replicaCount Deployment Relicas Count 1 true
image.repository Global Dockevr registry zai7lou/bilibili_tool_pro true
image.tag Image Tag 0.2.1 true
image.pullPolicy Image Pull Policy IfNotPresent true
imagePullSecrets Image Pull Secrets [] false
nameOverride Deployment name in the Chart "" false
fullnameOverride Release name when set "" false
resources.limits The resources limits for the BiliBili Tool containers {} true
resources.limits.memory The limited memory for the BiliBili Tool containers 180Mi true
resources.limits.cpu The limited cpu for the BiliBili Tool containers 100m true
resources.requests The resources requests for the BiliBili Tool containers {} true
resources.requests.memory The requested memory for the BiliBili Tool containers 180Mi true
resources.requests.cpu The requested cpu for the BiliBili Tool containers 100m true
affinity Affinity for pod assignment {} false
nodeSelector Node labels for pod assignment {} false
tolerations Tolerations for pod assignment [] false
env Environment variables for the BiliBili Tool container, Ray_BiliBiliCookies__1 and Ray_DailyTaskConfig__Cron are required, others vars pls take a look at supported envvars [] true
volumes.enabled Enable persistent log volume for BiliBili Tool or not "false" true
volumes.path The host path mounted into pod "/tmp/Logs" false
volumes.name The volume name "bili-tool-vol" false
podAnnotations The annotations for the BiliBili Tool pod {} false

可以用指定helm install命令行参数 --set key=value[,key=value], 比如

$ helm install my-release \
  --set  \
    relicas=1

也可以通过指定一个YAML格式的values文件来配置以上参数,比如

$ helm install my-release -f values.yaml my_chart_repo/bilibili-tool

Tip: 你可以使用默认的 values.yaml进行配置

当想更新一些变量时,可以通过指定参数或者直接修改YAML的values文件进行更新

$ helm upgrade my-release my_chart_repo/bilibili-tool <-f values> or <--set-file ...> 

[Optional]本地Cluster运行

通过安装kind工具在本地运行一个Kubernetes Cluster

Prerequisites

go 1.17+ and Docker installed

$ go install sigs.k8s.io/[email protected] && kind create cluster <--config kind_config_file>
$ cat <kind_config_file>
$ kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
- role: worker 
$ EOF

at least one worker node otherwise you have to provides tolerations in the values.yaml to schedule on master node