一、服务器信息
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()