当前位置:   article > 正文

Docker保存镜像到本地并载入本地镜像文件_如何将docker镜像放在系统中

如何将docker镜像放在系统中

目录

一、适用情况

二、镜像保存到本机 

1、查看已有的镜像文件

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

保存指令一

保存指令二

测试根据镜像ID保存镜像

三、载入本地镜像

载入指令一

载入指令二

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

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

批量保存镜像到本地脚本

批量载入镜像tar脚本


一、适用情况

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

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

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

二、镜像保存到本机 

1、查看已有的镜像文件

docker images

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

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

   注意点:

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

  1. #指令一
  2. docker save -o /data/docker/nginx_latest.tar nginx

#指令一

docker save -o

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

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

  • 保存指令二

  1. #指令二
  2. docker save nginx > nginx_latest01.tar

#指令二

docker save

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

        >

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

 分别执行指令一和指令二

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

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

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

docker save -o nginx_latest_byID.tar 89da1fb6dcb9

三、载入本地镜像

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

  • 载入指令一

  1. #指令一
  2. docker load < nginx_latest.tar

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

  • 载入指令二

  1. #指令二
  2. docker load --input nginx_latest.tar

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

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

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

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

批量保存和载入镜像脚本下载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

 执行效果演示:

  • 批量载入镜像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

执行效果演示:

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/81830
推荐阅读
相关标签
  

闽ICP备14008679号