我有6个shell别名,用于在k8s名称空间和不同的k8s集群之间切换上下文。上下文在kube配置文件中设置。
别名的例子如下:
alias kc11='kubectl config use-context cluster1-namespace-1'
和我的问题是:
如果我运行helm升级命令,大约需要30分钟,在升级过程中切换k8s上下文是否可以不影响运行?
helm如何与k8s上下文一起工作?它是加载到运行时开始或之前的每一个简单的操作在头盔升级?
头盔升级命令如下:
helm upgrade my-app . --reuse-values --values values.yaml --timeout 1200s
如您所见,我没有添加-n参数来指定k8s的命名空间。
TL;DR:是的,你可以。
当您发出helm upgrade
命令时,所有相关舱单都被发送到控制平面。这几乎是瞬间发生的,发送完所有内容后,您这边的所有工作都完成了。你可能会注意到,即使你在运行时中断helm
,最终所有相关的pod,服务等都会被创建。
您还可以自由切换当前上下文,并在安装资源时继续工作。
为了证明我的观点:
我配置了两个集群:
$ kubectl config get-contexts
CURRENT NAME
* cluster-1
istio
作为一个例子,我要安装superset
,因为我知道它需要一些时间来完成。
$ helm install superset superset/superset &
[1] 14291
&
将其发送到后台,所以我可以发出更多的命令,而helm做它的事情
现在,切换到另一个上下文
$ kubectl config use-context istio
Switched to context "istio".
helm仍在后台运行
$ jobs
[1]+ Running helm install superset superset/superset &
一段时间后,helm完成了它的工作,并抛出关于成功部署的信息
NAME: superset
LAST DEPLOYED: Thu Aug 26 13:55:03 2021
NAMESPACE: default
STATUS: deployed
REVISION: 1
TEST SUITE: None
NOTES:
1. Get the application URL by running these commands:
echo "Visit http://127.0.0.1:8088 to use your application"
kubectl port-forward service/superset 8088:8088 --namespace default
[1]+ Done helm install superset superset/superset
切换回原始上下文,并检查是否所有pod都已创建
$ kubectl config use-context cluster-1
Switched to context "cluster-1".
$ kubectl get pods
NAME READY STATUS RESTARTS AGE
superset-9cb794755-jwjls 1/1 Running 0 90s
superset-init-db-ndhlt 0/1 Completed 0 89s
superset-postgresql-0 1/1 Running 0 89s
superset-redis-master-0 1/1 Running 0 89s
superset-worker-66bb97f7ff-4ptq5 1/1 Running 0 90s
可以看到,在cluster-1
上下文中,在default
名称空间中,所有资源都被正确部署了(因为我没有指定不同的名称)。