docker save 和 docker load介绍
让我详细介绍 docker save
和 docker load
命令的使用:
docker save
命令:
- 作用:将一个或多个 Docker 镜像保存为 tar 归档文件
- 常用格式:
# 基本语法
docker save [options] image [image...] > output.tar
# 保存单个镜像
docker save nginx:latest > nginx.tar
# 保存多个镜像
docker save nginx:latest redis:latest > images.tar
# 使用 -o 参数
docker save -o mysql.tar mysql:5.7
# 实际项目示例
docker save \
mysql:5.7 \
redis:latest \
nginx:alpine \
> project_images.tar
docker load
命令:
- 作用:从 tar 归档文件加载镜像
- 常用格式:
# 基本语法
docker load < input.tar
# 使用 -i 参数
docker load -i images.tar
# 查看加载进度
docker load --input images.tar --quiet=false
# 实际项目示例
cat project_images.tar | docker load
- 常用组合示例:
# 1. 导出所有镜像
docker save $(docker images -q) > all_images.tar
# 2. 导出指定镜像及其相关依赖
docker save $(docker history -q nginx:latest | tac) > nginx_with_deps.tar
# 3. 导出 docker-compose 中的镜像
docker save $(docker compose images -q) > compose_images.tar
- 错误处理和验证:
# 保存镜像时验证
docker save nginx:latest | gzip > nginx.tar.gz
if [ $? -eq 0 ]; then
echo "Save successful"
else
echo "Save failed"
fi
# 加载镜像时验证
docker load < images.tar
if [ $? -eq 0 ]; then
echo "Load successful"
else
echo "Load failed"
fi
- 高级使用场景:
#!/bin/bash
# save_images.sh
# 设置变量
OUTPUT_DIR="docker_images"
mkdir -p $OUTPUT_DIR
# 获取所有镜像
images=$(docker images --format "{{.Repository}}:{{.Tag}}" | grep -v "<none>")
# 逐个保存镜像
for img in $images; do
# 替换 / 为 _ 以创建有效的文件名
filename=$(echo $img | tr '/' '_')
echo "Saving $img to $OUTPUT_DIR/$filename.tar"
docker save $img > "$OUTPUT_DIR/$filename.tar"
done
- 常见问题和解决方案:
# 1. 文件太大:使用 gzip 压缩
docker save nginx:latest | gzip > nginx.tar.gz
gunzip -c nginx.tar.gz | docker load
# 2. 验证镜像完整性
# 保存时计算校验和
docker save nginx:latest | tee nginx.tar | md5sum > nginx.md5
# 加载时验证
md5sum -c nginx.md5 && docker load < nginx.tar
# 3. 批量处理带进度显示
docker save nginx:latest | pv > nginx.tar
- 实用脚本示例:
#!/bin/bash
# docker_image_backup.sh
# 配置
BACKUP_DIR="/backup/docker/images"
DATE=$(date +%Y%m%d)
BACKUP_FILE="$BACKUP_DIR/docker_images_$DATE.tar"
# 创建备份目录
mkdir -p $BACKUP_DIR
# 获取所有非空镜像
IMAGES=$(docker images --format "{{.Repository}}:{{.Tag}}" | grep -v "<none>")
# 保存镜像
echo "Starting backup..."
docker save $IMAGES > $BACKUP_FILE
# 压缩
gzip $BACKUP_FILE
echo "Backup completed: ${BACKUP_FILE}.gz"
-
注意事项:
-
空间考虑:
# 检查镜像大小
docker images --format "{{.Repository}}:{{.Tag}} - {{.Size}}"
# 检查 tar 文件大小
du -sh images.tar
- 性能考虑:
# 使用压缩减小文件大小
docker save myimage | gzip > myimage.tar.gz
# 使用 pv 显示进度
docker save myimage | pv | gzip > myimage.tar.gz
- 安全考虑:
# 添加文件权限控制
chmod 600 images.tar
# 添加校验和
sha256sum images.tar > images.tar.sha256
使用建议:
- 保存镜像前先清理不需要的镜像
- 使用有意义的文件命名
- 保持版本记录
- 定期清理旧的备份文件
- 考虑使用压缩来节省空间