暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

开源 Spring Boot 中 Mongodb 多数据源扩展框架

猿天地 2019-04-25
461

在日常工作中,我们通过Spring Data Mongodb来操作Mongodb数据库,在Spring Boot中只需要引入spring-boot-starter-data-mongodb即可。

然后配置连接信息如下:

  1. spring.data.mongodb.uri=mongodb://localhost:27017/test

或者

  1. pring.data.mongodb.authentication-database= # Authentication database name.

  2. spring.data.mongodb.database=test # Database name.

  3. spring.data.mongodb.host=localhost # Mongo server host.

  4. spring.data.mongodb.password= # Login password of the mongo server.

  5. spring.data.mongodb.port=27017 # Mongo server port.

  6. spring.data.mongodb.username= # Login user of the mongo server.

spring-boot-starter-data-mongodb提供了两种配置方式,分别是uri和host方式。uri可以配置多个地址,也就是集群的配置方式。host只能连接一个节点。

当在一个项目中需要连接多个数据库的时候,spring-boot-starter-data-mongodb的自动配置无法满足需求,所以我这边封装了一个多数据源的Mongodb spring-boot-starter。

之前关于多数据源的使用写了篇文章:spring-boot-starter-mongodb-pool

由于是第一个版本,有些东西没考虑到,最近更新了下,加了一些内容,升级到Spring Boot 2.0版本。

Github(请为我加颗星): https://github.com/yinjihuan/spring-boot-starter-mongodb-pool

首先还是简单的介绍下如何使用:

配置仓库地址:

  1. <repositories>

  2.    <repository>

  3.        <id>jitpack.io</id>

  4.        <url>https://www.jitpack.io</url>

  5.    </repository>

  6. </repositories>

配置最新版本,只支持Spring Boot 2.0

  1. <dependency>

  2.    <groupId>com.github.yinjihuan</groupId>

  3.    <artifactId>spring-boot-starter-mongodb-pool</artifactId>

  4.    <version>2.0.2</version>

  5. </dependency>

我这边配置方式也是uri和host两种,uri的话是只配置mongo节点信息,跟默认的uri格式不一样,不包含用户信息和连接参数。

URI配置集群

  1. spring.data.mongodb.testMongoTemplate.uri=localhost:27017,localhost:27018

  2. spring.data.mongodb.testMongoTemplate.username=yinjihuan

  3. spring.data.mongodb.testMongoTemplate.password=123456

  4. spring.data.mongodb.testMongoTemplate.database=test

  5. spring.data.mongodb.testMongoTemplate.authenticationDatabase=admin

HOST方式配置

  1. spring.data.mongodb.testMongoTemplate.host=localhost

  2. spring.data.mongodb.testMongoTemplate.port=27017

  3. spring.data.mongodb.testMongoTemplate.database=test

  4. spring.data.mongodb.testMongoTemplate.username=yinjihuan

  5. spring.data.mongodb.testMongoTemplate.password=123456

testMongoTemplate就是我们用来操作test数据库的MongoTemplate对象,框架会自动为你创建好,只需要注入使用就可以了。

  1. @Autowired

  2. @Qualifier("testMongoTemplate")

  3. private MongoTemplate testMongoTemplate;

多数据源就配置多个MongoTemplate就行了,比如:

  1. spring.data.mongodb.testMongoTemplate.host=localhost

  2. spring.data.mongodb.testMongoTemplate.port=27017

  3. spring.data.mongodb.testMongoTemplate.database=test

  4. spring.data.mongodb.testMongoTemplate.username=yinjihuan

  5. spring.data.mongodb.testMongoTemplate.password=123456


  6. spring.data.mongodb.test2MongoTemplate.host=localhost

  7. spring.data.mongodb.test2MongoTemplate.port=27017

  8. spring.data.mongodb.test2MongoTemplate.database=test2

  9. spring.data.mongodb.test2MongoTemplate.username=yinjihuan

  10. spring.data.mongodb.test2MongoTemplate.password=123456

操作哪个数据库就注入哪个对象:

  1. @Autowired

  2. @Qualifier("testMongoTemplate")

  3. private MongoTemplate testMongoTemplate;


  4. @Autowired

  5. @Qualifier("test2MongoTemplate")

  6. private MongoTemplate test2MongoTemplate;

更新说明

  • 支持Spring Boot 2.x版本 第一个版本1.0.0只支持Spring Boot的1.x版本

  • 加上用户认证配置 第一个版本1.0.0中没有加账号密码认证逻辑

  • 支持集群地址配置 通过uri配置集群信息

想了解框架实现细节的请移步:http://cxytiandi.com/course 或 查看原文

更多技术分享尽在微信群,加群请加我微信 jihuan900。


加入星球特权

1、实战分库分表中间件Sharding-JDBC

2、实战分布式任务调度框架Elastic Job

3、配置中心Apollo实战

4、高并发解决方案之缓存

5、更多课程等你来解锁,20+课程

点个“好看”你懂得!

文章转载自猿天地,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论