一、基本环境:

mongdb3.0.5数据库

spring-data-mongodb-1.7.2.jar

mongo-java-driver-3.0.2.jar

linux-redhat6.3

tomcat7

二、搭建mongodb副本集:

1、  分别在三台linux系统机上安装mongodb,(为避免和机器上原有的mongodb端口冲突,这里设为57017):

192.168.0.160

192.168.0.211(192.168.0.33上的虚拟机)

192.168.0.213(192.168.0.4上的虚拟机)

安装步骤见安装文档,注意先不要更改用户验证方式。

2、  以副本集的方式启动三个mongodb,只是在单机mongodb启动的基础上加入副本集参数—replSet,例如启动160的:

/home/admin/mongodb3051/mongodb305/bin/mongod –f/home/admin/mongo3051/conf/mongodb.conf –replSet reptest

其中,reptest是指定的副本集名称,另外两台机也也要和这个一样。如:

/mongodb3051/mongodb305/bin/mongod –f/mongodb3051/conf/mongodb.conf –replSet repTest

3、  在任意一台机上配置副本集,这里在160上配置:

(1)、进入160上的mongodb sehll:

/home/admin/mongodb3051/mongodb305/bin/mongo–port 57017

(2)、切换到admin数据库:

use admin

(3)、配置副本集:

config={_id:”reptest”,members:[{_id:0,host:”192.168.0.160:57017”},{_id:1,host:”192.168.0.211:57017”},{_id:,host:”192.168.0.213:57017”}]}

(4)、加载副本集配置文件:

rs.initiate(config)

(5)、查看副本集状态:

rs.status()

会是主服务器,显示PRIMARY,如果是,就直接进行以下操作,如果不是,就切换到PRIMARY上进行以下操作;

(6)、增加用户:

db.createUser({“user”:”admin”,”pwd”:”admin”,”roles”:[“root”]})

(7)、更改用户验证方式:

varschema=db.system.version.findOne({“_id”:”authSchema”})

schema.currentVersion=3

db.system.version.save(schema)

(8)、删除用户:

db.dropUser(“admin”)

(9)、重新建立用户(系统中和上边建立的用户验证方式不一样):

db.createUser({“user”:”admin”,”pwd”:”admin”,”roles”:[“root”]})

(10)、关闭三个mongodb:

(11)、在160的数据库的data目录中建立keyFile文件:

cd/home/admin/mongodb3051/data

openssl rand –base64753 > keyFile

(12)、给keyFile文件设置600权限(权限):

chmod 600keyFile

(13)、把这个keyFile文件上传到另外两台机上mongodb的data目录中:

scp –r keyFile root@192.168.0.211/mongodb3051/data

scp –r keyFile root@192.168.0.213/mongodb3051/data

(14)、在mongodb.conf文件中加入keyFile,例如160:

keyFile=/home/admin/mongodb3051/data/keyFile

(15)、重新启动mongodb,使用replSet和auth参数:

(16)、在priority中设置副本集成员的优先级,给160设置最高优先级,优先级默认都是1:

config=rs.conf()

config.members[0].priority=2

rs.reconfig(config)

这样的话,只要160的mongodb是开着的,那么主服务器就会是160

三、Spring中连接副本集的配置:

<?xml version="1.0"encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:p="http://www.springframework.org/schema/p"

xmlns:mongo="http://www.springframework.org/schema/data/mongo"

xsi:schemaLocation="http://www.springframework.org/schema/beans

            http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

            http://www.springframework.org/schema/data/mongo

         http://www.springframework.org/schema/data/mongo/spring-mongo.xsd">

<!-- Factory bean that creates the Mongoinstance -->

<mongo:mongo-client replica-set="192.168.91.27:27017" credentials="admin:admin@admin" id="mongo">

<mongo:client-options write-concern="SAFE" connections-per-host="100"

threads-allowed-to-block-for-connection-multiplier="50"

/>

</mongo:mongo-client>

<mongo:db-factory  id="mongoDbFactory"dbname="admin" mongo-ref="mongo"/>

<bean id="mongoTemplate"class="org.springframework.data.mongodb.core.MongoTemplate">

<constructor-arg name="mongoDbFactory" ref="mongoDbFactory" />

</bean>

</beans>

四、java中连接副本集的代码:

public DB getMongoDB() {

if (mongoDB == null) {

try {

ServerAddress sa = new ServerAddress("192.168.0.160", 57017);

ServerAddress sa1 = new ServerAddress("192.168.0.211", 57017);

ServerAddress sa2 = new ServerAddress("192.168.0.213", 57017);

List<ServerAddress> sends = new ArrayList<ServerAddress>();

sends.add(sa);

sends.add(sa1);

sends.add(sa2);

List<MongoCredential> mongoCredentialList = new ArrayList<MongoCredential>();

mongoCredentialList.add(MongoCredential.createMongoCRCredential("admin", "admin","admin".toCharArray()));

mongoDB = new MongoClient(sends,mongoCredentialList).getDB("admin");

} catch (Exception e) {

throw new RuntimeException("连接MongoDB数据库错误", e);

}

}

return mongoDB;

}

Mongodb集群搭建及spring和java连接配置记录的更多相关文章

  1. Mongodb集群搭建之 Replica Set

    Mongodb集群搭建之 Replica Set Replica Set 中文翻译叫做副本集,不过我并不喜欢把英文翻译成中文,总是感觉怪怪的.其实简单来说就是集群当中包含了多份数据,保证主节点挂掉了, ...

  2. Mongodb 集群搭建以及常见错误

    Mongodb 集群搭建以及常见错误 1 关于Replica Sets +Sharding(主从复制加分片)搭建,不这详细去说,网上有很多,大部分的例子就三台服务器之间做主从复制,分2个shard,架 ...

  3. MongoDB集群搭建-副本集

    MongoDB集群搭建-副本集 概念性的知识,可以参考本人博客地址: 一.Master-Slave方案: 主从: 二.Replica Set方案: 副本集: 步骤:(只要按步骤操作,100%成功) 1 ...

  4. MongoDB集群搭建-分片

    MongoDB集群搭建-分片 一.场景: 1,机器的磁盘不够用了.使用分片解决磁盘空间的问题. 2,单个mongod已经不能满足写数据的性能要求.通过分片让写压力分散到各个分片上面,使用分片服务器自身 ...

  5. mongodb集群搭建过程记录

    mongodb集群搭建花费比较长的时间,在此记录下过程,方便以后使用 一 软件环境 系统:ubuntu 18.04,mongodb 社区版4.2 https://docs.mongodb.com/ma ...

  6. mongodb集群搭建(分片+副本)开启安全认证

    关于安全认证得总结: 这个讲述的步骤也是先创建超管用户,关闭服务,然后生成密钥文件,开启安全认证,启动服务 相关概念 先来看一张图: 从图中可以看到有四个组件:mongos.config server ...

  7. Mongodb集群搭建的三种方式

    转自:http://blog.csdn.net/luonanqin/article/details/8497860 MongoDB是时下流行的NoSql数据库,它的存储方式是文档式存储,并不是Key- ...

  8. Mongodb集群搭建

    搭建高可用Mongodb集群 http://www.lanceyan.com/category/tech/mongodb/page/2 再看MongoDB副本集  http://blog.itpub. ...

  9. Mongodb集群搭建之 Sharding+ Replica Sets集群架构(2)

    参考http://blog.51cto.com/kaliarch/2047358 一.概述 1.1 背景 为解决mongodb在replica set每个从节点上面的数据库均是对数据库的全量拷贝,从节 ...

随机推荐

  1. DB2中的ROW_NUMBER() OVER()函数用法

      ROW_NUMBER() OVER()大概有俩方面的作用 1,分页, 并返回分页结果集.2,是对数据进行处理 分组 db2的分页: select tmp.* from ( SELECT rownu ...

  2. List-ApI及详解

    1.API : add(Object o) remove(Object o) clear() indexOf(Object o) get(int i) size() iterator() isEmpt ...

  3. System.Web.UI.ScriptManager.RegisterStartupScript(语句末尾加分号,不然可能会造成语句不执行)

    System.Web.UI.ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "testKey", &q ...

  4. spark_updateStateByKey

    java核心代码 JavaPairDStream<String, Integer> wordCounts = pair.updateStateByKey(new Function2< ...

  5. Linux常用配置文件解析

    网络相关配置文件 1./etc/sysconfig/network-scripts/ifcfg-ethx 网络参数IP/子网掩码/广播地址等的配置(重启有效) 2./etc/resolv.conf   ...

  6. .c和.h文件的区别(转载)

    一个简单的问题:.c和.h文件的区别学了几个月的C语言,反而觉得越来越不懂了.同样是子程序,可以定义在.c文件中,也可以定义在.h文件中,那这两个文件到底在用法上有什么区别呢? 2楼:子程序不要定义在 ...

  7. (转) 实时SLAM的未来及与深度学习的比较

          首页 视界智尚 算法技术 每日技术 来打我呀 注册     实时SLAM的未来及与深度学习的比较 The Future of Real-Time SLAM and “Deep Learni ...

  8. excel让每个单元格的宽度随着字体自动变动的两种方式(有更好方法的大神,请忽略,求评论下)

    1.打开在EXCEL的工作表,点击工作表左上方的方框,选中整个工作表,将鼠标一致A列的右边线处,也就是A列和B列中间的分界线处,光标会变成十字,鼠标左键双击,列宽会调整到最恰当处.截图如下

  9. Tkinter

    单个选项 from Tkinter import * root = Tk() v = IntVar() Radiobutton(root, text="One", variable ...

  10. 【转】windows7的桌面右键菜单的“新建”子菜单,在注册表哪个位置,如何在“新建"里面添加一个新项

    点击桌面,就会弹出菜单,然后在“新建”中就又弹出可以新建的子菜单栏.office与txt 的新建都是在这里面的.我想做的事情是:在右键菜单的“新建” 中添加一个“TQ文本”的新建项,然后点击它之后,桌 ...