Docker镜像远程(离线)迁移教程

文章目录

一、大致步骤

  1. 把本地服务器的指定镜像打包为tar格式的文件
  2. 把tar格式文件通过scp命令(linux自带)拷贝到另一台服务器
  3. 通过ssh远程控制服务器加载tar文件为镜像

二、涉及工具:scp命令

命令介绍:

SCP(Secure Copy ),是linux/unix系统下,基于ssh协议协议的文件加密传输命令。

他有一下特点:

  • 安全加密:依赖ssh协议(默认22端口),全过程加密(先非对称+对称加密)
  • 跨主机通用:本地->远程 远程->本地 远程->远程
  • 易用性:linux自带的命令,不用安装默认工具,且大部分服务器防火墙默认允许scp文件传输,不需要额外配置防火墙

命令语法

bash 复制代码
scp [可选参数] 要传输的本地文件/目录 远程用户@远程IP:远程目标路径
  • 可选参数:-r可以递归传输文件
  • 远程用户:一般默认root,因为只有root才有最高权限
  • 远程IP:服务器的IP地址
  • 远程目标路径:目标服务器要下载该文件的文件夹路径

三、实操

编写bash脚本

这里可以不用脚本写,按照命令一步步来也行,不过为了更好的演示步骤,俺在这里就通过脚本的方式呈现给大家:

bash 复制代码
#!/bin/bash

# 脚本名称:transfer-docker-image.sh

#配置信息
REMOTE_USER="root" #远程服务器用户名
REMOTE_IP="113.44.150.39" #远程服务器IP
REMOTE_PATH="/root/remote_scp" #远程服务器的文件夹地址

IMAGE_NAME="depoy-app:latest" #要传输的镜像
TAR_FILE="depoy-app.tar" # 要打包成的tar文件


echo "=== Docker镜像传输开始 ==="

# 1. 保存镜像
echo "1. 保存镜像到本地文件..."
docker save -o "$TAR_FILE"  "$IMAGE_NAME"

echo "  文件大小: $(ls -lh "$TAR_FILE" | awk '{print $5}')"

# 2. 传输文件
echo "2. 传输到远程服务器..."
echo "  目标: $REMOTE_USER@$REMOTE_IP:$REMOTE_PATH/"
scp "$TAR_FILE"  "$REMOTE_USER@$REMOTE_IP:$REMOTE_PATH"

# 3.验证传输是否正常
ssh "$REMOTE_USER@$REMOTE_IP" "ls -lh $REMOTE_PATH"


# 4. 在线解压为镜像
ssh "$REMOTE_USER@$REMOTE_IP" "docker load -i $REMOTE_PATH/$TAR_FILE"

注意

每次执行scp命令都要填写远程服务器密码,这是为了防止中间人攻击(底层ssh协议)

使用演示

1、 执行脚本

bash 复制代码
chmod +x transfer-docker-image.sh  #赋予可执行权限,即使不用bash命令,也可执行bash脚本
bash transfer-docker-image.sh # 通过bash命令执行bash脚本(保险)

=== Docker镜像传输开始 ===
1. 保存镜像到本地文件...
  文件大小: 502M
2. 传输到远程服务器...
  目标: root@113.44.150.39:/root/remote_scp/
The authenticity of host '113.44.150.39 (113.44.150.39)' can't be established.
ED25519 key fingerprint is SHA256:pXZUvDvhC0aVaE3cH8WNtn4LMf9IUk0W7DUsnN/5IMg.
This key is not known by any other names
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '113.44.150.39' (ED25519) to the list of known hosts.
root@113.44.150.39's password: 
depoy-app.tar                                                                                                                                                                                                                                          100%  502MB   1.4MB/s   06:07    
root@113.44.150.39's password: 
total 502M
-rw------- 1 root root 502M Jan 31 16:21 depoy-app.tar
root@113.44.150.39's password: 
Loaded image: depoy-app:latest

2、查看远程服务器,tar文件和镜像已经回显:

bash 复制代码
pwd #查看远程服务器地址是否匹配
/root/remote_scp

ls -lh
total 502M
-rw------- 1 root root 502M Jan 31 16:21 depoy-app.tar
root@hcss-ecs-d15b:~/remote_scp# docker images

REPOSITORY   TAG       IMAGE ID       CREATED        SIZE
depoy-app    latest    911decca4303   4 months ago   522MB

相关推荐
乘云数字DATABUFF3 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
Patrick_Wilson4 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
Suroy4 天前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭4 天前
运行你的第一个Docker容器
后端·docker·容器
荣--5 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森5 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
宋均浩5 天前
# Docker 镜像瘦身实战:从 1.2G 到 80MB 的五个优化步骤
ci/cd·docker
Avan_菜菜6 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
程序员老赵6 天前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
WangMingHua1116 天前
LM Studio Docker 部署——本地大模型一键启动
docker