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

相关推荐
篙芷8 小时前
k8s Service 暴露方式详解:ClusterIP、NodePort、LoadBalancer 与 Headless Service
云原生·容器·kubernetes
篙芷8 小时前
k8s节点绑定:nodeName与nodeSelector实战
linux·docker·kubernetes
aashuii8 小时前
k8s POD上RDMA网卡VF不生效问题
云原生·容器·kubernetes
weixin_46688 小时前
K8S-Ingress
云原生·容器·kubernetes
l1t8 小时前
wsl docker安装达梦数据库的过程
数据库·docker·容器·达梦
Wzx1980128 小时前
go聊天室项目docker部署
运维·docker·容器
weixin_466816 小时前
K8S-特殊容器
云原生·容器·kubernetes
半夏知半秋16 小时前
docker常用指令整理
运维·笔记·后端·学习·docker·容器
逆风水手17 小时前
Ansible自动化运维入门指南
linux·运维·自动化·ansible
天空属于哈夫克317 小时前
外部群公告的动态更新算法
自动化·企业微信·api·rpa