SpringBoot AOP Mysql主从复制

本文介绍了如何利用Spring Boot的AOP和AbstractRoutingDataSource类进行MySQL主从复制的数据源路由选择。详细步骤包括配置主从数据源、定义HandleDataSource、实现路由数据源、配置数据源和路由、创建DataSource注解、配置AOP以及在Mapper接口上使用注解指定数据源。最终通过AOP动态选择合适的数据源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringBoot AOP Mysql主从复制

1.原理
借助spring的【org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource】这个抽象类实现,来进行·数据源的路由,并通过Aop 进行路由选择。
2 配置主从数据源

###datasource
spring.datasource.master.driverClassName = com.mysql.jdbc.Driver
#多数据源时,为master
spring.datasource.master.url = jdbc:mysql://192.168.18.131:3339/usermanage
spring.datasource.master.username = root
spring.datasource.master.password = 123456

spring.datasource.slave.driverClassName= com.mysql.jdbc.Driver
多数据源时,为slave
spring.datasource.slave.url = jdbc:mysql://192.168.18.131:3340/usermanage
spring.datasource.slave.username =root
spring.datasource.slave.password =123456
---------------------

3定义HandleDataSource类来获取当前线程的数据源类型


/**
 * Created by huanghengbo on 2019/8/21.
 */
public class HandleDataSource {
   
   
    public static final ThreadLocal<String> holder = new ThreadLocal<String>();

    /**
     * 绑定当前线程数据源
     *
     * @param key
     */
    public static void putDataSource(String datasource)
    {
   
   
        holder.set(datasource);
    }

    /**
     * 获取当前线程的数据源
     *
     * @return
     */
    public static String getDataSource()
    {
   
   
        return holder.get();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值