如何向K8s,Docker-Compose注入镜像Tag
最近在做基于容器的CI/CD, 一个朴素的自动部署的思路是:
- 从Git Repo打出git tag,作为镜像Tag
- ssh远程登录到部署机器
- 向部署环境注入镜像Tag,拉取镜像,重新部署
下面分享我是如何在K8s、docker-compose中注入镜像TAG(持续部署)?
k8s
熟悉k8s的同学知道, K8s有一个强大的原生配置管理工具:Kustomize
工具。
Kustomize 以一种无模板的方式来定制应用程序配置,从而简化了现有应用程序的使用。现在kustomize已经以
apply -k
的方式内置进kubectl。
这里可以利用Kustomize的edit
命令修改定义在Kustomization.yaml
中的镜像TAG:
下面是一个简单的Kustomization.yaml文件:
kind: Kustomization namespace: wd resources: - ../base images: - name: hub.docker.com/eap/website //原镜像名 newName: hub.docker.com/eap/website newTag: v1.0.7-hotfix5 // 持续被修改的Tag
做自动部署时,一般由CI给部署脚本导入此次Git Tag,作为镜像Tag。
#!/bin/sh cd /home/wd-deploy/localdeploy/wd/overlays/ kustomize edit set image hub.docker.com/eap/website=hub.docker.com/eap/website:${TAG} kustomize build . | kubectl apply -f -
以上部署脚本: 进入Kustomization.yaml目录,向Kustomization.yaml文件注入新的镜像Tag,构建并应用新的配置。
docker-compose
Docker平台就没有那么好的工具,可明文让你修改镜像配置。
我们可采用shell脚本
来曲线修改镜像配置:
假如你有一个简单的docker-compose.yml文件:
version: '3' services: app: image: username/app:d7s8f12 ports: - 80:80
通过shell脚本修改字符串app:后面的镜像Tag,达到注入Tag的目的
sed -E -i'' "s/(.*app:).*/\1$COMMIT/" 'docker-compose.yml'
同样,在做自动部署时,由CI给以上脚本导入此次Git Tag,作为镜像Tag。
#!/bin/sh cd /home/wd-deploy/app/ sed -E -i'' "s/(.*app:).*/\1$COMMIT/" 'docker-compose.yml' docker-compose pull app && docker-compose up -d
以上部署脚本: 进入docker-compose.yml目录,向Compose文件注入新的镜像Tag,拉取镜像并应用新的配置。
结束语
本文记录了向K8s, Docker-Compose平台注入镜像Tag的方式, 为啥要专题讲这个呢? 因为注入Tag是自动部署的必经过程。
本文只是一个粗浅的、朴素的注入思路(Devops生态有许多组件可以完成该项动作), 也欢迎大家多多留言,带我上路。
本文来自博客园,作者:{有态度的马甲},转载请注明原文链接:https://www.cnblogs.com/JulianHuang/p/14317948.html
欢迎关注我的原创技术、职场公众号, 加好友谈天说地,一起进化
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?