SpringBoot运行时如何实现动态增加数据库连接池?

2026-06-09 04:072阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计733个文字,预计阅读时间需要3分钟。

SpringBoot运行时如何实现动态增加数据库连接池?

此方案适用于解决Spring Boot项目运行时动态添加数据源,非静态切换多个数据源!

一、多个数据源应用场景:

1.配置文件配置多数据源,例如默认数据源:master,数据源1:salve1... 运行时动态切换数据源。

此方案适用于解决springboot项目运行时动态添加数据源,非静态切换多数据源!!!

一、多数据源应用场景:

1.配置文件配置多数据源,如默认数据源:master,数据源1:salve1...,运行时动态切换已配置的数据源(master、salve1互相切换),无法在运行时动态添加配置文件中未配置的数据源。

2.配置一个默认数据源,运行时动态添加新数据源使用(本博客适用于此场景)

二、解决方案:

Spring提供了AbstractRoutingDataSource用于动态路由数据源,第一种场景继承AbstractRoutingDataSource类并覆写其protected abstract Object determineCurrentLookupKey()即可;

SpringBoot运行时如何实现动态增加数据库连接池?

而第二种场景我们直接覆写protected DataSource determineTargetDataSource方法即可。原理可看下AbstractRoutingDataSource对应源码,比较简单,不做赘述。

阅读全文

本文共计733个文字,预计阅读时间需要3分钟。

SpringBoot运行时如何实现动态增加数据库连接池?

此方案适用于解决Spring Boot项目运行时动态添加数据源,非静态切换多个数据源!

一、多个数据源应用场景:

1.配置文件配置多数据源,例如默认数据源:master,数据源1:salve1... 运行时动态切换数据源。

此方案适用于解决springboot项目运行时动态添加数据源,非静态切换多数据源!!!

一、多数据源应用场景:

1.配置文件配置多数据源,如默认数据源:master,数据源1:salve1...,运行时动态切换已配置的数据源(master、salve1互相切换),无法在运行时动态添加配置文件中未配置的数据源。

2.配置一个默认数据源,运行时动态添加新数据源使用(本博客适用于此场景)

二、解决方案:

Spring提供了AbstractRoutingDataSource用于动态路由数据源,第一种场景继承AbstractRoutingDataSource类并覆写其protected abstract Object determineCurrentLookupKey()即可;

SpringBoot运行时如何实现动态增加数据库连接池?

而第二种场景我们直接覆写protected DataSource determineTargetDataSource方法即可。原理可看下AbstractRoutingDataSource对应源码,比较简单,不做赘述。

阅读全文