ToB企服应用市场:ToB评测及商务社交产业平台
标题:
Docker生存镜像到当地并载入当地镜像文件
[打印本页]
作者:
缠丝猫
时间:
2024-6-25 23:52
标题:
Docker生存镜像到当地并载入当地镜像文件
目录
一、实用情况
二、镜像生存到本机
1、检察已有的镜像文件
2、将镜像生存为当地文件
生存指令一
生存指令二
测试根据镜像ID生存镜像
三、载入当地镜像
载入指令一
载入指令二
载入通过镜像ID生存的当地镜像
四、批量生存和载入镜像脚本
批量生存镜像到当地脚本
批量载入镜像tar脚本
一、实用情况
一般我们下载Docker镜像会通过配置国内镜像源来加快下载,但是偶然候会有以下几种的需求:
装备不能联网,不能直接下载镜像,需要从其他装备下载镜像后拷贝到当前不能联网的装备上
装备上的镜像在私有堆栈中,无法进行下载,需要拷贝到当前装备
当遇到以上几种情况时,可参考以下操作(附镜像批量生存及批量导入脚本)
二、镜像生存到本机
1、检察已有的镜像文件
docker images
复制代码
如下图所示,当前装备内的全部镜像
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生存镜像
为测试“生存指令中如果使用的是镜像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
复制代码
指令二基本操作同指令一、
载入通过镜像ID生存的当地镜像
通过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
复制代码
实验效果演示:
批量载入镜像tar脚本
新建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企服之家,中国第一个企服评测及商务社交产业平台。
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/)
Powered by Discuz! X3.4