mysql切换数据库⽅案
业务场景
在SAAS模式下,不同的租户需要切换数据库,我们可以使⽤动态数据源,动态数据源有个问题,就是需要对每⼀个数据库创建⼀个连接池,在初始化的时候初始化这些连接池,
如果多台应⽤服务器的情况,每⼀台应⽤服务器都需要创建连接池。
⽐如有10台应⽤服务器,每台创建10个链接池。每个连接池200个链接。
那么每台应⽤服务器的链接数为 10*200 两千个链接。
数据库也会有很多的链接。如果应⽤服务器更多的情况,那么链接管理这块都会占⽤很多的服务器资源,如果服务器更多的情况,则可能报错。
解决⽅案
我们在同⼀个数据库上创建相同的数据库,那么我们就不需要使⽤动态数据源,我们可以使⽤切换数据库的⽅式来实现。
jdbctemplate查询一条数据
实现原理很简单 use db1,use db2 这样就很容易进⾏数据库切换了。
切换⽅法
使⽤AOP拦截来实现:
创建⼀个切⾯:
public class DbSelectAspect {
public void doSelectDb(JoinPoint point ){
JdbcTemplate Bean(JdbcTemplate.class);
}
}
这⾥我代码写死了。
然后配置好AOP切⾯就可以了。
程序数据库连接配置如下:
db.url=jdbc:mysql://192.168.1.88:4000/?useUnicode=true&characterEncoding=utf-8
不需要指定数据库名,根据切⾯进⾏数据库切换就可以了。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论