若依分离版后台框架配置不同驱动数据源


需求

项目后台需要用到MYSQL 与 PostgreSQL,所以需要配置多源数据库,而且两种数据库驱动不一致


一、参考若依官网文档

参考官网
根据官网对多元数据库配置的说明进行配置修改

二、具体配置

1.在application-druid.yml配置从库数据源

代码如下:

 datasource:
        type: com.alibaba.druid.pool.DruidDataSource
        druid:
            # 主库数据源
            master:
                url: jdbc:mysql://19.19.3.15:336/basic?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
                username: xx
                password: Xx
  # 从库数据源
            slave4:
                # 从数据源开关/默认关闭
                enabled: true
                url: jdbc:postgresql://19.24.112.29:1111/jszd?useUnicode=true&characterEncoding=utf8
                username: xx
                password: yy

注意要去掉diverClassName配置:
在这里插入图片描述

2.在DataSourceType类添加数据源枚举

代码如下:

package com.ruoyi.framework.aspectj.lang.enums;

/**
 * 数据源
 * 
 * @author ruoyi
 */
public enum DataSourceType
{
    /**
     * 主库
     */
    MASTER,
    /**
     * 从库
     */
    SLAVE4
}

3.在DruidConfig配置读取数据源,在DruidConfig类dataSource方法添加数据源

代码如下:

   @Bean
    @ConfigurationProperties("spring.datasource.druid.slave4")
    @ConditionalOnProperty(prefix = "spring.datasource.druid.slave4", name = "enabled", havingValue = "true")
    public DataSource slave4DataSource(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.SLAVE4.name(), "slave4DataSource");
        return new DynamicDataSource(masterDataSource, targetDataSources);
    }

在需要使用多数据源方法或类上添加@DataSource注解,其中value用来表示数据源

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
若依框架是一个基于Spring Boot、Spring Security、MyBatis-plus、Vue、Element-UI的快速开发平台,它采用前后端分离的方式进行开发。它包含了许多常用的功能,如用户管理、角色管理、菜单管理、部门管理、字典管理、定时任务等等,并提供了代码生成器、日志管理、在线用户管理等扩展功能,可以快速搭建企业级应用。\[1\] 若依框架的前后端分离包含以下几个模块: - ruoyi-admin: 后台服务,用于启动和配置数据库。 - ruoyi-common: 通用工具,包括工具类、异常处理、过滤器等。 - ruoyi-framework: 框架核心,包括aop切面、系统配置、拦截器等。 - ruoyi-generator: 代码生成器,通过页面操作生成代码。 - ruoyi-quartz: 定时任务模块。 - ruoyi-system: 系统模块,包含系统代码。 - ruoyi-ui: 后台管理系统的页面代码,采用Vue和Element UI作为前端框架。\[2\] 要搭建若依框架前后端分离,需要满足以下环境要求: - JDK >= 1.8 (推荐1.8本) - MySQL >= 5.7.0 (推荐5.7本) - Maven >= 3.0 - Node >= 12.0 - Redis >= 5\[2\] 在搭建环境完成后,可以执行相应的命令来启动若依框架。执行成功后,可能会遇到数据表不显示的问题。这时需要在数据库中刷新表,可以在表上点击鼠标右键,选择刷新,即可显示出所有的表。\[3\] #### 引用[.reference_title] - *1* [若依框架——前后端分离](https://blog.csdn.net/moran_3346/article/details/131803190)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [使用若依框架RuoYi前后端分离(超详细步骤)](https://blog.csdn.net/thewhat/article/details/131264175)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值