前言
本文为链接: 云效流水线+k8s半自动部署java(保姆级)的补充,本文起初的目的是为了补充完善k8s流水线的全自动化部署,但是也适用于k8s的一键重启,因为使用k8s的web页面容易出现漏点的情况,因此也可以把代码保存为shell脚本,同样可以实现一键重启。关于流水线的搭建和k8s的搭建请移步上方的链接,本文主要作为差缺补漏。
一、云效
云效这一步较为简单,进入项目后,点击新的任务-部署-主机部署
因为只需要执行k8s的命令即可,因此无需下载制品,因此把下载制品勾选掉
主机组可以参考 云效+小皮(nginx) vue项目部署(保姆级)内的主机组创建
创建完成之后就可以在这边选择到,最终界面应当如上图所示,脚本的话,根据自己的情况调整下方的代码即可。
二、k8s
下方的代码需要修改的地方仅有下面的
NAMESPACE
EXCLUDE_DEPLOYMENTS
两个变量
第一个变量需要填写的为容器的命名空间
当处于这个界面的时候,下方英文名称即为NAMESPACE 的值,切记是名称不是别名,不要填写的时候把括号里的值也填写上,因为名称是唯一值,即使是不同的环境,也不允许使用同一的名称。
EXCLUDE_DEPLOYMENTS 是需要填写不需要重启的服务名称,因为有时候像是mysql,xxljob这样的中间件和数据库和nginx代理,因为是同一个项目都会塞到一起,这些服务一般是不需要重启的,因此需要规避掉这些的重启,此时需要填写第二个参数,并按照空格分隔开,此处是模糊匹配,即便是名称不完全重复,也可以匹配上。
如上图所示,因为项目中包含nginx,和xxljob,我的xxljob只填写xxl依旧可以匹配上排除掉。
修改好后填写到云效的部署脚本处即可。
三、代码
shell
# 定义命名空间
NAMESPACE="xxxx"
# 定义要排除的部署名称列表,用空格分隔不同的名称
EXCLUDE_DEPLOYMENTS="nginx mysql redis xxl"
#遍历查询所有pod,并排除上方需要排除的名称
DEPLOYMENT_NAMES=$(kubectl get deployments -n "$NAMESPACE" | while read line; do
should_include=true
for excluded in $EXCLUDE_DEPLOYMENTS; do
if [[ "$line" == *"$excluded"* ]]; then
should_include=false
break
fi
done
if $should_include; then
echo "$line" | awk '{print $1}'
fi
done | sed '1d')
# 循环遍历获取到的部署名称列表,对每个部署执行重启操作
for name in $DEPLOYMENT_NAMES
do
kubectl rollout restart deployment/"$name" -n "$NAMESPACE"
done