mongodb集群之分片设计和实现

一、服务器信息

1、ip

192.168.5.107 192.168.5.118 192.168.5.171 

在三台服务器分别配置mongos,config,shard1,shard2,shard3

 

2、端口

约定mongos为 20000, config server 为 21000, shard1为 22001 , shard2为22002, shard3为22003.

3、架构图

二、配置服务器

1、配置服务器配置

port=21000
dbpath=/home/data/config/data/
logpath=/home/data/config/log/mongodb.log
pidfilepath=/usr/local/mongodb/config/config.pid
fork=true
logappend=true      

2、在每一台服务器分别启动配置服务器。

 


./mongod --config /usr/local/mongodb/config/config.conf   --configsvr

 

 

三、mongos服务器

 

 ./mongos --configdb 192.168.5.107:21000,192.168.5.118:21000,192.168.5.171:21000 --port 20000 --logpath /home/data/mongos/log/mongos.log --fork

 

四、shard服务器 

1、配置


 

#shard1
port=22001
dbpath=/home/data/shard1/data/
logpath=/home/data/shard1/log/mongodb.log
pidfilepath=/usr/local/mongodb/config/shard1.pid
fork=true
logappend=true
shardsvr=true


#shard2
port=22002
dbpath=/home/data/shard2/data/
logpath=/home/data/shard2/log/mongodb.log
pidfilepath=/usr/local/mongodb/config/shard2.pid
fork=true
logappend=true
shardsvr=true

#shard3
port=22003
dbpath=/home/data/shard3/data/
logpath=/home/data/shard3/log/mongodb.log
pidfilepath=/usr/local/mongodb/config/shard3.pid
fork=true
logappend=true
shardsvr=true

 

 

 

 

2、启动  


 

 ./mongod --config /usr/local/mongodb/config/shard1.conf --replSet shard1 --nojournal --oplogSize 10
 ./mongod --config /usr/local/mongodb/config/shard2.conf --replSet shard2 --nojournal --oplogSize 10
 ./mongod --config /usr/local/mongodb/config/shard3.conf --replSet shard3 --nojournal --oplogSize 10

 

五、配置各个分片的副本集

 

1、shard1 副本集配置

#定义副本集配置
mongo -port 22001
#使用admin数据库
use admin
config = { _id:"shard1", members:[
  {_id:0,host:"192.168.5.107:22001"},
  {_id:1,host:"192.168.5.118:22001"},
  {_id:2,host:"192.168.5.171:22001",arbiterOnly:true}
  ]
  }

#初始化副本集配置
rs.initiate(config);

 

2、shard2副本集配置

#定义副本集配置
mongo -port 22002
#使用admin数据库
use admin
config = { _id:"shard2", members:[
  {_id:0,host:"192.168.5.107:22002"},
  {_id:1,host:"192.168.5.118:22002"},
  {_id:2,host:"192.168.5.171:22002",arbiterOnly:true}
  ]
  }

#初始化副本集配置
rs.initiate(config);

 

3、shard3副本集配置

#定义副本集配置
mongo -port 22003
#使用admin数据库
use admin
config = { _id:"shard3", members:[
  {_id:0,host:"192.168.5.107:22003"},
  {_id:1,host:"192.168.5.118:22003"},
  {_id:2,host:"192.168.5.171:22003",arbiterOnly:true}
  ]
  }

#初始化副本集配置
rs.initiate(config);

 

 

六、分片配置

1、链接mongos添加分片

mongo -port 20000
db.runCommand( { addshard : "shard1/192.168.5.107:22001,192.168.5.118:22001,192.168.5.171:22001"});

db.runCommand( { addshard : "shard2/192.168.5.107:22002,192.168.5.118:22002,192.168.5.171:22002"});

db.runCommand( { addshard : "shard3/192.168.5.107:22003,192.168.5.118:22003,192.168.5.171:22003"});

2、指定需要分片的数据库和表

db.runCommand( { enablesharding :"testshard"});

db.runCommand( { shardcollection : "testshard.user",key : {_id: 1} } )

 

七、测试

 

测试

连接到路由器   

./mongo -port 20000

 for (var i = 10; i <= 10000; i++) {
db.user.save({"name":"iphone7", "id":i});
}

 

 

八、效果

 

 

 

 

九、分片管理

 

1、db.printShardingStatus()

 

 


 


 

 

 

 

 

 

转载于:https://my.oschina.net/fengshuzi/blog/752352

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值