wsl的docker备份mongo和迁移

wsl原版本Ubuntu20.04迁移到新版本Ubuntu22.04

一、确定版本

bash 复制代码
root@LAPTOP-AFO65SIR:/home/fantasy# docker exec mongo mongod --version
db version v5.0.5
Build Info: {
    "version": "5.0.5",
    "gitVersion": "d65fd89df3fc039b5c55933c0f71d647a54510ae",
    "openSSLVersion": "OpenSSL 1.1.1f  31 Mar 2020",
    "modules": [],
    "allocator": "tcmalloc",
    "environment": {
        "distmod": "ubuntu2004",
        "distarch": "x86_64",
        "target_arch": "x86_64"
    }
}

二、提交容器为新镜像

bash 复制代码
# 首先,停止容器以保证数据一致性
docker stop mongo
# 将当前容器状态提交为一个新的镜像,并明确指定版本标签
docker commit mongo my-mongo-5.0.5

三、将镜像保存为文件

bash 复制代码
# 将镜像保存为 .tar 文件,方便传输
docker save -o my-mongo-5.0.5.tar my-mongo-5.0.5

四、 在新环境加载和运行

bash 复制代码
# 在新机器上加载镜像文件
docker load -i my-mongo-5.0.5.tar
# 运行新容器(注意:数据已包含在镜像中,但为了持久化,仍建议挂载卷)
docker run -d --name my-mongo -p 27017:27017 my-mongo-5.0.5

五、验证

bash 复制代码
检查容器是否运行
docker ps | grep my-mongo

六、从原容器内部复制数据目录

bash 复制代码
# 1. (如果之前停止了)先启动容器
docker start <你的容器名称>
# 2. 将容器内的数据目录复制到宿主机当前目录
docker cp <你的容器名称>:/data/db ./mongo_data_backup/
# 3. 打包数据目录
tar czf mongo_data_backup.tar.gz mongo_data_backup/

七、将镜像和数据打包成文件

bash 复制代码
将新创建的本地镜像保存为 .tar 文件
docker save -o my-mongo-5.0.5.tar my-mongo:5.0.5

现在得到了两个关键文件:

- my-mongo-5.0.5.tar (包含MongoDB 5.0.5程序的镜像)

- mongo_data_backup.tar.gz (包含所有数据库数据)

八、传输文件到新服务器

把上述两个文件传输到新服务器

九、在新服务器上恢复并运行

bash 复制代码
# 在新机器上加载镜像文件
docker load -i my-mongo-5.0.5.tar
# 运行新容器(注意:数据已包含在镜像中,但为了持久化,仍建议挂载卷)
docker run -d --name my-mongo -p 27017:27017 my-mongo-:5.0.5
docker cp /tmp/mongo_dump/ mongo-new:/tmp/
docker exec mongo-new sh -c 'mongorestore --drop /tmp/mongo_dump/'

十、启动并验证数据

bash 复制代码
root@LAPTOP-AFO65SIR:/home/fantasy# docker exec -it my-mongo mongosh
Current Mongosh Log ID: 6984123c9acd564e1a9194b2
Connecting to:          mongodb://127.0.0.1:27017/?directConnection=true&serverSelectionTimeoutMS=2000
Using MongoDB:          5.0.5
Using Mongosh:          1.1.6

For mongosh info see: https://docs.mongodb.com/mongodb-shell/

------
   The server generated these startup warnings when booting:
   2026-02-05T03:44:24.935+00:00: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine. See http://dochub.mongodb.org/core/prodnotes-filesystem
   2026-02-05T03:44:25.062+00:00: Access control is not enabled for the database. Read and write access to data and configuration is unrestricted
   2026-02-05T03:44:25.062+00:00: Soft rlimits for open file descriptors too low
------

Warning: Found ~/.mongorc.js, but not ~/.mongoshrc.js. ~/.mongorc.js will not be loaded.
  You may want to copy or rename ~/.mongorc.js to ~/.mongoshrc.js.
test>
bash 复制代码
test> show dbs
admin   8.19 kB
config  12.3 kB
local   8.19 kB
test    24.6 kB
test> use test
already on db test
test>
相关推荐
葫芦和十三8 小时前
图解 MongoDB 22|读写关注:持久性与一致性的档位选择
后端·mongodb·agent
葫芦和十三14 小时前
图解 MongoDB 21|选举与 failover:Primary 是怎么选出来的
后端·mongodb·agent
SkyWalking中文站1 天前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控
雪梨酱QAQ1 天前
Kubeneters HA Cluster部署
运维
lichenyang4531 天前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4531 天前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4531 天前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4531 天前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
江华森1 天前
Spring Cloud 微服务全栈实战:从 Eureka 到 Docker Compose 一文贯通
运维
江华森1 天前
Matplotlib 数据绘图基础入门
运维