目录
一、实用情况
二、镜像生存到本机
1、检察已有的镜像文件
2、将镜像生存为当地文件
生存指令一
生存指令二
测试根据镜像ID生存镜像
三、载入当地镜像
载入指令一
载入指令二
载入通过镜像ID生存的当地镜像
四、批量生存和载入镜像脚本
批量生存镜像到当地脚本
批量载入镜像tar脚本
一、实用情况
一般我们下载Docker镜像会通过配置国内镜像源来加快下载,但是偶然候会有以下几种的需求:
- 装备不能联网,不能直接下载镜像,需要从其他装备下载镜像后拷贝到当前不能联网的装备上
- 装备上的镜像在私有堆栈中,无法进行下载,需要拷贝到当前装备
当遇到以上几种情况时,可参考以下操作(附镜像批量生存及批量导入脚本)
二、镜像生存到本机
1、检察已有的镜像文件
如下图所示,当前装备内的全部镜像
2、将镜像生存为当地文件
注意点:
- 生存的镜像必须为tar类型的文件
- 生存指令中如果使用的是镜像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指定版本)
分别实验指令一和指令二
乐成后生存到当地名为nginx_latest.tar和nginx_latest01.tar的文件
为测试“生存指令中如果使用的是镜像ID,导入tar文件时REPOSTITORY和TAG为none,需要使用该镜像的id重新设置镜像标签”而通过IMAGE ID生存的当地镜像,载入镜像时会单独测试
- docker save -o nginx_latest_byID.tar 89da1fb6dcb9
复制代码
三、载入当地镜像
我们有了当地的镜像文件,在需要的时候可以将生存好的当地镜像复制到所需装备上,使用docker load将当地生存的镜像再次导入docker中。
- #指令一
- docker load < nginx_latest.tar
复制代码 以下演示为对同一个镜像删除后进行恢复
- #指令二
- 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,写入以下内容:
- #!/bin/bash
-
-
- # 获取到 "image:tag" 格式的镜像名
- IMG_NAME=`docker images | grep -v TAG | awk '{print $1":"$2}'`
- # 如果原本镜像名中存在 "/" 是需要去掉的
- echo $IMG_NAME | awk '{gsub(/ /,"\n",$0)} {print $0}'
- # 定义镜像存放目录
- DIR="/data/docker/image_save"
- if [ ! -d "$DIR" ]; then
- echo -e "\033[34m${DIR}\033[0m 不存在"
- mkdir -p "$DIR"
- echo -e "\033[34m${DIR}\033[0m 已创建"
- else
- echo -e "\033[34m${DIR}\033[0m 已存在"
- fi
- echo ""
- for IMAGE in $IMG_NAME
- do
- echo -e "正在保存 \033[33m${IMAGE}\033[0m"
- SAVE_NAME=`echo $IMAGE | awk -F: '{print $1"_"$2}' | sed 's/\//_/g'`
- docker save $IMAGE -o ${DIR}/${SAVE_NAME}.tar
- echo -e "已保存到 \033[34m${DIR}/\033[31m${SAVE_NAME}.tar\033[0m"
- echo ""
- done
复制代码 新增的脚本并无实验权限,当前测试直接设置权限给777
- #修改文件权限为简单粗暴的所有者、所属组和其他人都有读写执行权限
- chmod 777 save_images.sh
复制代码 实验效果演示:
新建load_images.sh,其他操作同save_image.sh的操作
- #!/bin/bash
-
- # 在此处填写镜像文件的保存目录
- IMAGE_DIR="/data/docker/image_save"
-
- for IMAGE in `ls $IMAGE_DIR`
- do
- echo -e "正在导入镜像 \033[33m$IMAGE\033[0m"
- docker load -i ${IMAGE_DIR}/${IMAGE}
- echo -e "已成功导入镜像 \033[33m$IMAGE\033[0m"
- echo ""
- done
复制代码 实验效果演示:
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |