eggo/0009-add-spec-of-eggo-hook.patch

99 lines
4.6 KiB
Diff
Raw Permalink Normal View History

From 70113bd0d942f714abda2bb181386e7a041ee9cf Mon Sep 17 00:00:00 2001
From: haozi007 <liuhao27@huawei.com>
Date: Fri, 12 Nov 2021 09:49:35 +0800
Subject: [PATCH 09/12] add spec of eggo hook
Signed-off-by: haozi007 <liuhao27@huawei.com>
---
docs/hooks_of_eggo.md | 63 +++++++++++++++++++++++++++++++++++++++++++
docs/manual.md | 6 +++++
2 files changed, 69 insertions(+)
create mode 100644 docs/hooks_of_eggo.md
diff --git a/docs/hooks_of_eggo.md b/docs/hooks_of_eggo.md
new file mode 100644
index 0000000..92b9a38
--- /dev/null
+++ b/docs/hooks_of_eggo.md
@@ -0,0 +1,63 @@
+# eggo支持的hooks设计
+
+为了提供更好的灵活性eggo支持多种hooks主要分为如下几个场景
+
+- 集群生命周期管理的过程中针对特定角色的每个节点的hooks支持prehook和posthook两种
+ - 生命周期管理包括:集群创建、集群删除、节点加入、节点删除;
+ - 节点角色包括master、worker、etcd和loadbalance
+- 针对整个集群的hooks集群创建和删除的过程中只会在一个master节点上执行一次支持prehook和posthook两种
+
+## 配置hook方式
+
+### 命令行参数方式
+
+| 参数 | 支持的命令 | 说明 |
+| ----------------------------- | --------------------------- | ------------------------------------------------------------ |
+| --cluster-prehook=[dir/file] | deploy, cleanup | 设置集群创建/删除之前执行的hooks可以是一个脚本文件或者目录 |
+| --cluster-posthook=[dir/file] | deploy, cleanup | 设置集群创建/删除之后执行的hooks可以是一个脚本文件或者目录 |
+| --prehook=[dir/file],role | deploy, cleanup,join,delete | 集群创建/删除,节点加入/删除之前执行的hooks可以是脚本文件或者目录role设置执行脚本的节点角色 |
+| --posthook=[dir/file],role | deploy, cleanup,join,delete | 集群创建/删除,节点加入/删除之后执行的hooks可以是脚本文件或者目录role设置执行脚本的节点角色 |
+
+说明:
+
+- 脚本目录下的所有脚本都会被执行,而子目录中的脚本不会被执行;
+- 每个脚本的超时时间为60s
+
+### 配置文件参数方式
+
+在集群配置的addition字段中可以设置shell类型的文件
+
+- 支持prejoin、postjoin、precleanup和postcleanup等执行时机
+- 而且通过在master或者worker角色下配置设置hook执行的节点类型
+
+示例如下:
+
+```
+ addition: // 额外的安装包或二进制文件列表
+ master:
+ - name: prejoin.sh
+ type: shell // shell脚本
+ schedule: "prejoin" // 执行时间master节点加入集群前
+ TimeOut: "30s" // 脚本执行时间超时则被杀死未配置默认30s
+ worker:
+ - name: postjoin.sh
+ type: shell // shell脚本
+ schedule: "postjoin" // 执行时间worker节点加入集群后
+```
+
+## hook规范
+
+eggo会在hook执行时通过环境变量传递部分信息用于脚本执行。环境变量如下
+
+| key | value说明 |
+| ------------------------- | ------------------------------------------- |
+| EGGO_CLUSTER_ID | 集群ID |
+| EGGO_CLUSTER_API_ENDPOINT | 集群的API入口 |
+| EGGO_CLUSTER_CONFIG_DIR | 集群配置存放目录,默认/etc/kubernetes |
+| EGGO_NODE_IP | hook执行的节点IP |
+| EGGO_NODE_NAME | hook执行的节点name |
+| EGGO_NODE_ARCH | hook执行的节点架构 |
+| EGGO_NODE_ROLE | hook执行的节点角色 |
+| EGGO_HOOK_TYPE | hook的类型prehook或者posthook |
+| EGGO_OPERATOR | 当前的操作deploycleanupjoindelete。 |
+
diff --git a/docs/manual.md b/docs/manual.md
index a570d5c..05668ab 100644
--- a/docs/manual.md
+++ b/docs/manual.md
@@ -236,3 +236,9 @@ $ eggo -d delete --id k8s-cluster 192.168.0.5 192.168.0.6
* --id集群的id
* --type可以为master或者worker默认worker
* 192.168.0.5 需要删除的机器的IP地址列表或者名称列表注意第1个master节点不能删除
+
+## 规范说明
+
+### hook规范
+
+详情见[hooks spec](./hooks_of_eggo.md)
--
2.25.1