Jenkins-自动化部署-通知

场景

使用jenkins部署,但有时不能立马部署,需要先通知相关人员,再部署,如果确实不能部署,可以留时间撤销。

方案

1.开始前我们添加,真正开始执行的等待时间;可供选择(Choice Parameter),先通知相关人员,如果这段时间不能部署,则取消任务

2.每个任务建议 在 Build Steps 中单独编写,并且都添加,成功或则失败的检查,如果失败直接阻止主要流程继续。参考如下

Jenkins 中 写 shell 命令执行失败,检测失败问题_jenkins 执行shell脚本 不生效-CSDN博客

3.发送内容:

我们这个分两步,第一步 发送:开始 重启服务器; 第二步发送:服务器重启成功

4.方式:

我们使用通讯软件提供的外部api(不同的通讯软件,应该都可以添加类似这种机器人接口), 比如给qq群添加 机器人等,这里使用 钉钉为例

外部调用例子

bash 复制代码
# DingDingToken Env 前面定义的参数名
curl --location "https://oapi.dingtalk.com/robot/send?access_token=${DingDingToken}" \
  --header 'Content-Type: application/json' \
  --data "{
  \"msgtype\":\"markdown\",
  \"markdown\":{
  	\"title\":\"服务器更新\",
  	\"text\":\"# ${Env} \n ${DeployTypeContent} **开始**\"
  }
}"

效果如下,模拟服务器重启

Note

1.建议前期先每个功能单独编写

2.总结公共的可选参数放在 Choice Parameter 或者其它类型

3.整合前面编写的功能,根据实际情况,一部分放在jenkins中,一部分通过 svn等加载进来

4.注意所有异常情况,防止服务因部署问题意外被杀等问题

5.根据时间情况配置每个自动化流程,比如磁盘容量问题,长期执行可能存在大量日志,可通过配置设置保存时间

相关推荐
libraG11 小时前
Jenkins打包问题
前端·npm·jenkins
JuiceFS11 小时前
从 MLPerf Storage v2.0 看 AI 训练中的存储性能与扩展能力
运维·后端
chen94517 小时前
mysql 3节点mgr集群部署
运维·后端
LH_R17 小时前
OneTerm开源堡垒机实战(三):功能扩展与效率提升
运维·后端·安全
dessler18 小时前
Hadoop HDFS-高可用集群部署
linux·运维·hdfs
少妇的美梦2 天前
logstash教程
运维
chen9452 天前
k8s集群部署vector日志采集器
运维
chen9452 天前
aws ec2部署harbor,使用s3存储
运维
東雪蓮☆2 天前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
qq_264220892 天前
LVS负载均衡群集和LVS+Keepalived群集
运维·负载均衡·lvs