开源 Spring Boot 中 Mongodb 多数据源扩展框架
原创 尹吉欢 猿天地 2019-04-25
在日常工作中,我们通过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. 7. spring.data.mongodb.test2MongoTemplate.host=localhost 8. spring.data.mongodb.test2MongoTemplate.port=27017 9. spring.data.mongodb.test2MongoTemplate.database=test2 10. spring.data.mongodb.test2MongoTemplate.username=yinjihuan 11. spring.data.mongodb.test2MongoTemplate.password=123456
操作哪个数据库就注入哪个对象:
1. @Autowired 2. @Qualifier("testMongoTemplate") 3. private MongoTemplate testMongoTemplate; 4. 5. @Autowired 6. @Qualifier("test2MongoTemplate") 7. 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+课程
尹吉欢
我不差钱啊
喜欢作者