一、基本环境:

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. Codeforces Round #277 (Div. 2) A B C 水 模拟 贪心

    A. Calculating Function time limit per test 1 second memory limit per test 256 megabytes input stand ...

  2. html部分---a标签的用法、放置图片与表格;

    a标签的用法: 1.加链接  herf <a href="http://www.baidu.com">百度一下</a> 2.加载本地文件 <a hre ...

  3. linux 下查看机器是cpu是几核的(转)

    几个cpu more /proc/cpuinfo |grep "physical id"|uniq|wc -l 每个cpu是几核(假设cpu配置相同) more /proc/cpu ...

  4. js的数组操作 splice

    原文:点击打开链接 1.作用:从指定位置删除部分元素并增加新的元素                1.1.该方法返回值是被删除的元素组成的数组                1.2.splice是直接 ...

  5. phpstorm用正则删除PHP代码空行小技巧

    有很多小伙伴会遇到代码空行特别多,但是一行一行删除肯定很烦躁,这时候就需要用到批量删除空行. 怎么批量删除空行呢? 我的办法是用正则把所有空行找到,然后一键全部替换. 首先把Match Case和Re ...

  6. awesome-very-deep-learning

    awesome-very-deep-learning is a curated list for papers and code about implementing and training ver ...

  7. IntelliJ IDEA currently

    https://www.jetbrains.com/help/idea/2016.2/creating-a-project-from-scratch.html https://www.jetbrain ...

  8. Linux中的15个‘echo’ 命令实例

    echo是一种最常用的与广泛使用的内置于Linux的bash和C shell的命令,通常用在脚本语言和批处理文件中来在标准输出或者文件中显示一行文本或者字符串. echo命令的语法是: echo [选 ...

  9. 【Hadoop】搭建完全分布式的hadoop

    博客已转移,请借一步说话! http://www.weixuehao.com/archives/577 下面博文已更新,请移步 ↑ 用于测试,我用4台虚拟机搭建成了hadoop结构 我用了两个台式机. ...

  10. linux下文件合并、分割、去重

    1.文件合并 1.1文件上下合并 cat f1 f2> muti  (将文件f1.f2合并成文件muti,f1在上,f2在下) 1.2左右合并 paste f1 f2 > muti  (将 ...