MongoDB: 升级版本至:5.0.28

说明:

限制因素: 服务器为centos7, sdk=1.8,springboot=2.7.18 ,spring-data-mongodb=3.4.18, mongodb-driver-core=4.6.1

centos7 官网下载选项可支持7.0.26等高版本。

spring-data-mongodb=3.4.18 最高支持5.0+。 当前选择(5.0.28版本)

我们当前服务器安装的mongodb版本=4.4.15

历史不重要数据可以根据需求先进行数据清理,防止备份时数据量太大,导致磁盘撑爆。

下载地址:https://www.mongodb.com/try/download/community

服务安装

Docker 安装:

复制代码
docker run -d --name mongodb-5.0.28 -p 27017:27017 mongo:5.0.28

linux安装包下载:

复制代码

# 进入目录
cd /opt/hussar-cloud
`

下载文件(arm框架请自行调整,当前标记的为centos7版本,其它版本请自行调整)`

wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-5.0.28.tgz
`

创建文件夹,解压文件,规整目录,去掉第一层`

mkdir ./mongodb-5.0.28 && tar --no-same-owner -zxf mongodb-linux-*.tgz -C ./mongodb-5.0.28 --strip-components 1
`

copy配置文件到目录(之前服务的配置文件,比如包含端口路径挂载等)`

`

创建日志和数据文件夹`

mkdir -p /opt/hussar-cloud/mongodb-5.0.28/data
mkdir -p /opt/hussar-cloud/mongodb-5.0.28/logs

# mongodb6.0 之后,主包内不包含工具包。需要单独下载工具类。(因为备份需要先看一下自己的bin目录下是否有对应的包)
`

下载并解压工具包:稳定版本=100.5.4,`

wget https://fastdl.mongodb.org/tools/db/mongodb-database-tools-rhel70-x86_64-100.5.4.tgz
tar --no-same-owner -zxvf mongodb-database-tools-*.tgz -C ./mongodb-5.0.28 --strip-components 1 --wildcards "*/bin/*"
`

下载并解压shell包。`

wget https://downloads.mongodb.com/compass/mongosh-2.5.10-linux-x64.tgz
tar --no-same-owner -zxvf mongosh-*.tgz -C ./mongodb-5.0.28 --strip-components 1 --wildcards "*/bin/*"

# 删除无效压缩包
rm -rf mongodb-database-tools-*.tgz && rm -rf mongodb-linux-*.tgz

windows安装包下载:

https://fastdl.mongodb.org/windows/mongodb-windows-x86_64-5.0.28-signed.msi

服务升级:

前置备份

进入文件夹

cd /opt/hussar-cloud

数据库数据备份,请留够时间

mongodb-5.0.28/bin/mongodump --host 127.0.0.1 --port 27017 --username root --password root --authenticationDatabase admin --out /backup/mongodb/full_$(date +%Y%m%d)

历史安装文件备份

tar -zcvf mongodb-4.4.15.tar.gz mongodb-4.4.15/

新版本启动:

老版本服务停止

cd /opt/hussar-cloud/mongodb-4.4.15/bin && ./mongod --shutdown -f mongo.config

进入目录

cd /opt/hussar-cloud/mongodb-5.0.28

查看配置文件是否替换(目录文件必须为5.0.28相关)

cat bin/mongo.config

启动服务

./bin/mongod -f bin/mongo.config

验证服务是否启动成功

./bin/mongosh

初始化脚本执行 # copy数据库初始化语句(如果有建库创建用户等语句)

./bin/mongosh < bin/init-mongo.js

数据恢复

./bin/mongorestore --host 127.0.0.1 --port 27017 --username root --password root --authenticationDatabase admin /backup/mongodb/full_$(date +%Y%m%d)

功能验证:

  • 恢复后数据条数是否一致(./bin/mongosh执行)

    bash 复制代码
    db.adminCommand({ listDatabases: 1 }).databases.forEach(function(dbInfo) {
        var db1 = db.getSiblingDB(dbInfo.name);
        print("========== 数据库:" + dbInfo.name + " ==========");
        db1.getCollectionNames().forEach(function(colName) {
            if (!colName.startsWith("system.")) {
                var count = db1[colName].countDocuments({});
                print("集合:" + colName + " | 数据条数:" + count);
            }
        });
        print("\n");
    });
  • 业务使用功能是否正常。(普通查询,聚合查询等尽可能多的场景验证)

版本回退

停止新服务

cd /opt/hussar-cloud/mongodb-5.0.28/bin && ./mongod --shutdown -f mongo.config

#进入文件夹

cd /opt/hussar-cloud

解压老版本数据(如果原始文件夹未删除可忽略)

ar -zxvf mongodb-4.4.15.tar.gz

启动老服务

cd /mongodb-4.4.15 ./bin/mongod -f bin/mongo.config

验证服务正常启动

./bin/mongo

风险点: 新版本的快照,老版本加载失败。新版本运行期间数据丢失。

相关推荐
·云扬·9 小时前
MySQL Redo Log落盘机制深度解析
数据库·mysql
用户982863025689 小时前
pg内核实现细节
数据库
飞升不如收破烂~9 小时前
Redis 分布式锁+接口幂等性使用+当下流行的限流方案「落地实操」+用户连续点击两下按钮的解决方案自用总结
数据库·redis·分布式
workflower9 小时前
业务需求-假设场景
java·数据库·测试用例·集成测试·需求分析·模块测试·软件需求
亓才孓9 小时前
[JDBC]基于三层架构和MVC架构的JDBCTools
数据库
IT邦德10 小时前
RPM包快速安装Oracle26ai
数据库·oracle
Dovis(誓平步青云)10 小时前
《滑动窗口算法:从 “暴力遍历” 到 “线性高效” 的思维跃迁》
运维·服务器·数据库·算法
mr_LuoWei200910 小时前
python工具:python代码知识库笔记
数据库·python
这周也會开心10 小时前
Redis数据类型的底层实现和数据持久化
数据库·redis·缓存
ん贤10 小时前
一次批量删除引发的死锁,最终我选择不加锁
数据库·安全·go·死锁