MongoDB集群相关资料

MongoDB分布式部署

http://hi.baidu.com/lzpsky/blog/item/d59af4276c73c50f908f9d5d.html

 

配置MongoDB集群

http://blog.csdn.net/duck_genuine/archive/2010/10/09/5929743.aspx

 

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
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Spring Boot应用程序中配置MongoDB集群,需要执行以下步骤: 1. 添加MongoDB驱动程序依赖项:在pom.xml文件中添加以下依赖项: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> ``` 2. 配置MongoDB集群连接:在application.properties或application.yml文件中添加以下属性: ``` spring.data.mongodb.uri=mongodb://host1:port1,host2:port2,host3:port3/databaseName?replicaSet=yourReplicaSetName ``` 其中,host1、host2、host3是MongoDB集群中的主机名,port1、port2、port3是MongoDB端口号,databaseName是要连接的数据库名称,yourReplicaSetName是MongoDB集群的副本名称。 3. 创建MongoDB集群配置类:创建一个MongoDB集群配置类,以便将MongoDB集群连接设置传递给MongoDB客户端。例如: ``` @Configuration public class MongoConfig { @Value("${spring.data.mongodb.uri}") private String mongoUri; @Bean public MongoClient mongoClient() { return MongoClients.create(mongoUri); } @Bean public MongoTemplate mongoTemplate() throws Exception { return new MongoTemplate(mongoClient(), "databaseName"); } } ``` 在这个配置类中,我们注入了MongoDB集群连接URI,并使用它来创建MongoDB客户端和MongoDB模板。 4. 测试MongoDB集群连接:可以编写一个简单的测试类来测试MongoDB集群连接是否正常工作。例如: ``` @SpringBootTest public class MongoClusterTest { @Autowired private MongoTemplate mongoTemplate; @Test public void testMongoTemplate() { mongoTemplate.createCollection("testCollection"); List<String> collections = mongoTemplate.getCollectionNames(); System.out.println(collections); mongoTemplate.dropCollection("testCollection"); } } ``` 这个测试类将创建一个名为“testCollection”的集合,并在控制台上输出所有集合名称。最后,它将删除“testCollection”集合。 以上就是在Spring Boot应用程序中配置MongoDB集群的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值