Docker保存镜像到本地并载入本地镜像文件

╰半橙微兮° 2023-10-14 11:31 111阅读 0赞

目录

一、适用情况

二、镜像保存到本机

1、查看已有的镜像文件

2、将镜像保存为本地文件

保存指令一

保存指令二

测试根据镜像ID保存镜像

三、载入本地镜像

载入指令一

载入指令二

载入通过镜像ID保存的本地镜像

四、批量保存和载入镜像脚本

批量保存镜像到本地脚本

批量载入镜像tar脚本


一、适用情况

一般我们下载Docker镜像会通过配置国内镜像源来加速下载,但是有时候会有以下几种的需求:

  • 设备不能联网,不能直接下载镜像,需要从其他设备下载镜像后拷贝到当前不能联网的设备上
  • 设备上的镜像在私有仓库中,无法进行下载,需要拷贝到当前设备

当遇到以上几种情况时,可参考以下操作(附镜像批量保存及批量导入脚本)

二、镜像保存到本机

1、查看已有的镜像文件

  1. docker images

如下图所示,当前设备内的所有镜像

3b8241a7f9024070891ba857b3789931.png

2、将镜像保存为本地文件

注意点:

  1. 保存的镜像必须为tar类型的文件
  2. 保存指令中如果使用的是镜像ID,导入tar文件时REPOSTITORY和TAG为none,需要利用该镜像的id重新设置镜像标签;如果使用的是镜像名称则不会出现该问题。
  • 保存指令一

    指令一

    docker save -o /data/docker/nginx_latest.tar nginx

#指令一

docker save -o

/data/docker/nginx_latest.tar 保存文件名,必须为tar类型,可加保存路径

nginx 要保存的镜像(名称或ID均可,名称后可加TAG指定版本)

  • 保存指令二

    指令二

    docker save nginx > nginx_latest01.tar

#指令二

docker save

nginx 要保存的镜像(名称或ID均可)

>

nginx_latest01.tar 要保存的镜像(名称或ID均可,名称后可加TAG指定版本)

分别执行指令一和指令二

871425b794af4608bbb3ed317cafbb40.png

成功后保存到本地名为nginx_latest.tar和nginx_latest01.tar的文件

  • 测试根据镜像ID保存镜像

为测试“保存指令中如果使用的是镜像ID,导入tar文件时REPOSTITORY和TAG为none,需要利用该镜像的id重新设置镜像标签”而通过IMAGE ID保存的本地镜像,载入镜像时会单独测试

  1. docker save -o nginx_latest_byID.tar 89da1fb6dcb9

29c347a2f9a54ec3a380a59485a3db34.png

三、载入本地镜像

我们有了本地的镜像文件,在需要的时候可以将保存好的本地镜像复制到所需设备上,使用docker load将本地保存的镜像再次导入docker中。

  • 载入指令一

    指令一

    docker load < nginx_latest.tar

以下演示为对同一个镜像删除后进行恢复

d5e7f9002ac541cba82e43481981c6cc.png

  • 载入指令二

    指令二

    docker load —input nginx_latest.tar

指令二基本操作同指令一、

b2e1a6e59e0742a99ab32fb13eb8eab4.png

  • 载入通过镜像ID保存的本地镜像

通过IMAGE ID保存的本地镜像文件为nginx_latest_byID.tar,载入后REPOSTITORY和TAG为none,以下为load测试

afcec6310aad4a52a8d50f62ab4d243b.png

四、批量保存和载入镜像脚本

批量保存和载入镜像脚本下载icon-default.png?t=N6B9https://download.csdn.net/download/DreamEhome/88146817

  • 批量保存镜像到本地脚本

新建save_images.sh,写入以下内容:

  1. #!/bin/bash
  2. # 获取到 "image:tag" 格式的镜像名
  3. IMG_NAME=`docker images | grep -v TAG | awk '{print $1":"$2}'`
  4. # 如果原本镜像名中存在 "/" 是需要去掉的
  5. echo $IMG_NAME | awk '{gsub(/ /,"\n",$0)} {print $0}'
  6. # 定义镜像存放目录
  7. DIR="/data/docker/image_save"
  8. if [ ! -d "$DIR" ]; then
  9. echo -e "\033[34m${DIR}\033[0m 不存在"
  10. mkdir -p "$DIR"
  11. echo -e "\033[34m${DIR}\033[0m 已创建"
  12. else
  13. echo -e "\033[34m${DIR}\033[0m 已存在"
  14. fi
  15. echo ""
  16. for IMAGE in $IMG_NAME
  17. do
  18. echo -e "正在保存 \033[33m${IMAGE}\033[0m"
  19. SAVE_NAME=`echo $IMAGE | awk -F: '{print $1"_"$2}' | sed 's/\//_/g'`
  20. docker save $IMAGE -o ${DIR}/${SAVE_NAME}.tar
  21. echo -e "已保存到 \033[34m${DIR}/\033[31m${SAVE_NAME}.tar\033[0m"
  22. echo ""
  23. done

新增的脚本并无执行权限,当前测试直接设置权限给777

  1. #修改文件权限为简单粗暴的所有者、所属组和其他人都有读写执行权限
  2. chmod 777 save_images.sh

执行效果演示:

bd5c1a2669984bfc8693b521e7c8ec06.png

  • 批量载入镜像tar脚本

新建load_images.sh,其他操作同save_image.sh的操作

  1. #!/bin/bash
  2. # 在此处填写镜像文件的保存目录
  3. IMAGE_DIR="/data/docker/image_save"
  4. for IMAGE in `ls $IMAGE_DIR`
  5. do
  6. echo -e "正在导入镜像 \033[33m$IMAGE\033[0m"
  7. docker load -i ${IMAGE_DIR}/${IMAGE}
  8. echo -e "已成功导入镜像 \033[33m$IMAGE\033[0m"
  9. echo ""
  10. done

执行效果演示:

196a5897186c4c06ac67d757bafad57c.png

ca9e23ab59434f6da82d9409d5643b3a.png

发表评论

表情:
评论列表 (有 0 条评论,111人围观)

还没有评论,来说两句吧...

相关阅读