转自:http://blog.csdn.net/zhangzhaokun/article/details/6269514

前言

最近在研习MongoDB集群,找到一个不错的例子,加了几句,按照自己的理解画了一个图,做个笔记。

该实验是在一台Windows机器下搭建了一个 Replica Sets + Sharding 测试集群环境,以此作为后续对于Mongodb更进一步调研的实验平台。

正文

只有一台windows机器,配置方案:

1、3个分片sharding
2、每一个分片由3个节点构成1主2备的Replica Sets
3、3个配置节点Configsever
4、1个路由节点Mongos 分片复制集A(三个分片节点构成一个复制集):
127.0.0.1: 127.0.0.1: 127.0.0.1: 分片复制集B(三个分片节点构成一个复制集):
127.0.0.1: 127.0.0.1: 127.0.0.1: 分片复制集C(三个分片节点构成一个复制集):
127.0.0.1: 127.0.0.1: 127.0.0.1: Configsvc(三个配置服务器节点):
127.0.0.1: 127.0.0.1: 127.0.0.1: mongos(一个路由节点):
127.0.0.1:


详细操作步骤:

(1)下载mongodb-window 安装文件,将bin文件整个放置在D:/MongoDB目录下

(2)创建数据和日志文件目录

进入D:/MongoDB目录下创建如下目录:

 创建数据文件目录:
data/a/r0
data/a/r1
data/a/r2 data/b/r0
data/b/r1
data/b/r2 data/c/r0
data/c/r1
data/c/r2 data/configsvr/r0
data/configsvr/r1
data/configsvr/r2 创建日志文件目录:
logs/a
logs/b
logs/c
logs/configsvr

(3)创建分片和复制集

第一组:

mongod --logpath D:/MongoDB/logs/a/r0.log --logappend --dbpath D:/MongoDB/data/a/r0 --port  --shardsvr --replSet setA --rest  --oplogSize
mongod --logpath D:/MongoDB/logs/a/r1.log --logappend --dbpath D:/MongoDB/data/a/r1 --port --shardsvr --replSet setA --rest --oplogSize
mongod --logpath D:/MongoDB/logs/a/r2.log --logappend --dbpath D:/MongoDB/data/a/r2 --port --shardsvr --replSet setA --rest --oplogSize

启动上述分片节点之后,再使用mongo的命令行来初始化复制集:

D:/MongoDB/bin>call mongo 127.0.0.1:/admin
MongoDB shell version: 1.8.
connecting to: 127.0.0.1:/admin
> config={ _id:'setA',
members:[{_id: ,host:'127.0.0.1:10000'},
{_id:,host:'127.0.0.1:10001'},
{_id:,host:'127.0.0.1:10002'}]
}
{
"_id" : "setA",
"members" : [
{
"_id" : ,
"host" : "127.0.0.1:10000"
},{
"_id" : ,
"host" : "127.0.0.1:10001"
},{
"_id" : ,
"host" : "127.0.0.1:10002"
}] }
setA> rs.initiate(config);

第二组:

mongod --logpath D:/MongoDB/logs/b/r0.log --logappend --dbpath D:/MongoDB/data/b/r0 --port  --shardsvr --replSet setB --rest  --oplogSize
mongod --logpath D:/MongoDB/logs/b/r1.log --logappend --dbpath D:/MongoDB/data/b/r1 --port --shardsvr --replSet setB --rest --oplogSize
mongod --logpath D:/MongoDB/logs/b/r2.log --logappend --dbpath D:/MongoDB/data/b/r2 --port --shardsvr --replSet setB --rest --oplogSize

启动上述分片节点之后,再使用mongo的命令行来初始化复制集

D:/MongoDB/bin>call mongo 127.0.0.1:/admin
MongoDB shell version: 1.8.
connecting to: 127.0.0.1:/admin
> config={
_id: 'setB',
members:[
{_id:,host:'127.0.0.1:20000'},
{_id:,host:'127.0.0.1:20001'},
{_id:,host:'127.0.0.1:20002'}
]}
{
"_id" : "setB",
"members" : [
{
"_id" : ,
"host" : "127.0.0.1:20000"
},{
"_id" : ,
"host" : "127.0.0.1:20001"
},{
"_id" : ,
"host" : "127.0.0.1:20002"
}]
}
> rs.initiate(config);

第三组:

从命令行进入D:/MongoDB/bin目录,分别执行如下命令:

mongod --logpath D:/MongoDB/logs/c/r0.log --logappend --dbpath D:/MongoDB/data/c/r0 --port  --shardsvr --replSet setC --rest  --oplogSize
mongod --logpath D:/MongoDB/logs/c/r1.log --logappend --dbpath D:/MongoDB/data/c/r1 --port --shardsvr --replSet setC --rest --oplogSize
mongod --logpath D:/MongoDB/logs/c/r2.log --logappend --dbpath D:/MongoDB/data/c/r2 --port --shardsvr --replSet setC --rest --oplogSize

启动上述分片节点之后,再使用mongo的命令行来初始化复制集

D:/MongoDB/bin>call mongo 127.0.0.1:/admin
MongoDB shell version: 1.8.
connecting to: 127.0.0.1:/admin
> config={
_id: 'setC',
members:[
{_id: ,host:'127.0.0.1:30000'},
{_id:,host:'127.0.0.1:30001'},
{_id:,host:'127.0.0.1:30002'}
]}
{
"_id" : "setC",
"members" : [
{
"_id" : ,
"host" : "127.0.0.1:30000"
},{
"_id" : ,
"host" : "127.0.0.1:30001"
},{
"_id" : ,
"host" : "127.0.0.1:30002"
}
]
}
> rs.initiate(config);

(4)启动三个配置服务节点Configsvr:(从命令行分别执行如下命令,配置三个Configsvr)

cd D:/MongoDB/bin
call mongod --configsvr --logpath D:/MongoDB/logs/configsvr/r0.log --logappend --dbpath D:/MongoDB/data/configsvr/r0 --port --shardsvr cd D:/MongoDB/bin
call mongod --configsvr --logpath D:/MongoDB/logs/configsvr/r1.log --logappend --dbpath D:/MongoDB/data/configsvr/r1 --port --shardsvr cd D:/MongoDB/bin
call mongod --configsvr --logpath D:/MongoDB/logs/configsvr/r2.log --logappend --dbpath D:/MongoDB/data/configsvr/r2 --port --shardsvr

(5)启动一个路由节点mongos

cd D:/MongoDB/bin
call mongos --configdb 127.0.0.1:,127.0.0.1:,127.0.0.1: --logpath D:/MongoDB/logs/mongos.log --logappend --port

(6)配置分片

>cd D:/MongoDB/bin
D:/MongoDB/bin>call mongo 127.0.0.1:
MongoDB shell version: 1.8.
connecting to: 127.0.0.1:/test
>use admin
switched to db admin
> db.runCommand({addshard:"setA/127.0.0.1:10000,127.0.0.1:10001,127.0.0.1:10002",name:"ShardSetA"})
{ "shardAdded" : "ShardSetA", "ok" : }
> db.runCommand({addshard:"setB/127.0.0.1:20000,127.0.0.1:20001,127.0.0.1:20002",name:"ShardSetB"})
{ "shardAdded" : "ShardSetB", "ok" : }
> db.runCommand({addshard:"setC/127.0.0.1:30000,127.0.0.1:30001,127.0.0.1:30002",name:"ShardSetC"})
{ "shardAdded" : "ShardSetC", "ok" : }
>printShardingStatus() --- Sharding Status ---
sharding version: { "_id" : , "version" : }
shards:
{
"_id" : "ShardSetA",
"host" : "setA/127.0.0.1:10000,127.0.0.1:10001,127.0.0.1:10002"
}
{
"_id" : "ShardSetB",
"host" : "setB/127.0.0.1:20000,127.0.0.1:20001,127.0.0.1:20002"
}
{
"_id" : "ShardSetC",
"host" : "setC/127.0.0.1:30000,127.0.0.1:30001,127.0.0.1:30002"
}
databases:
{ "_id" : "admin", "partitioned" : false, "primary" : "config" }

配置到这里,集群搭建完毕!

在完成了集群的搭建工作之后,需要做的就是建立一个数据库,建立表,设置分片主键来初始化数据了:

查看分片:

db.runCommand( { listshards :  } )

数据库分片:

db.runCommand( { enablesharding : "test"} )

Collecton分片:

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

添加数据测试:

for (var i = ; i <= ; i++){
db.person.insert({"name":"jack"+i, "age":i});
}
db.printShardingStatus() (查看mongodb的数据分片情况)

读者:

撒花,恭喜你兄弟,如果没出意外的话,你已经完成了一个sample,吃枣吃枣哈........

Mongodb集群配置(sharding with replica set)的更多相关文章

  1. 实例:Mongodb集群配置过程

    最近因为一些项目公司开始采用Mongodb做为大量的数据存储,通过网络上大量的资源自己已经掌握一套可行的Mongodb集群配置过程,Mongodb具有无规则存储.大数据存储.多平台支持.强大的扩展插件 ...

  2. MongoDB集群配置笔记一

    MongoDB 的部署方案有单机部署.复本集(主备)部署.分片部署.复本集与分片混合部署.混合的部署方式如图: 分片集群的构造 (1)mongos :数据路由,和客户端打交道的模块.mongos本身没 ...

  3. mongodb集群配置及备份恢复

    Mongodb安装: 编辑/etc/yum.repos.d/mongodb.repo,添加以下: [MongoDB] name=MongoDB Repository baseurl=https://r ...

  4. mongodb集群——配置服务器放分片meta信息,说明meta里包含了哪些数据信息

    在搭建分片之前,先了解下分片中各个角色的作用. ① 配置服务器.是一个独立的mongod进程,保存集群和分片的元数据,即各分片包含了哪些数据的信息.最先开始建立,启用日志功能.像启动普通的mongod ...

  5. mongodb集群配置分片集群

    测试环境 操作系统:CentOS 7.2 最小化安装 主服务器IP地址:192.168.197.21 mongo01 从服务器IP地址:192.168.197.22 mongo02 从服务器IP地址: ...

  6. MongoDB集群配置笔记二(实战)

    单台mongodb配置文件: dbpath=/opt/mongodb/data logpath=/opt/mongodb/logs/mongodb.log logappend=true fork=tr ...

  7. mongodb集群配置副本集

    测试环境 操作系统:CentOS 7.2 最小化安装 主服务器IP地址:192.168.197.21 mongo01 从服务器IP地址:192.168.197.22 mongo02 从服务器IP地址: ...

  8. MongoDB集群配置

    本文演示:(一个主服务器,一个备份服务器,三个仲裁服务器) 官方推荐副本集的成员数量为奇数,最多12个副本集节点,最多7个节点参与选举. 本文演示基于本机,用端口区分服务(每个服务器下新建db文件夹用 ...

  9. mongodb集群配置主从模式

    测试环境 操作系统:CentOS 7.2 最小化安装 主服务器IP地址:192.168.197.21 master-node 从服务器IP地址:192.168.197.22 slave-node 关闭 ...

随机推荐

  1. html --- ajax --- javascript --- 简单的封装

    Ajax的简单封装 Ajax的全称是AsynchronousJavaScriptAndXML 如有疑问请参考:http://zh.wikipedia.org/zh-cn/AJAX 以及传智播客的视频教 ...

  2. openGl从零开始之添加颜色

    OpenGL 支持两种颜色模式:一种是 RGBA模式,一种是 颜色索引模式.无论哪种颜色模式,计算机都必须为每一个像素保存一些数据,即通过每一个像素的颜色,来改变整体图形的颜色.不同的是, RGBA ...

  3. 求相同号码一天内的上网流量——mapreduce

    上网数据 1363157985066 13726230503 00-FD-07-A4-72-B8:CMCC 120.196.100.82 i02.c.aliimg.com 24 27 2481 246 ...

  4. Linker scripts之Intro

    1 Intro Every link is controlled by a linker script. The main purpose of the linker script is to des ...

  5. TopFreeTheme精选免费模板【20130701.特别版】

    今天我们整理了16款WordPress和Joomla的最新主题.它们都是来自Themeforest,RocketTheme,YooTheme以及TemPlaza的高质量主题,赶快收藏起来吧. Este ...

  6. STL源码剖析读书笔记--第6章&第7章--算法与仿函数

    老实说,这两章内容还蛮多的,但是其实在应用中一点点了解比较好.所以我决定这两张在以后使用过程中零零散散地总结,这个时候就说些基本概念好了.实际上,这两个STL组件都及其重要,我不详述一方面是自己偷懒, ...

  7. Camel In Action 阅读笔记 第一章 认识Camel 1.1 Camel 介绍

    1.1 Camel 介绍 Camel 是一个为了您的项目集成变得高效有趣的集成框架,Camel 项目在2007年初开始的,相对来说它还比较年轻,但它已然是一个非常成熟的开源项目,它所使用的是Apach ...

  8. SCU 4440 分类: ACM 2015-06-20 23:58 16人阅读 评论(0) 收藏

    SCU - 4440 Rectangle Time Limit: Unknown   Memory Limit: Unknown   64bit IO Format: %lld & %llu ...

  9. HD2046骨牌铺方格

    骨牌铺方格 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...

  10. 无责任Windows Azure SDK .NET开发入门篇三[使用Azure AD 管理用户信息--3.4 Edit修改用户信息]

    3.4 Edit修改用户信息 我们用FormCollection简化了表单提交,非常方便的进行用户信息修改. [HttpPost, Authorize] public async Task<Ac ...