千家信息网

3.0.2→3.2.12 Sharded Cluster升级

发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,前期准备:1)3.2.12版本准备好2)升级过程中,保证client不会修改集合元数据。例如:不能执行下列操作:sh.enableSharding()sh.shardCollection()sh.ad
千家信息网最后更新 2025年02月23日3.0.2→3.2.12 Sharded Cluster升级

前期准备:

1)3.2.12版本准备好

2)升级过程中,保证client不会修改集合元数据。例如:不能执行下列操作:


    • sh.enableSharding()

    • sh.shardCollection()

    • sh.addShard()

    • db.createCollection()

    • db.collection.drop()

    • db.dropDatabase()

    • any operation that creates a database

    • any other operation that modifies the cluster metadata in any way.

3)关闭balancer

4)备份config数据库



操作步骤:

1、关闭balancer

mongos> db.setBalancerState(false);


2、升级shards

  • 升级其中一个Secondary成员

    • 关闭mongod实例,3.0命令替换成3.2

    • 重启该成员。等待该成员集群中的状态为SECONDARY后,再升级第二个Secondary

  • Step Down主节点。

  • 当rs.status()显示主节点已经是分片的其他成员,开始升级stepped-down的主节点(此时,只是role是Secondary)

    • 关闭mongod实例,3.0命令替换成3.2

    • 重启


3、升级config server

升级config server是有顺序的。如果启动mongos指定的config server顺序如下

//mongod_config.confsharding:   configDB: db-test01:20001,db-test02:20001,db-test03:20001

那么,升级的顺序为:db-test03 → db-test02 → db-test01

  • 关闭db-test03 config server,并且3.0命令替换成3.2

  • 启动3.2版本的config server,指定configsvr和port

    • 使用命令行启动

mongod --configsvr --port 20001 --dbpath /data/mongodb/config

    • 使用配置文件启动

sharding:   clusterRole: configsvrnet:   port: 20001storage:   dbpath: /data/mongodb/config

依次重复启动其他configDB:db-test02、db-test01


4、升级mongos实例

  • 无序的。替换3.2版本的mongos,重启(一个一个mongos做替换)

关闭mongos时,程序会有报错。因为mongos关闭,当前连接会断掉,之后程序尝试连接关闭的mongos连不上会连接其他mongos(如有多个mongos节点且程序配置访问多个mongos),不影响业务。


5、开启balancer

mongos> db.setBalancerState(true);



升级过程中,使用脚本每秒向数据库写一条数据。观察数据写入情况

//报错信息WriteResult({        "nInserted" : 0,        "writeError" : {                "code" : 94,                "errmsg" : "Request contains sharding metadata, but the server has not been made sharding aware."        }})

可能原因:stepDown未切换到其他节点,就将节点关闭了。




0