Linux环境shell脚本:Docker部署服务_回滚策略_脚本设计

2024-06-09 00:58

本文主要是介绍Linux环境shell脚本:Docker部署服务_回滚策略_脚本设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:公司使用docker服务集成jenkins实现一键部署项目(分步骤:达到上线条件就合并代码打release分支的包,然后只是先生成镜像,然后再部署,这样做的好处:release版本的代码还可以经过一轮验证测试后才上线),假使在现网出现问题且不能及时有效定位并解决的情况下,需要支持版本回滚操作,release分支打包脚本流程如下:先删除对应服务的images文件,再重新build镜像并push到nexus私服,images则是最新的包(并未上线),并且nexus私服上也是最新的prod。如果部署上线后,需要回滚该如何操作?首先可以确定是,如果没有问题之后,才会合并master,所以上一个安全的服务分支是master,只需重走一遍由master分支构建服务build==>push到私服的过程,部署服务即可回滚!不然出现release分支合并到master就无法快速分离代码回滚。

那么现在需要针对这一现象,优化一下回滚策略,分析办法如下:

1、以往使用docker部署服务的经验来看,镜像通过版本号控制,每次升级服务携带的版本号不一样,所以当前版本需要回滚时,可以通过指定任意版本号回滚---此法最灵活,不用管上一个镜像的分支是哪个!

2、结合实际情况,可以先备份镜像,然后再恢复,并且启动即可。

命令使用如下:

启动容器:docker run -id --name=container_name server_name:tag_name查看容器:docker ps -a保存容器:docker commit container_name image_name # 这时的版本是latest压缩镜像:docker save -o image_name.tar image_name删除镜像:docker rmi image_name加载镜像:docker load -i image_name.tar

至此镜像文件又回来了,然后将它push到私服覆盖有问题的镜像即可重新拉取还原:docker push nexus.edaedu.net/server_name:tag_name

实际情况:部署服务的时候,执行脚本会一股脑的干掉容器、删除镜像,没有留下任何文件,那么为了更快捷的回滚服务,在clear之前先备份image即可,一旦需要回滚,仍旧先是clear,再从镜像压缩文件load即可。

再度思考:是备份镜像呢还是备份容器?

分析原因:镜像和容器是两个相互独立的步骤,有关联但是可以分开操作!例如:现网是先打好的镜像push到私服,这时线上运行的容器和将来运行的镜像服务内容是不一致的;如果这时候备份了镜像显然是错的(再构建release时先备份image又没错了),但是如果备份的是容器就没多大问题,例如容器有修改配置文件、或是修复过bug上传的最小class文件?是不是需要验证备份的容器是否包含了这些?

实际结果:测试环境是一键打包部署的,即不可能出现镜像和容器有偏差的地方,所以备份哪个,关系不是很大!

现网环境:建议备份容器,为什么?因为release版本可能需要合并多次,如此自动打包多次,也就被很多次,就算以日期标识,也会被无限覆盖,可能需要时间戳来区分比较合理(如果脚本备份没有其他标识,就只会产生一个备份文件)!

推荐使用版本号控制镜像发版!

nexus私服清理过期的镜像:nexus-cli,github地址

1、下载工具:wget https://s3.eu-west-2.amazonaws.com/nexus-cli/1.0.0-beta/linux/nexus-cli

2、授权:chmod +x nexus-cli

3、./nexus-cli configure 配置

[root@aliyun-sh-94 opt]# ./nexus-cli configure

Enter Nexus Host: 私服地址,如果是ip+portEnter Nexus Repository Name: 镜像仓库名Enter Nexus Username: 账号Enter Nexus Password: 密码

4、基本使用命令见github:

$ nexus-cli configure 配置$ nexus-cli image ls 列出镜像$ nexus-cli image tags -name mlabouardy/nginx 查看镜像下的所有tag$ nexus-cli image info -name mlabouardy/nginx -tag 1.2.0 查看镜像指定tag的详细信息$ nexus-cli image delete -name mlabouardy/nginx -tag 1.2.0 删除指定tag的镜像$ nexus-cli image delete -name mlabouardy/nginx -keep 4 保留最近4个镜像$ nexus-cli image size -name mlabouardy/nginx size不支持的参数

最重要的环节,脚本如何来设计呢?(修改原来的打包部署脚本即可)

前面已经分析了如何来备份以及备份哪个?首先要明确意图,我们是要回滚当前有bug的版本到上一个正常使用的版本?那么这种备份操作一个都不使用,上面也已经给出了清理私服的镜像操作,那么还是通过版本号来控制回滚操作!打包部署,我们一如既往,在jenkins中加一个string参数控制,将脚本原来默认的test标签通过这个参数控制,每次打包都迭代一个版本,例如从1.0开始,以此类推,直到5.0,那么再创建一个对应服务的回滚job,当需要回滚的时候,也是通过这个string参数进行版本的回滚,这样我们既不需要重新pull代码打包,只需要stop容器并rm容器即可,然后再从私服上拉取一个tag的版本进行启动即可。

#!/bin/bash
echo 'update before'
docker_name='服务名'
port=8100
# 判断容器是否存在
#sh /脚本路径/docker_clear.sh $docker_nameresult=`docker ps -a|grep ${docker_name}|awk '{print $1}'`
echo "result==>${result}"if [ ! -z "$result" ]
thenecho "clear none images now!"#docker ps -a|grep ${result} | awk '{print $1}' | xargs docker stop#docker ps -a|grep ${result} | awk '{print $1}' | xargs docker rmdocker stop ${result}docker rm  ${result}docker images|grep ${docker_name}|awk '{print $3}'|xargs docker rmi
elseecho "nothing clear!"
fidocker run -p $port:$port \--restart=always \--user 1000 \--name $docker_name \-v /etc/localtime:/etc/localtime:ro \--add-host 主机:127.0.0.1\--add-host mysql服务:127.0.0.1 \--add-host redis服务:127.0.0.1 \-v /var/logs:/var/logs \-e JAVA_OPTS="-Xms128m -Xmx128m -Xloggc:/日志路径/gc.log -XX:+PrintGCDetails -XX:+PrintGCDateStamps" \-e SPRING_PROFILES_ACTIVE="test" \-d 私服地址/$docker_name:$1
sleep 5s
docker logs --tail=all $docker_name

tips:linux环境下,字符串的截取,使用方法:

#!/usr/binstring="nexus_image_url/server_name"array=(${string }) # 这会生成一个以/符号分割的数组,表达式为:($string//pattern/ ) pattern是分割符,最后一个/后面有空格echo "array:${array[1]}" #linux下数组索引取值方法for var in ${array[@]}doecho $vardonesubstr=${string:17} # 这个方式有点笨,必须要数数从左边的多少个字符开始截取后面的内容echo "substr : ${substr}"

这篇关于Linux环境shell脚本:Docker部署服务_回滚策略_脚本设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043812

相关文章

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

TP-Link PDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务

《TP-LinkPDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务》近期,路由器制造巨头普联(TP-Link)在用户群体中引发了一系列重要变动,上个月,公司发出了一则通知,明确要求所... 路由器厂商普联(TP-Link)上个月发布公告要求所有用户必须完成实名认证后才能继续使用普联提供的 D

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll