代码拉取完成,页面将自动刷新
同步操作将从 src-openEuler/eggo 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
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 | 当前的操作,deploy,cleanup,join,delete。 |
+
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
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。