若依框架连接多个库配置

一个学习加记录的博客!

一、第一步

在application-druid.yml里配置多个库的连接设置

# 主库数据源
master:
url: jdbc:mysql://111.111.111.1111:3306/test?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
username: root
password: root

# 从库数据源1
slave:
# 从数据源开关/默认关闭
enabled: true
url: jdbc:mysql://111.111.111.1111:3306/test1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
username: root
password: root

# 从库数据源2
slaveData:
# 从数据源开关/默认关闭
enabled: true
url: jdbc:mysql://111.111.111.1111:3306/test3?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
username: root
password: root

# 从库数据源3
...........................................................................

2.第二步

在ruoyi-common下的DataSourceType里配置数据源
在这里插入图片描述

3.第三步

修改ruoyi-framework下的DruidConfig文件

	@Bean
    @ConfigurationProperties("spring.datasource.druid.slave") //这里就是从库1
    @ConditionalOnProperty(prefix = "spring.datasource.druid.slave", name = "enabled", havingValue = "true")
    public DataSource slaveDataSource(DruidProperties druidProperties)
    {
        DruidDataSource dataSource = DruidDataSourceBuilder.create().build();
        return druidProperties.dataSource(dataSource);
    }
    
	@Bean
    @ConfigurationProperties("spring.datasource.druid.slaveData") //这里就是从库2
    @ConditionalOnProperty(prefix = "spring.datasource.druid.slaveData", name = "enabled", havingValue = "true")
    public DataSource slaveData(DruidProperties druidProperties)
    {
        DruidDataSource dataSource = DruidDataSourceBuilder.create().build();
        return druidProperties.dataSource(dataSource);
    }

    @Bean(name = "dynamicDataSource")
    @Primary
    public DynamicDataSource dataSource(DataSource masterDataSource)
    {
        Map<Object, Object> targetDataSources = new HashMap<>();
        targetDataSources.put(DataSourceType.MASTER.name(), masterDataSource);
        setDataSource(targetDataSources, DataSourceType.SLAVE.name(), "slaveDataSource");//从库1
        setDataSource(targetDataSources, DataSourceType.SLAVEDATA.name(), "slaveData");//从库2
        return new DynamicDataSource(masterDataSource, targetDataSources);
    }

3.最后一步

在service上加上@DataSource(value = DataSourceType.MASTER)这个注解 DataSourceType.就是你想要连的那一个库
在这里插入图片描述
注:如果需要生成代码的也需要用到注解,生成那个库的表就用那个,GenController
在这里插入图片描述

多租户是一种架构设计模式,它允许将单个应用程序的实例分割成多个独立的租户,每个租户都拥有自己的数据和配置。实现多租户框架有多种方式,以下是其中一种常见的方法: 1. 数据隔离:最重要的一点是确保不同租户的数据相互隔离,每个租户的数据都应该存储在独立的数据库中,或者通过数据库中的某种方式进行分区。这可以防止一个租户的数据被其他租户访问到。 2. 身份验证和授权:需要对不同租户进行身份验证和授权,以确保只有合法的租户才能访问其对应的数据和功能。可以使用标准的身份验证机制,如用户名密码或令牌,并在访问控制层面对用户进行权限控制。 3. 配置管理:每个租户可能有不同的配置需求,如界面定制、业务规则等。在多租户框架中,需要提供一种机制来管理和应用这些配置,以便满足不同租户的个性化需求。 4. 多租户路由:为了能够将请求正确地路由到对应的租户实例,需要在框架中实现多租户路由功能。这可以通过在请求中包含租户标识符,并在路由层面根据标识符将请求发送到正确的租户实例。 5. 扩展性和可伸缩性:多租户框架需要具备良好的扩展性和可伸缩性,以应对不同租户的需求和变化。这包括在硬件资源、网络连接和计算能力方面能够进行动态调整,以适应不同租户的负载变化。 需要注意的是,以上只是一种常见的多租户实现方式,具体实施时还需要考虑具体业务需求和技术架构。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

代码百小生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值