docker完整导出镜像并在新服务器运行
一般我们在迁移或者给第三方docker镜像时经常出现这个问题, 需要打包好已经配置好的完整docker镜像, 本文意在解决这个问题
一、把当前运行的容器 → 保存为新镜像
以如下的镜像为例

这一步会把你所有修改、配置、文件都打包进去
bash
docker commit gracious_liskov office-plugin:v1
- gracious_liskov:你的 onlyOffice 容器名
- office-plugin:v1:自定义新镜像名(随便起)
执行成功会输出一串镜像 ID, 如下图所示:

二、导出这个新镜像为文件
命令如下:
bash
# 可以自定义导出路径, 如下为/opt/
docker save -o /opt/office-plugin.tar office-plugin:v1
导出后你会得到一个 office-plugin.tar 文件(体积较大,正常)。
三、把 tar 文件拷贝到另一台服务器
可以用 scp、U 盘、rz/sz 等方式传输, 如果是内网推荐使用scp命令, 示例如下:
bash
scp office-plugin.tar root@192.168.1.100:/home/data
- office-plugin.tar: 待传输文件
- root: 用户名
- 192.168.1.100: 目标服务器ip
- /home/data: 目标服务器路径(传输到此路径下)
如图所示:

四、在另一台 Docker 上导入镜像
命令如下:
bash
docker load -i office-plugin.tar
- office-plugin.tar: 可自定义文件位置, 如不在当前目录下可添加文件路径, 例如/data/images/office-plugin.tar
五、运行镜像
直接用这个命令运行:
bash
docker run -d -p 18080:80 --restart=always -e JWT_SECRET=secret office-plugin:v1
参数说明:
- docker run: 启动容器命令
- -d : 后台运行
- -p 18080:80: 端口映射(-p 宿主机端口:容器内部端口), 即18080 = 你电脑对外访问的端口, 80 = 容器内部服务用的端口
- --restart=always: 开机 / 崩溃自动重启容器
- -e JWT_SECRET: 给容器传环境变量
- office-plugin:v1: 启动的容器名
启动成功, 如图所示:

至此, 完成docker镜像完整迁移 !