docker高级应用之镜像打包与节点推送

本文介绍使用 Docker 构建 CaaS 平台的经验,重点在于代码自动化部署、镜像管理和集群更新效率提升。文章详细阐述了如何解决因节点增加导致的更新速度减慢问题,并提供实际操作步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目前我这里使用docker做caas平台,主要是解决:

1、运维沙箱环境测试;

2、研发半自动化代码部署与回滚;

3、集群化应用与auto scale。

目前这3点都实现,但在第2点与第3点联系的时候有个问题。在第2里,研发测试成功的代码会被打包为一个images,放入私有库,然后第3部集群更新的时候,会选择这个成功版本的镜像,但在更新中,由于每个节点都需要从私有库里获取镜像,这样节点越多更新越慢,所以为了解决这个问题,我这里在第二步研发打包image之后,会进行一下所有节点推送,这样在进行集群更新的时候,会很快了。

下面是我进行代码自动打包为镜像与镜像全节点推送的操作过程。

1、代码自动打包为镜像

主要是在容器所在宿主机里运行下面命令

docker commit --pause=false  container_name image_name:image_tag &>>/dev/null && docker push image_repo/image_name:image_tag &>>/dev/null && echo 0 || echo 1

上面只是操作的命令,实现操作我已经在程序里封装好了。

下面是web平台里的操作情况

wKioL1XtAofBndrVAAGjgOPROq4159.jpg

我想对容器test_update进行镜像打包,那么就点击Compress按钮输入具体描述就可以。

wKioL1XtA73zzq6SAACwAyg-YHA028.jpg

然后选择确定,等一会就会出现

wKioL1XtBBORtv1IAALscW8OnU8447.jpg可以看到右侧有个对话框,显示容器打包为镜像成功。

然后在去容器管理里查看具体信息

wKiom1XtAkCQicZrAAGnnHktexg252.jpg


可以看到镜像已经有了,在通过Info按钮查看具体信息

wKioL1XtBJHB9bv4AAGzC8DXpHk182.jpg

可以看到详情跟之前打包的一样。

2、进行镜像推送到所有节点

也是在镜像管理里,选择push按钮

wKiom1XtArWB9NxBAAGKDNzC6Fk018.jpg

选择推送就会在所有节点里同步镜像信息,其实也就是在所有节点运行docker pull命令

wKiom1XtAxyAdGLzAAOAFJNlrrc459.jpg可以通过左下角的firebug看到通过18.18秒就在所有节点里给361m的镜像同步完成。

之后这个进行就可以被集群环境或者其他环境给使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值