docker 镜像导出命令(支持所有镜像导出为独立的包)

Docker 镜像导出命令

网上搜到全部镜像导出为一个包的命令,没有搜到每个独立打包的命令,自己写了一下。

导出文件名为 : 镜像标签 + 创建时间 + 系统 + 架构 + 文件大小 + sha + 替换非法字符,自用足够了。

sh 复制代码
# 1. 替换日期 : `(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):(\d{2})` -->  `\1\2\3T\4\5\6` # 匹配到日期格式后重新连接 # sed 不支持 `\d`
# 2. 截取ID   : `sha256:(\w{10})\w{54}` --> `\1` # 64位拆分为前10位与后54位,仅保留前10位即可
# 3. 去除无用字符 : `[|]` --> ``  # 去除包裹镜像名称的`[]`符号
# 4. 文件名合法化 : `/:*?<>|\"` --> `_`  # 替换掉非法字符

# 初始化格式字符串,之后再使用每个语句
$ IMAGES_FORMAT="{{.Repository}}:{{.Tag}}"; \
  INSPECT_FORMAT="{{.RepoTags}}_{{.Created}}_{{.Os}}-{{.Architecture}}_{{.Size}}_{{.ID}}.tar"; \
  REGEX_TIME="s#\([0-9]\{4\}\)-\([0-9]\{2\}\)-\([0-9T]\{5\}\):\([0-9]\{2\}\):\([0-9]\{2\}\)#\1\2\3\4\5#g;"; \
  REGEX_ID="s#sha256:\(\w\{10\}\)\w\{54\}#\1#g;"; \
  REGEX_REMOVE="s#\[\|\]##g;"; \
  REGEX_REPLACE="s#[/:*?<>|\\\\\"]#_#g";

# 显示单个镜像名称 # "hello-world:latest"
$ IMAGE="hello-world"; docker images --format ${IMAGES_FORMAT} ${IMAGE};
# 显示单个镜像原始文件名 # "[hello-world:latest]_2023-05-02T16:49:27Z_linux-amd64_13256_sha256:d2c94e258dcb3c5ac2798d32e1249e42ef01cba4841c2234249495f87264ac5a.tar"
$ IMAGE="hello-world"; docker inspect --format ${INSPECT_FORMAT} ${IMAGE};
# 显示单个镜像导出语句   # "# ==== docker save hello-world -o hello-world_latest_20230502T164927Z_linux-amd64_13256_d2c94e258d.tar"
$ IMAGE="hello-world"; \
  FROM=$(docker inspect --format ${INSPECT_FORMAT} ${IMAGE}); \
  FILE=$(echo ${FROM} | sed "${REGEX_TIME} ${REGEX_ID} ${REGEX_REMOVE} ${REGEX_REPLACE}"); \
  echo \# ==== docker save ${IMAGE} -o ${FILE};
# 显示所有镜像的导出语句
$ echo \# ==== IMAGES LIST COUNT : $(docker images -q | wc -l); \
  for IMAGE in $(docker images --format ${IMAGES_FORMAT} | sort); \
  do \
    FROM=$(docker inspect --format ${INSPECT_FORMAT} ${IMAGE}); \
    FILE=$(echo ${FROM} | sed "${REGEX_TIME} ${REGEX_ID} ${REGEX_REMOVE} ${REGEX_REPLACE}"); \
    echo \# ==== docker save ${IMAGE} -o ${FILE}; \
  done
# 执行每个镜像导出为单个文件 # docker save each images to each files.
$ echo \# ==== IMAGES LIST COUNT : $(docker images -q | wc -l); \
  for IMAGE in $(docker images --format ${IMAGES_FORMAT} | sort); \
  do \
    FROM=$(docker inspect --format ${INSPECT_FORMAT} ${IMAGE}); \
    FILE=$(echo ${FROM} | sed "${REGEX_TIME} ${REGEX_ID} ${REGEX_REMOVE} ${REGEX_REPLACE}"); \
    echo \# ==== docker save ${IMAGE} -o ${FILE}; \
    docker save ${IMAGE} -o ${FILE}; \
  done
  • 其他命令
sh 复制代码
# 以下每行命令均独立

# 导入镜像
docker load -i ${NAME}.tar
docker load <  ${NAME}.tar

# 导出一个镜像到一个文件内
docker save -o ${NAME}.tar ${IMAGE_NAME}:{IMAGE_TAG}
docker save ${IMAGE_NAME}:{IMAGE_TAG} > ${NAME}.tar
# 导出多个镜像到一个文件内
docker save -o ${NAME}.tar ${IMAGE1_NAME}:{IMAGE1_TAG} ${IMAGE2_NAME}:{IMAGE2_TAG}

# 显示镜像列表 # 格式 ${IMAGE_NAME}:{IMAGE_TAG}
IMAGES=$(docker images --format '{{.Repository}}:{{.Tag}}'); for element in ${IMAGES[@]}; do echo "${element}"; done
docker images | sed '1d' | awk '{print $1 ":" $2 }'
# 显示镜像列表 # 格式 ${IMAGE_ID} # 显示全部镜像的 ID
docker images -q

# 导出全部镜像到一个文件内
docker save $(docker images --format '{{.Repository}}:{{.Tag}}') -o ${NAME}.tar
# docker save $(docker images | sed '1d' | awk '{print $1 ":" $2 }') -o ${NAME}.tar
# docker save $(docker images -q) -o ${NAME}.tar
相关推荐
搬码临时工8 分钟前
如何把本地服务器变成公网服务器?内网ip网址转换到外网连接访问
运维·服务器·网络·tcp/ip·智能路由器·远程工作·访问公司内网
容器魔方10 分钟前
KubeCon 抢鲜 | Kmesh与你共创高性能流量治理更优方案
云原生·容器·云计算
vortex513 分钟前
探索 Shell:选择适合你的命令行利器 bash, zsh, fish, dash, sh...
linux·开发语言·bash·shell·dash
Guheyunyi1 小时前
监测预警系统重塑隧道安全新范式
大数据·运维·人工智能·科技·安全
杰哥技术分享1 小时前
在 CentOS 上安装 Docker 和 Docker Compose 并配置使用国内镜像源
linux·docker·centos
知更鸟呆呆1 小时前
【Linux操作系统】基础开发工具(yum、vim、gcc/g++)
linux·运维·vim
Gold Steps.2 小时前
Docker容器部署elasticsearch8.*与Kibana8.*版本使用filebeat采集日志
运维·docker·云原生·es
m0_637146932 小时前
C语言基础面试问答
运维·服务器
ricky_fan3 小时前
window下配置ssh免密登录服务器
运维·服务器·ssh
地衣君3 小时前
Ubuntu 配置使用 zsh + 插件配置 + oh-my-zsh 美化过程
linux·运维·ubuntu