MongoDB 分片集群复制数据库副本

文章目录


提示:MongoDB分片集群数据库名称不能直接重命名(MongoDB副本集或MongoDB单机可以直接重命名数据库名称),如果MongoDB分片集群数据库名称需要重命名,则需要创建一个新的数据库并把数据库备份导入。

MongoDB分片集群主机规划

主机名称 主机IP CPU 内存 mongos端口 config端口 share1端口 share2端口 share3端口 操作系统及软件版本
mongodb01 192.168.91.61 2*4 16GB 27017 27019 27101 27102 27103 CentOS 7.9 mongo 4.4.29 mongos 4.4.29 mongod 4.4.29 mongosh 2.2.29
mongodb02 192.168.91.62 2*4 16GB 27017 27019 27101 27102 27103 CentOS 7.9 mongo 4.4.29 mongos 4.4.29 mongod 4.4.29 mongosh 2.2.29
mongodb03 192.168.91.63 2*4 16GB 27017 27019 27101 27102 27103 CentOS 7.9 mongo 4.4.29 mongos 4.4.29 mongod 4.4.29 mongosh 2.2.29

实验场景:

现在需要把emop_elinkmain数据库中main_repetition集合和shard_repetition 集合复制到另外一个新的数据库emop_elinkmain_new进行测试(同一个MonogDB分片集群操作)。


一、登录MongoDB查询数据库及集合分片情况

bash 复制代码
mongosh --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111"

### 查看分片情况
sh.status();

二、登录MongoDB先创建副本数据库并设置数据库及集合分片功能

bash 复制代码
mongosh --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111"

### 进入到admin数据库
use admin

### 创建副本数据库分片功能(默认自动分片)
db.runCommand( { enablesharding : "emop_elinkmain_new" } );

### 设置副本数据库main_repetition集合和hard_repetition 集合分片功能,_id为片键使用hashed哈希算法
db.runCommand({ shardcollection : "emop_elinkmain_new.main_repetition",key : {"_id": "hashed"}} );
db.runCommand({ shardcollection : "emop_elinkmain_new.shard_repetition",key : {"_id": "hashed"}} );

### 查看分片情况
sh.status();

三、登录MongoDB查询emop_slinkmain数据库main_repetition集合和

bash 复制代码
shard_repetition 集合数据行数
mongosh --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111"

### 进入到emop_elinkmain旧数据库查看main_repetition、shard_repetition三个集合的数据行数
use emop_elinkmain
db.main_repetition.stats().count;
db.shard_repetition.stats().count;

四、使用mongodump压缩备份emop_slinkmain数据库中的main_repetition集合和shard_repetition 集合

bash 复制代码
mongosh --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111"
mongodump --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111" --authenticationDatabase admin -d emop_elinkmain -c main_repetition -o /data/backup/ --gzip
mongodump --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111" --authenticationDatabase admin -d emop_elinkmain -c shard_repetition -o /data/backup/ --gzip

五、使用mongorestore解压恢复emop_slinkmain数据库中的main_repetition集合和shard_repetition 集合

bash 复制代码
mongosh --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111"
mongorestore --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111" --authenticationDatabase admin -d emop_elinkmain_new -c main_repetition --dir=/data/backup/emop_elinkmain/main_repetition.bson.gz --gzip
mongorestore --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111" --authenticationDatabase admin -d emop_elinkmain_new -c shard_repetition --dir=/data/backup/emop_elinkmain/shard_repetition.bson.gz --gzip

六、登录MongoDB新旧集合数据行数是否一样

bash 复制代码
mongosh --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111"

### 进入到emop_elinkmain_new新数据库查看main_repetition、shard_repetition三个集合的数据行数
use emop_elinkmain_new
db.main_repetition.stats().count;
db.shard_repetition.stats().count;

七、删除库、删除集合、清空集合所有数据

bash 复制代码
mongosh --host 192.168.91.61 --port 27017 -u "root" -p "AAAaaa111"

### 删除emop_elinkmain数据库(所有集合都会删除)
use emop_elinkmain
db.dropDatabase()

### 删除emop_elinkmain数据库main_repetition集合、shard_repetition集合
use emop_elinkmain
db. main_repetition.drop()
db. shard_repetition.drop()

### 清空emop_elinkmain数据库main_repetition集合和shard_repetition集合所有数据
use emop_elinkmain
db. main_repetition.deleteMany({})
db. shard_repetition.deleteMany({})
相关推荐
专注API从业者16 分钟前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
大迪deblog21 分钟前
系统架构师-数据库-数据库设计
数据库·oracle·系统架构
leo__52033 分钟前
IEC 104 协议 C 语言实现
c语言·数据库
摇滚侠34 分钟前
DBeaver 导入数据库 导入 SQL 文件 MySQL 备份恢复
java·数据库·mysql
若兰幽竹1 小时前
【从零开始编写数据库系统:架构设计与实现】第5章:查询执行引擎与火山模型
数据库·架构·数据库内核·toydb
天空属于哈夫克32 小时前
企业微信API常见的错误和解决方案
java·数据库·企业微信
东风破1372 小时前
DM8达梦数据库备份、恢复原理介绍
数据库·oracle·dm达梦数据库
鹏子训2 小时前
AI记忆新思路:用SQLite替代向量数据库,去EMBEDDINGS化,谷歌开源Google Always On Memory Agent
数据库·人工智能·sqlite·embedding
Frank_refuel2 小时前
终端环境下:Ubuntu 22.04.1 安装 MySQL 数据库
数据库·mysql·ubuntu
虹科网络安全3 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(下)
数据库·redis·bootstrap