码迷,mamicode.com
首页 > 其他好文 > 详细

mongo学习笔记(五):分片

时间:2015-12-11 12:51:41      阅读:222      评论:0      收藏:0      [点我收藏+]

标签:

分片

技术分享

   人脸:       代表客户端,客户端肯定说,你数据库分片不分片跟我没关系,我叫你干啥就干啥,没什么好商量的。

     mongos: 首先我们要了解”片键“的概念,也就是说拆分集合的依据是什么?按照什么键值进行拆分集合....

                     好了,mongos就是一个路由服务器,它会根据管理员设置的“片键”将数据分摊到自己管理的mongod集群,数据

                    和片的对应关系以及相应的配置信息保存在"config服务器"上。

    mongod:   一个普通的数据库实例,如果不分片的话,我们会直接连上mongod。

 

一、mongo复制黏贴7份

技术分享

技术分享

date文件夹为空文件夹

在每个bin文件夹里加一个bat

文件名 内容
config1.bat mongod --dbpath=F:\mongo\mongodb_config1\data --port 2001
config2.bat mongod --dbpath=F:\mongo\mongodb_config2\data --port 2002
config3.bat mongod --dbpath=F:\mongo\mongodb_config3\data --port 2003
mongos.bat mongos --port 2222 --configdb 127.0.0.1:2001,127.0.0.1:2002,127.0.0.1:2003
mongod1.bat mongod --dbpath=F:\mongo\mongodb_data1\data --port 2004
mongod2.bat mongod --dbpath=F:\mongo\mongodb_data2\data --port 2005
mongod3.bat mongod --dbpath=F:\mongo\mongodb_data3\data --port 2006

技术分享

依次启动

config1.bat

config2.bat

config3.bat

mongos.bat

mongod1.bat

mongod2.bat

mongod3.bat

 

新开个cmd

f:
cd F:\mongo\mongodb_mongos\bin
mongo 127.0.0.1:2222/admin
db.runCommand({"addShard":"127.0.0.1:2004"})
db.runCommand({"addShard":"127.0.0.1:2005"})
db.runCommand({"addShard":"127.0.0.1:2006"})

db.runCommand({"enablesharding":"test"})
db.runCommand({"shardcollection":"test.person","key":{"name":1}})

插入数据

use test
for(var i=0;i<10000;i++){
db.person.insert({"name":"jack"+i,"age":i})
}

技术分享

查看效果

技术分享

 

疑问:

1.mongos 一直报这个:distributed lock ‘balancer/****‘ unlocked 

2.分片不均匀,1W数据分成4444,5555,1  到3个数据库

mongo学习笔记(五):分片

标签:

原文地址:http://www.cnblogs.com/margin-gu/p/5038539.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!