数据库

 首页 > 数据库 > MongoDB > MongoDB集群相关操作

MongoDB集群相关操作

分享到:
【字体:
导读:
         摘要:MongoDBreplicaSet配置说明MongoDB在1.6版本对开发了新功能replicaset,这比之前的replication功能要强大一些,autoshard已经明确说明不支持replicationparis,建议使用replicaset,replicaset故障切换完全自动,各个DB之间数据完全一致,大大...

MongoDB集群相关操作

MongoDB replica Set配置说明

MongoDB在1.6版本对开发了新功能replica set,这比之前的replication功能要强大一些,auto shard已经明确说明不支持replication paris,建议使用replica set,replica set故障切换完全自动,各个DB之间数据完全一致,大大降低了维护成功。
replica set 配置如下:
1、创建目录 /data/db ,data/db2 ,/data/db3,启动mongod并创建复制集 foo

启动mongod 
[root@TEST40]
mongod --shardsvr --fork --replSet foo  --logpath /var/log/mongodb.log --logappend   --rest
mongod --shardsvr --fork --replSet foo --port 27019 --logpath /var/log/mongodb2.log --logappend --dbpath /data/db2 --rest
mongod --shardsvr --fork --replSet foo --port 27020 --logpath /var/log/mongodb3.log --logappend --dbpath /data/db3 --rest
2、初始化复制集配置信息
初始化时给每个host分配一个ID,该ID在复制集中是唯一的,在测试过程中没有发现该ID和故障切换有直接关系。
> config = {_id: 'foo', members: [
...                           {_id: 0, host: '192.168.100.212:27018'},
...                           {_id: 1, host: '192.168.100.212:27019'},
...                           {_id: 2, host: '192.168.100.212:27020'}]
...            }
{
        "_id" : "foo",
        "members" : [
                {
       "_id" : 0,
       "host" : "192.168.100.212:27018"
                },
                {
       "_id" : 1,
       "host" : "192.168.100.212:27019"
                },
                {
       "_id" : 2,
       "host" : "192.168.100.212:27020"
                }
        ]
}
> rs.initiate(config);
{
        "info" : "Config now saved locally.  Should come online in about a minute.",
        "ok" : 1
}

已经配置成功
3、查看查看replica set存在的成员
state:1表示该host是当前可以进行读写,2:不能读写
health:1表示该host目前是正常的,0:异常
[root@TEST40 data]# mongo 192.168.100.212:27018 
MongoDB shell version: 1.6.0
connecting to: 192.168.100.212:27018/test
> use admin
switched to db admin
> db.runCommand({replSetGetStatus : 1});
{
        "set" : "foo",
        "date" : "Fri Aug 20 2010 08:35:59 GMT+0000 (UTC)",
        "myState" : 1,
        "members" : [
                {
       "_id" : 0,
       "name" : "TEST40:27018",
       "health" : 1,
       "state" : 1,
       "self" : true
                },
                {
       "_id" : 1,
       "name" : "192.168.100.212:27019",
       "health" : 1,
       "state" : 2,
       "uptime" : 516,
       "lastHeartbeat" : "Fri Aug 20 2010 08:35:58 GMT+0000 (UTC)"
                },
                {
       "_id" : 2,
       "name" : "192.168.100.212:27020",
       "health" : 1,
       "state" : 2,
       "uptime" : 508,
       "lastHeartbeat" : "Fri Aug 20 2010 08:35:58 GMT+0000 (UTC)"
                }
        ],
        "ok" : 1
}

4、failover试验
登陆其它的slave,slave是不可以进行读写的。
[root@TEST40 data]# mongo 192.168.100.212:27019
MongoDB shell version: 1.6.0
connecting to: 192.168.100.212:27019/test
> use test          
switched to db test
> db.people.find();
error: { "$err" : "not master", "code" : 10107 }

[root@TEST40 data]# mongo 192.168.100.212:27020
MongoDB shell version: 1.6.0
connecting to: 192.168.100.212:27020/test
> use test         
switched to db test
> db.people.find();
error: { "$err" : "not master", "code" : 10107 }

查看复制集合成员状态
登陆192.168.100.212:27020
[root@TEST40 data]# mongo 192.168.100.212:27020
MongoDB shell version: 1.6.0
connecting to: 192.168.100.212:27020/test
> use admin
switched to db admin
> db.runCommand({replSetGetStatus : 1});
{
        "set" : "foo",
        "date" : "Fri Aug 20 2010 08:36:39 GMT+0000 (UTC)",
        "myState" : 2,
        "members" : [
                {
       "_id" : 0,
       "name" : "192.168.100.212:27018",
       "health" : 1,
       "state" : 1,
       "uptime" : 546,
       "lastHeartbeat" : "Fri Aug 20 2010 08:36:38 GMT+0000 (UTC)"
                },
                {
       "_id" : 1,
       "name" : "192.168.100.212:27019",
       "health" : 1,
       "state" : 2,
       "uptime" : 546,
       "lastHeartbeat" : "Fri Aug 20 2010 08:36:38 GMT+0000 (UTC)"
                },
                {
       "_id" : 2,
       "name" : "TEST40:27020",
       "health" : 1,
       "state" : 2,
       "self" : true
                }
        ],
        "ok" : 1
}
将主DB关闭,再次查看发现192.168.100.212:27020 DB角色转变为主。原先主库无法登陆,但是state仍然为1 health变为0
> db.runCommand({replSetGetStatus : 1});
{
        "set" : "foo",
        "date" : "Fri Aug 20 2010 08:41:16 GMT+0000 (UTC)",
        "myState" : 1,
        "members" : [
                {
       "_id" : 0,
         "name" : "192.168.100.212:27018",
       "health" : 0,
       "state" : 1,
       "uptime" : 0,
       "lastHeartbeat" : "Fri Aug 20 2010 08:41:12 GMT+0000 (UTC)",
       "errmsg" : "connect/transport error"
                },
                {
       "_id" : 1,
       "name" : "192.168.100.212:27019",
       "health" : 1,
       "state" : 2,
       "uptime" : 823,
       "lastHeartbeat" : "Fri Aug 20 2010 08:41:16 GMT+0000 (UTC)"
                },
                {
       "_id" : 2,
       "name" : "TEST40:27020",
       "health" : 1,
       "state" : 1,
       "self" : true
                }
        ],
        "ok" : 1
}

MongoDB集群相关操作
分享到:
Java程序如何对MongoDB的进行AND、OR和IN...
Java程序如何对MongoDB的进行AND、OR和IN操作  在MongoDB的官方文档中关于Java操作的介绍,只给出了很简单的几个例子。这些例子虽然可以满足一定的需求,但是还并不是太完全。下面是我根据网页中的提示写的几个例子。        1.背景。用JUnit4.8.2实现的单元测试的形式。测试数据: {uid:10,username:"...
mongodb shell使用教程
mongodb shell使用教程 MongoDB shell是MongoDB自带的一个javascript shell,通过它,我们可以与MongoDB实例交互。包括执行管理操作, 检查运行实例,或其他操作。 1. 启动MongoDB shell 启动shell的方法很简单,将我们从http://www.mongodb.org/downloads#32-bit-limit这里下载的文件加压出来后, 放在如下位...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……