docker 篇

简单描述下,有时候真的要熟练,否者上了生产真的不知所措。

背景:有个项目上线了,依赖的项目没有上线,因此需要紧急发布,发现:打包环境有问题,第一、架构不一致,第二、环境隔离导出镜像包慢,第三、本地打包dockerfile不一致导致加载配置有问题。

面对以上问题,我们需要知道的事

打包机器写死打包 amd,目标机器arm64,从而折腾了不少时间。

侧面说明对架构变换打包不熟练,对go 程序来说,打包docker镜像,只需要修改go build相关参数即可,具体为: GOARCH=arm64 GOOS=linux go build -ldflags="-s -w" 源文件 目标文件

在打包机器上生成的镜像需要导出,只需要知道镜像名,然后命令如下

bash 复制代码
docker save -o xxx.tar

当然可以对xxx.tar进行压缩(如果包比较大的话)
gzip xxx.tar

接着就是下载下来,由于部分公司会存在跳板机的情况,因此需要先下载到跳板机,然后才能通过跳板机来下载文件到本地。其过程如下

bash 复制代码
跳板机执行
scp user@ip:/ddd/target.tar .

然后本地sftp到跳板机 sftp user@ip 会车输入密码

接着cd到跳板机相应目录,然后本机lcd到下载目录,直接get target.tar文件即可

拿到tar文件,需要把tar文件加载成docker镜像,以下命令

bash 复制代码
docker load -i target.tar

接着就是启动镜像容器

docker run -d --name xxx --restart=aways -v 本地目录:镜像目录 target/image

当然还有很多参数可以配置,这个就需要熟练度了。

当此时,如果容器起不来,怎么办?譬如加载配置失败

因此有可能你需要进去容器把配置放到相应目录(在你没有把目录映射出来的时候)

bash 复制代码
即 docker exec -it 容器id /bin/bash 走不通,因为容器没起来,所以你可以通过镜像来进入修改


docker run -it --entrypoint /bin/bash 镜像

即可进入容器修改。

当然啦针对docker build编译不通架构镜像,我们可以通过

docker buildx build -t myimage:v1 --platform linux/arm64 .

来打包相应平台的包

上面其实涉及到的内容还算多吧,需要掌握一定的知识才能对当前遇到的问题做到心中有数,而心不乱。

相关推荐
刘某的Cloud几秒前
硬链接 和 软链接 区别
运维·系统·硬链接·软链接
jiayong234 分钟前
harness 与 hermes-agent 扩展性、安全与运维
运维·人工智能·安全·ai·架构·智能体·harness
STDD19 分钟前
Linux Namespace:容器隔离的底层原理,PID、网络、挂载隔离实战
linux·运维·网络
todoitbo20 分钟前
一台 2C2G 服务器上的 KingbaseES 安装记录
运维·服务器·数据库·国产数据库
容器魔方21 分钟前
KubeEdge SIG AI: 基于KubeEdge-Ianvs的大模型联邦微调算法
大数据·人工智能·算法·云原生·容器·云计算
tianyuanwo28 分钟前
企业级容器镜像管理实践:基于JFrog Artifactory的私有镜像仓库搭建与配置指南
docker·云原生·registry
最后一支迷迭香30 分钟前
Mac使用docker下的两个冷知识
macos·docker·容器
Gong-Yu36 分钟前
MySQL数据库运维(1)
运维·数据库·mysql·慢查询
Yang961137 分钟前
宽频高精度!鼎讯信通 OM-T 台式频谱分析仪风电实验室专用
大数据·运维·网络
亚空间仓鼠39 分钟前
Docker容器化高可用架构部署方案(十八)
docker·容器·架构