ToB企服应用市场:ToB评测及商务社交产业平台

标题: Docker生存镜像到当地并载入当地镜像文件 [打印本页]

作者: 缠丝猫    时间: 2024-6-25 23:52
标题: Docker生存镜像到当地并载入当地镜像文件
目录
一、实用情况
二、镜像生存到本机 
1、检察已有的镜像文件
2、将镜像生存为当地文件
生存指令一
生存指令二
测试根据镜像ID生存镜像
三、载入当地镜像
载入指令一
载入指令二
载入通过镜像ID生存的当地镜像
四、批量生存和载入镜像脚本
批量生存镜像到当地脚本
批量载入镜像tar脚本


一、实用情况

   一般我们下载Docker镜像会通过配置国内镜像源来加快下载,但是偶然候会有以下几种的需求:
  
  当遇到以上几种情况时,可参考以下操作(附镜像批量生存及批量导入脚本)
  
二、镜像生存到本机 

1、检察已有的镜像文件

  1. docker images
复制代码
 如下图所示,当前装备内的全部镜像


2、将镜像生存为当地文件

      注意点:
    
  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,导入tar文件时REPOSTITORY和TAG为none,需要使用该镜像的id重新设置镜像标签”而通过IMAGE ID生存的当地镜像,载入镜像时会单独测试
  1. 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
复制代码
指令二基本操作同指令一、



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


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

批量生存和载入镜像脚本下载
https://download.csdn.net/download/DreamEhome/88146817

新建save_images.sh,写入以下内容:
  1. #!/bin/bash
  2.   
  3.   
  4. # 获取到 "image:tag" 格式的镜像名
  5. IMG_NAME=`docker images | grep -v TAG | awk '{print $1":"$2}'`
  6. # 如果原本镜像名中存在 "/" 是需要去掉的
  7. echo $IMG_NAME | awk '{gsub(/ /,"\n",$0)} {print $0}'
  8. # 定义镜像存放目录
  9. DIR="/data/docker/image_save"
  10. if [ ! -d "$DIR" ]; then
  11.   echo -e "\033[34m${DIR}\033[0m 不存在"
  12.   mkdir -p "$DIR"
  13.   echo -e "\033[34m${DIR}\033[0m 已创建"
  14. else
  15.   echo -e "\033[34m${DIR}\033[0m 已存在"
  16. fi
  17. echo ""
  18. for IMAGE in $IMG_NAME
  19. do
  20.   echo -e "正在保存 \033[33m${IMAGE}\033[0m"
  21.   SAVE_NAME=`echo $IMAGE | awk -F: '{print $1"_"$2}' | sed 's/\//_/g'`
  22.   docker save $IMAGE -o ${DIR}/${SAVE_NAME}.tar
  23.   echo -e "已保存到 \033[34m${DIR}/\033[31m${SAVE_NAME}.tar\033[0m"
  24.   echo ""
  25. done
复制代码
新增的脚本并无实验权限,当前测试直接设置权限给777
  1. #修改文件权限为简单粗暴的所有者、所属组和其他人都有读写执行权限
  2. chmod 777 save_images.sh
复制代码
 实验效果演示:




新建load_images.sh,其他操作同save_image.sh的操作
  1. #!/bin/bash
  2.   
  3. # 在此处填写镜像文件的保存目录
  4. IMAGE_DIR="/data/docker/image_save"
  5.   
  6. for IMAGE in `ls $IMAGE_DIR`
  7. do
  8.   echo -e "正在导入镜像 \033[33m$IMAGE\033[0m"
  9.   docker load -i ${IMAGE_DIR}/${IMAGE}
  10.   echo -e "已成功导入镜像 \033[33m$IMAGE\033[0m"
  11.   echo ""
  12. done
复制代码
实验效果演示:

 




免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4