背景:

  之前项目里面把quartz相关的表跟业务数据库(涉及系统业务的库)融合在一起,后面需要把quartz单独拎出来放在一个数据库里面,

旧的数据源配置(application.properties),无其他,程序可以跑:    

spring.datasource.password=root
spring.datasource.username=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/fdata?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&zeroDateTimeBehavior=convertToNull&serverTimezone=GMT%2B8

  

  quartz独立数据库:

  1、增加quartz数据源配置(application.properties):

# quartz datasource conf
spring.datasource.quartz.password=root
spring.datasource.quartz.username=root
spring.datasource.quartz.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.quartz.url=jdbc:mysql://localhost:3306/fdata_quartz_test?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true

  

  2、增加DataSourceConfig类

加入了上述配置但是这样配置的datasouce并不生效,用的还是原来的数据库。查了些网上的资料,要给scheduler单独的dataSource,而且发现springboot文档里有

"To have Quartz use a DataSource other than the application’s main DataSource, declare a DataSource bean, annotating its @Bean method with @QuartzDataSource. Doing so ensures that the Quartz-specific DataSource is used by both the SchedulerFactoryBean and for schema initialization."

翻译:要让Quartz使用除应用程序主数据源之外的其他数据源,需要声明一个数据源bean,并用@QuartzDataSource注释它的@Bean方法。这样做可以确保SchedulerFactoryBean和模式初始化都使用特定于quartzs的数据源。

所以增加 DataSourceConfig类,如下:

 1 package com.xx.fdata.console.conf;
2 import javax.sql.DataSource;
3 import lombok.extern.slf4j.Slf4j;
4 import org.apache.commons.dbcp.BasicDataSource;
5 import org.springframework.boot.autoconfigure.quartz.QuartzDataSource;
6 import org.springframework.boot.context.properties.ConfigurationProperties;
7 import org.springframework.context.annotation.Bean;
8 import org.springframework.context.annotation.Configuration;
9 import org.springframework.context.annotation.Primary;
10
11 @Slf4j
12 @Configuration
13 public class DataSourceConfig {
14
15 /**
16 * 数据源配置的前缀,必须与application.properties中配置的对应数据源的前缀一致
17 */
18 private static final String BUSINESS_DATASOURCE_PREFIX = "spring.datasource";
19
20 private static final String QUARTZ_DATASOURCE_PREFIX = "spring.datasource.quartz";
21
22 @Primary
23 @Bean
24 @ConfigurationProperties(prefix = BUSINESS_DATASOURCE_PREFIX)
25 public BasicDataSource businessDataSource() {
26 return new BasicDataSource();
27 }
28
29 /**
30 * @QuartzDataSource 注解则是配置Quartz独立数据源的配置
31 */
32 @Bean
33 @QuartzDataSource
34 @ConfigurationProperties(prefix = QUARTZ_DATASOURCE_PREFIX)
35 public DataSource quartzDataSource(){
36 return new BasicDataSource();
37 }
38 }

  3、使用的是dbcp连接池,所以pom增加相应配置:

<dependency>
<groupId>commons-dbcp</groupId>
<artifactId>commons-dbcp</artifactId>
<version>1.4</version>
</dependency>

  

参考资料:

  1、Springboot quartz 独立数据源配置

  2、springboot 2.x 集成quartz持久化到一个单独的dataSource时遇到的坑

    

补充:

  完成需求过程中最初是在quartz.properties里面增加quartzDataSource内容,但是没什么效果,还是用的业务数据库,后面就有了前面提到的DataSourceConfig类的诞生:

spring.quartz.properties.org.quartz.jobStore.dataSource=quartzDataSource

#数据源
spring.quartz.properties.org.quartz.dataSource.quartzDataSource.driver=com.mysql.jdbc.Driver
spring.quartz.properties.org.quartz.dataSource.quartzDataSource.URL=jdbc:mysql://localhost:3306/fdata_quartz_test?useUnicode=true&amp;characterEncoding=UTF-8&amp;allowMultiQueries=true
spring.quartz.properties.org.quartz.dataSource.quartzDataSource.user=root
spring.quartz.properties.org.quartz.dataSource.quartzDataSource.password=root
spring.quartz.properties.org.quartz.dataSource.quartzDataSource.validationQuery=select 1

SpringBoot之独立quartz数据源的更多相关文章

  1. springboot 配置quart多数据源

    Springboot版本为2.1.6 多数据源配置使用druid进行配置,数据库使用的为Oracle11g,如果使用的是MySQL,直接将数据库的地址和驱动改一下即可 <parent> & ...

  2. springboot中实现多数据源

    springboot中实现多数据源 1.什么场景需要多数据源 业务读写分离 业务分库 业务功能模块拆分多库 2.常见的多数据源的方案 按照数据源分别把mapper和entity放到不同的package ...

  3. SpringBoot与动态多数据源切换

      本文简单的介绍一下基于SpringBoot框架动态多数据源切换的实现,采用主从配置的方式,配置master.slave两个数据库. 一.配置主从数据库 spring: datasource: ty ...

  4. SpringBoot定时任务 - 集成quartz实现定时任务(单实例和分布式两种方式)

    最为常用定时任务框架是Quartz,并且Spring也集成了Quartz的框架,Quartz不仅支持单实例方式还支持分布式方式.本文主要介绍Quartz,基础的Quartz的集成案例本,以及实现基于数 ...

  5. SpringBoot+MyBatis配置多数据源

    SpringBoot 可以支持多数据源,这是一个非常值得学习的功能,但是从现在主流的微服务的架构模式中,每个应用都具有唯一且准确的功能,多数据源的需求很难用到,考虑到实际情况远远比理论复杂的多,这里还 ...

  6. SpringBoot整合阿里Druid数据源及Spring-Data-Jpa

    SpringBoot整合阿里Druid数据源及Spring-Data-Jpa https://mp.weixin.qq.com/s?__biz=MzU0MDEwMjgwNA==&mid=224 ...

  7. springboot 中使用Druid 数据源提供数据库监控

    一.springboot 中注册 Servlet/Filter/Listener 的方式有两种,1 通过代码注册 ServletRegistrationBean. FilterRegistration ...

  8. SpringBoot整合Mybatis多数据源 (AOP+注解)

    SpringBoot整合Mybatis多数据源 (AOP+注解) 1.pom.xml文件(开发用的JDK 10) <?xml version="1.0" encoding=& ...

  9. SpringBoot和Mycat动态数据源项目整合

    SpringBoot项目整合动态数据源(读写分离) 1.配置多个数据源,根据业务需求访问不同的数据,指定对应的策略:增加,删除,修改操作访问对应数据,查询访问对应数据,不同数据库做好的数据一致性的处理 ...

  10. 三、SpringBoot 整合mybatis 多数据源以及分库分表

    前言 说实话,这章本来不打算讲的,因为配置多数据源的网上有很多类似的教程.但是最近因为项目要用到分库分表,所以让我研究一下看怎么实现.我想着上一篇博客讲了多环境的配置,不同的环境调用不同的数据库,那接 ...

随机推荐

  1. 关于echart折线图只有2个点时的平滑曲线问题

    问题描述: 折线图,设置平滑曲线,多个点时没有问题, 可当只有两个点(数据)的时候,这时光靠 smooth: true  就不管用了. 解决方法: 还另需设置   smoothMonotone 单调性 ...

  2. c#在代码中再次调用按钮点击事件

    在一个按钮事件中调用另一个按钮(button1)的点击事件,可以直接如下: button1.PerformClick() 也称之为 以编程方式调用按钮的click事件

  3. git reset 加不加 --hard的区别

    通常我们提交代码一般都是 git add ,git commit -m,   git push的这么个流程.添加到暂存区,提交到git库生成版本号,push到远程仓库以供他人可以使用.这是一个完整的且 ...

  4. java redis 获取key 剩余时间

    /** * 查询key的生命周期 * @param key redis 存数据的键 * @return 默认单位秒,也可以自行传入单位 */public long getKeyExpire(Strin ...

  5. heap 算法函数

    这一系列函数是在做 这道题 时发现的 这道题空间卡的很死,是不能用数组存下所有数字进行快排的 后来又尝试用 \(multiset\) 优化空间,发现不行,可能是 \(multiset\) 还有结构性存 ...

  6. node.js发送短信验证码(附带60秒倒计时插件)

    推荐一个简单且功能齐全的发送短信验证码接口1.安装下载后的SDK只包含一个zhenzisms.js文件,直接导入到工程中即可使用.下载 2.用法引入模块 const zhenzismsClient = ...

  7. 配置SASS过程

    1.首先在电脑上安装Node.js 2.其次在命令行配置npm,命令:npm init.运行后会创建一个package.json文件 3.然后输入命令配置npm中可以使用SASS的包,命令:npm i ...

  8. xmake构建C/C++编译环境

    1. xmake介绍 XMake是一个基于Lua的轻量级跨平台自动构建工具,支持在各种主流平台上构建项目 xmake的目标是开发者更加关注于项目本身开发,简化项目的描述和构建,并且提供平台无关性,使得 ...

  9. mysql自动生成时间

    字段类型: DATETIME 默认值: CURRENT_TIMESTAMP

  10. OPENSUSE网速慢

    无线网卡是Broadcom 4313,刚安装完opensuse,网速只有60Kb左右. 添加packman私有驱动后,网速才正常起来.