这是去年写的一篇文档,最近突然发现并没有发不出来,因此现在补上,希望能对某些朋友有所帮助。因为当时记录时没有截图,因此这里看起来可能就比较单调。

一、基本环境:

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上的虚拟机)

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

(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:

db.shutDownServer()或者kill命令

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

cd /home/admin/mongodb3051/data
openssl  rand  –base64 753  >  keyFile

权限):

chmod 600 keyFile

(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参数:

/home/admin/mongodb3051/mongodb305/bin/mongod –f /home/admin/mongo3051/conf/mongodb.conf --replSet reptest  --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.0.160:57017" 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>

只需要配置一个ip,就会自动切换。用户验证格式:username:password@dbname。

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

public DB getMongoDB() {
      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()));
        DB mongoDB = new MongoClient(sends,mongoCredentialList).getDB("admin");
      } catch (Exception e) {
        throw new RuntimeException("连接MongoDB数据库错误", e);
      }
    return mongoDB;
  }

用户验证格式是:username,dbname,password

Mongodb3.0.5副本集搭建及spring和java连接副本集配置的更多相关文章

  1. Mongodb集群搭建及spring和java连接配置记录

    一.基本环境: mongdb3.0.5数据库 spring-data-mongodb-1.7.2.jar mongo-java-driver-3.0.2.jar linux-redhat6.3 tom ...

  2. Hadoop(五)搭建Hadoop客户端与Java访问HDFS集群

    阅读目录(Content) 一.Hadoop客户端配置 二.Java访问HDFS集群 2.1.HDFS的Java访问接口 2.2.Java访问HDFS主要编程步骤 2.3.使用FileSystem A ...

  3. 通过jedis连接redis单机成功,使用redis客户端可以连接集群,但使用JedisCluster连接redis集群一直报Could not get a resource from the pool

    一,问题描述: (如题目)通过jedis连接redis单机成功,使用JedisCluster连接redis集群一直报Could not get a resource from the pool 但是使 ...

  4. Java连接Elasticsearch集群

    package cn.test; import java.net.InetAddress; import java.net.UnknownHostException; import org.elast ...

  5. Java 连接MongoDB集群的几种方式

    先决条件 先运行mongodb肯定是必须的,然后导入以下包: import com.mongodb.MongoClient; import com.mongodb.MongoClientURI; im ...

  6. Java连接redis集群操作存储、删除以及获取值

    pom文件添加: <!-- https://mvnrepository.com/artifact/redis.clients/jedis --> <dependency> &l ...

  7. spring boot JedisCluster连接redis集群配置

    配置文件 配置类 构造的时候, 可以看一下, 只有Set<HostAndPort> 参数是必须的 做了一层封装, 更方便使用 结果

  8. java 连接 redis集群时报错:Could not get a resource from the pool

    由于弄这个的时候浪费了太多的时间,所以才记录下这个错,给大伙参考下 检查了一下,配置啥的都没问题的,但在redis集群机器上就可以,错误如下: Exception in thread "ma ...

  9. ElasticSearch(四):使用Java连接ElasticSearch集群

    public class ESIndexMapping { private static String host="192.168.56.3"; // 服务器地址 private ...

随机推荐

  1. GitHub For Beginners: Commit, Push And Go

    In Part 1 of this two-part GitHub tutorial, we examined the main uses for GitHub and bega5n the proc ...

  2. Object对象和function对象

    Obejct对象 1.ECMAScript 中的 Object 对象与 Java 中的 java.lang.Object 相似. 2.ECMAScript中的所有对象都由Object对象继承而来,Ob ...

  3. Jmeter之http性能测试实战 非GUI模式压测 NON-GUI模式 结果解析TPS——干货(十一)

    性能测试计划 性能测试用例 录制脚本 性能测试结果 性能测试报告 性能测试监控报告 准备工作 从脚本已录制成功之后开始进行压测 安装Jmeter拓展插件 查看 Transactions per Sec ...

  4. [DeeplearningAI笔记]ML strategy_1_3可避免误差与改善模型方法

    机器学习策略 ML strategy 觉得有用的话,欢迎一起讨论相互学习~Follow Me 1.8 为什么是人的表现 今天,机器学习算法可以与人类水平的表现性能竞争,因为它们在很多应用程序中更有生产 ...

  5. maven项目引入sqljdbc4 找不到包的完美 解决方案。

    今天碰到了这个问题,解决了,顺便做一下记录.首先来 重现 一下这个问题,maven install报错,说 找不到这个包,但是其实 我已经安装了. 我们 再来 看看 maven本地仓库里面有 什么,这 ...

  6. React 16.3来了:带着全新的Context API

    文章概览 React在版本16.3-alpha里引入了新的Context API,社区一片期待之声.我们先通过简单的例子,看下新的Context API长啥样,然后再简单探讨下新的API的意义. 文中 ...

  7. Vsftp的PASV mode(被动模式传送)和Port模式解释

    什么叫做PASV mode(被动模式传送)?他是如何工作的?FTP的连接一般是有两个连接的,一个是客户程和服务器传输命令的,另一个是数据传送的连接.FTP服务程序一般会支持两种不同的模式,一种是Por ...

  8. selenium打开chrome浏览器代码

    import os from selenium import webdriver chromedriver = "C:\Program Files (x86)\Google\Chrome\A ...

  9. CF 235C. Cyclical Quest [后缀自动机]

    题意:给一个主串和多个询问串,求询问串的所有样子不同的周期同构出现次数和 没有周期同构很简单就是询问串出现次数,|Right| 有了周期同构,就是所有循环,把询问串复制一遍贴到后面啊!思想和POJ15 ...

  10. 使用angular/react/vue实现相同的面试题组件

    面试题要求如下所示 1.angular: <!DOCTYPE html><html lang="en"><head> <meta char ...