mongo 分片集群的搭建
MongoDB版本
当前使用的MongoDB版本为4.2.0,下载地址.https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.0.tgz
关闭防火墙
systemctl stop filewalld
集群架构
副本集

若要查看具体的文档,可以访问官方文档,文章中很多内容都可以参考https://docs.mongodb.com/manual/,地址
分片

分三步:
(1).shard副本集的建立
(2).config的replica set 建立
(3).mongos 路由的建立
1.shard副本集的建立
共两个shard,shard1和shard2
(1)三台服务器上分别建立这个文件,及创建需要的目录
mkdir /data/shard1 -p
mkdir /data/logs/12305 -p
shard1.conf
storage:
dbPath: /data/shard1/data
journal:
enabled: true
directoryPerDB: true
#syncPeriodSecs: 60
engine: wiredTiger
processManagement:
fork: true
pidFilePath: /data/shard1/mongod.pid
net:
bindIp: 0.0.0.0
port: 12305
systemLog:
destination: file
path: /data/logs/12305/log.txt
logAppend: true
#security:
# keyFile: /data/phpmongo-keyfile
# authorization: enabled
operationProfiling:
slowOpThresholdMs: 100
mode: slowOp
replication:
#oplogSizeMB: 20000
replSetName: shard1
sharding:
clusterRole: shardsvr
重启服务
/usr/bin/mongod -f shard1.conf
(2) 登陆任意的mongo客户端
/usr/bin/mongo --host 主机ip --port 12305
use admin
storage:
dbPath: /data/confser/data
journal:
enabled: true
directoryPerDB: true
#syncPeriodSecs: 60
engine: wiredTiger
processManagement:
fork: true
pidFilePath: /data/confser/mongoconf.pid
net:
bindIp: 0.0.0.0
port: 12201
systemLog:
destination: file
path: /data/logs/12201/log.txt logAppend: true
replication:
oplogSizeMB: 2048
replSetName: csvr
sharding:
clusterRole: configsvr
processManagement:
fork: true
#security:
# keyFile: /data/phpmongo-keyfile
# authorization: enabled
重启服务
/usr/bin/mongod -f confser.conf
(2) 登陆任意的mongo客户端
/usr/bin/mongo --host 主机ip --port 12201
use admin
processManagement:
fork: true
pidFilePath: /data/mongos/mongos.pid
net:
bindIp: 0.0.0.0
port: 12101
systemLog:
destination: file
path: /data/logs/12101/log.txt
logAppend: true
#security:
# keyFile: /data/phpmongo-keyfile
# #authorization: enabled ##is available only for mongod.
sharding:
configDB: csvr/mongoconf-node1:12201,mongoconf-node2:12201,mongoconf-node3:12201
重启服务
/usr/bin/mongos -f mongos.conf
(2) 登陆任意的mongo客户端
/usr/bin/mongo --host 主机ip --port 12101
mongos>use admin
添加分片
use admin
- db.runCommand( { addshard : "shard1/mongoshard1-node1:12305,mongoshard1-node2:12305,mongoshard1-arb01:12305",name:"shard1"} )
- db.runCommand( { addshard : "shard2/mongoshard2-node1:12306,mongoshard2-node2:12306,mongoshard2-arb01:12306",name:"shard2"} )
激活分片
需要注意的是,分片功能是需要手动开启的.
在mongo shell中,这里设置一个测试数据库,用来测试分片的功能.
- db.runCommand( { enablesharding : "testdb" } )
- db.runCommand( { shardcollection : "testdb.users",key : {id: 1} } )
创建测试数据,用来测试分片功能,下面的代码向数据库中插入了200w条数据,由于数据量比较大,所以批量插入的时候,时间会稍微有点久.
- var arr=[];
- for(var i=0;i<2000000;i++){
- var uid = i;
- var name = "mongodb"+i;
- arr.push({"id":uid,"name":name});
- }
- db.users.insertMany(arr);
查询状态
通过sh.status()函数查看当前分片的状态,查看副本集的状态通过rs.status().
库,用来测试分片的功能.
- db.runCommand( { enablesharding : "testdb" } )
- db.runCommand( { shardcollection : "testdb.users",key : {id: 1} } )
创建测试数据,用来测试分片功能,下面的代码向数据库中插入了200w条数据,由于数据量比较大,所以批量插入的时候,时间会稍微有点久.
- var arr=[];
- for(var i=0;i<2000000;i++){
- var uid = i;
- var name = "mongodb"+i;
- arr.push({"id":uid,"name":name});
- }
- db.users.insertMany(arr);
查询状态
通过sh.status()函数查看当前分片的状态,查看副本集的状态通过rs.status().
mongo 分片集群的搭建的更多相关文章
- Mongo--04 Mongo分片集群
目录 一.分片的概念 二. 分片工作原理 三.IP端口目录规划 1.IP端口规划 2.目录规划 四.分片集群搭建副本集步骤 1.安装软件 2.创建目录 3.创建配置文件 4.优化警告 5.启动服务 6 ...
- 从零搭建mongo分片集群的简洁方法
一.目录 1.mongo路径,config数据路径,shard数据路径
- mongo分片集群部署
测试环境192.168.56.101-213 前期准备: openssl rand -base64 756 > /home/software/mongodb/mongodbkey chmod ...
- Mongo分片集群脚本
bash大法好啊,一键玩mongo. 我的mongo版本是:MongoDB shell version v4.0.2 这里准备为大家献上Mongo创建分片和可复制集的脚本,以及在部署的时候踩的坑. 分 ...
- MongoDB分片集群环境搭建记录
--创建配置服务器mongod.exe --logpath "G:\USERDATA\MONGODB\Test2\Log\mongodb.log" --logappend --db ...
- MongoDB Sharding(二) -- 搭建分片集群
在上一篇文章中,我们基本了解了分片的概念,本文将着手实践,进行分片集群的搭建 首先我们再来了解一下分片集群的架构,分片集群由三部分构成: mongos:查询路由,在客户端程序和分片之间提供接口.本次实 ...
- 【MongoDB】在windows平台下搭建mongodb的分片集群(二)
在上一片博客中我们讲了Mongodb数据库中分片集群的主要原理. 在本篇博客中我们主要讲描写叙述分片集群的搭建过程.配置分片集群主要有两个步骤.第一启动全部须要的mongod和mongos进程. 第二 ...
- Windows 搭建MongoDB分片集群(二)
在本篇博客中我们主要讲描述分片集群的搭建过程.配置分片集群主要有两个步骤,第一启动所有需要的mongod和mongos进程.第二步就是启动一个mongos与集群通信.下面我们一步步来描述集群的搭建过程 ...
- MongoDB之分片集群(Sharding)
MongoDB之分片集群(Sharding) 一.基本概念 分片(sharding)是一个通过多台机器分配数据的方法.MongoDB使用分片支持大数据集和高吞吐量的操作.大数据集和高吞吐量的数据库系统 ...
随机推荐
- OpenSuSe开启sshd服务
需要测试OpenSuSE11 x64上mysql性能,发现很多东西与centos以及红帽有差别.其中最切身的就是sshd服务的开启. 安装好OpenSuSE 11后,发现ssh连接不上去,可以ping ...
- DPS首战鞍山
10月17日就即将飞机去鞍山了,不知不觉进入ACM的世界已经有一年了.虽然这一年我不够勤奋, 还是经常打LOL ,但是感觉自己真的学到了很多 . 在SCAU无数次选拔赛, 淘汰赛,个人排位赛 ,组队训 ...
- CTU OPEN 2017 Pond Cascade /// 思维
题目大意: 给定N F 给定N个水池的大小 每个水池都以流量F开始注水 当位置较前的水池注满后 水会溢出到下一个水池 求 最后一个水池开始溢出的时间 和 所有水池全部注满的时间 1.最后一个n水池开始 ...
- Elastic-Job分布式任务调度
任务调度是指系统为了自动完成特定任务,在约定的特定时刻去执行任务的过程,有了任务调度即可解放更多的人力由系统自动去执行任务. 多线程方式实现: Timer方式实现: ScheduledExecutor ...
- 使用androidstudio时遇到的一些小错误
1 路径名字中不能有汉字 报如下错误:Error:(1, 0) Your project path contains non-ASCII characters. This will most lik ...
- Feign实现服务调用
上一篇博客我们使用ribbon+restTemplate实现负载均衡调用服务,接下来我们使用feign实现服务的调用,首先feign和ribbon的区别是什么呢? ribbon根据特定算法,从服务列表 ...
- 关于js中Ajax的同步、异步使用
下面一个简单的例子,说明前后端交互中,Ajax同步和异步的使用 1.设置简单的一个div,包含触发事件 CompanyType() <div> <input type="h ...
- webpack output.publicPath
output.publicPath string function 对于按需加载(on-demand-load)或加载外部资源(external resources)(如图片.文件等)来说,outpu ...
- 08-03-re-模块
一组特殊符号组成的表达式,用于描述某种规则.该应用场景生活中随处可见. 例如:让有志青年过上体面的生活,这里面就由规则,即有志青年. 正则表达式的作用,以及使用场景 1.用于从字符串中匹配满足 ...
- Dart编程实例 - Enabling Checked Mode
Dart编程实例 - Enabling Checked Mode void main() { int n="hello"; print(n); } 本文转自:http://codi ...