K8S命令部署后端(流水线全自动化部署)

前言

本文为链接: 云效流水线+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

相关推荐
晨旭缘1 分钟前
kubectl、kubelet、kubeadm命令详解
docker·kubernetes·kubelet
janeysj3 分钟前
docker-proxy实现原理
运维·docker·容器
小夏子_riotous8 分钟前
Docker学习路径——5、容器数据卷
linux·运维·服务器·学习·docker·容器·云计算
wydd99_lll12 小时前
docker特权模式下逃逸
运维·docker·容器
薛定谔的猫36912 小时前
探索 MCP 协议:构建跨平台的 Agent 自动化生态
ai·自动化·agent·技术趋势·mcp
mseaspring13 小时前
一款用于监控跨多台主机 Docker 容器的实时终端
运维·docker·容器
heimeiyingwang14 小时前
【架构实战】Kubernetes日志收集:EFK/Loki架构
容器·架构·kubernetes
qq_4523962315 小时前
【工程实战】第十篇:性能监控集成 —— 自动化脚本的“副产品”:不仅仅是功能测试
python·功能测试·自动化
星座52816 小时前
科研效率革命:基于Hermes Agent的Meta分析自动化工作流——涵盖随机效应模型、亚组分析与Egger检验
自动化·meta分析·hermes agent
SPC的存折17 小时前
6、Docker常用配置
运维·docker·容器