Mongodb3.0.5副本集搭建及spring和java连接副本集配置

简介: 这是去年写的一篇文档,最近突然发现并没有发不出来,因此现在补上,希望能对某些朋友有所帮助。因为当时记录时没有截图,因此这里看起来可能就比较单调。一、基本环境:mongdb3.0.5数据库spring-data-mongodb-1.7.2.jarmongo-java-driver-3.0.2.jarlinux-redhat6.3tomcat7 二、搭建mongodb副本集:1

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


一、基本环境:

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

每个mongodb的安装这里就不细说了,可以参考我的安装方面的文档,注意先不要更改用户验证方式。另外,这里如果没有三台机,也可以只用一台机开三个端口,同时准备三个数据存储目录。


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上的mongo 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()

   正常情况下可以看到160会是主服务器,显示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


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

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

目录
相关文章
|
3月前
|
前端开发 Java 应用服务中间件
《深入理解Spring》 Spring Boot——约定优于配置的革命者
Spring Boot基于“约定优于配置”理念,通过自动配置、起步依赖、嵌入式容器和Actuator四大特性,简化Spring应用的开发与部署,提升效率,降低门槛,成为现代Java开发的事实标准。
|
4月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
667 5
|
4月前
|
Java 关系型数据库 MySQL
Spring Boot自动配置:魔法背后的秘密
Spring Boot 自动配置揭秘:只需简单配置即可启动项目,背后依赖“约定大于配置”与条件化装配。核心在于 `@EnableAutoConfiguration` 注解与 `@Conditional` 系列条件判断,通过 `spring.factories` 或 `AutoConfiguration.imports` 加载配置类,实现按需自动装配 Bean。
|
4月前
|
人工智能 Java 开发者
【Spring】原理解析:Spring Boot 自动配置
Spring Boot通过“约定优于配置”的设计理念,自动检测项目依赖并根据这些依赖自动装配相应的Bean,从而解放开发者从繁琐的配置工作中解脱出来,专注于业务逻辑实现。
1521 0
|
4月前
|
传感器 Java 数据库
探索Spring Boot的@Conditional注解的上下文配置
Spring Boot 的 `@Conditional` 注解可根据不同条件动态控制 Bean 的加载,提升应用的灵活性与可配置性。本文深入解析其用法与优势,并结合实例展示如何通过自定义条件类实现环境适配的智能配置。
217 0
探索Spring Boot的@Conditional注解的上下文配置
|
4月前
|
负载均衡 监控 Java
Spring Cloud Gateway 全解析:路由配置、断言规则与过滤器实战指南
本文详细介绍了 Spring Cloud Gateway 的核心功能与实践配置。首先讲解了网关模块的创建流程,包括依赖引入(gateway、nacos 服务发现、负载均衡)、端口与服务发现配置,以及路由规则的设置(需注意路径前缀重复与优先级 order)。接着深入解析路由断言,涵盖 After、Before、Path 等 12 种内置断言的参数、作用及配置示例,并说明了自定义断言的实现方法。随后重点阐述过滤器机制,区分路由过滤器(如 AddRequestHeader、RewritePath、RequestRateLimiter 等)与全局过滤器的作用范围与配置方式,提
Spring Cloud Gateway 全解析:路由配置、断言规则与过滤器实战指南
|
5月前
|
安全 算法 Java
在Spring Boot中应用Jasypt以加密配置信息。
通过以上步骤,可以在Spring Boot应用中有效地利用Jasypt对配置信息进行加密,这样即使配置文件被泄露,其中的敏感信息也不会直接暴露给攻击者。这是一种在不牺牲操作复杂度的情况下提升应用安全性的简便方法。
1087 10
Java相关配置
Java相关配置
1380 0
|
3月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
202 1
|
3月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
229 1

推荐镜像

更多