当前位置: 首页 > news >正文

多数据源 - dynamic-datasource | 集成 Quartz 及 ShardingJDBC

文章目录

  • 集成 Quartz
    • 引入 quartz-starter
    • 配置数据源参数
    • 创建任务
    • 配置 Quartz 实际使用的数据源
      • 方式一: 自定义 SchedulerFactoryBeanCustomizer
      • 方式二: 使用@QuartzDataSource来指明quartz数据源
  • 集成 ShardingJDBC
    • 项目引入 shardingsphere 依赖
    • 分别配置shardingjdbc和多数据源
    • 通过自定义 DynamicDataSourceProvider 完成与shardingsphere 的集成

🗯️ 上节回顾:上一节中,我们集成了 MyBatisPlus 及 p6spy。
👉 本节目标:实现第三方技术框架的集成,比如 Quartz、ShardingJDBC。
🚀 本节内容:

  • 集成 Quartz
  • 集成 ShardingJDBC

🔊 版本

  • JDK 17
  • Spring Boot 3.2.1
  • dynamic-datasource 4.3.0

集成 Quartz

Github:https://github.com/quartz-scheduler/quartz
文档:http://www.quartz-scheduler.org/
Quartz 是一个定时任务框架,常常用于解决分布式系统下的定时任务协调问题。
Quartz 常常需要独立运行在主业务数据库外, 在 springboot 场景中可以以下面方式运行。

引入 quartz-starter

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-quartz</artifactId>
</dependency>

配置数据源参数

根据需要可配置独立数据源的参数,或把 quartz 数据源也作为动态数据源的一个数据源。
一般来说二种方式根据需要选择一种即可,如果没有在动态数据源里需要切到 quartz 的的场景,建议独立配。

spring:datasource: #独立quartz配置username: rootpassword: 123456url: jdbc:mysql://39.108.158.138:3306/quartzdriver-class-name: com.mysql.cj.jdbc.Driverdynamic:datasource:master:username: sapassword: ""url: jdbc:h2:mem:testdriver-class-name: org.h2.Driverquartz:  #把quartz数据源也作为动态数据源的一个数据源username: rootpassword: 123456url: jdbc:mysql://39.108.158.138:3306/quartzdriver-class-name: com.mysql.cj.jdbc.Driverquartz:job-store-type: jdbcjdbc:initialize-schema: always

创建任务

创建一个每秒打印一次hello world的任务。

@Slf4j
public class HelloworldJob extends QuartzJobBean {private static int time = 0;@Overrideprotected void executeInternal(JobExecutionContext jobExecutionContext) throws JobExecutionException {log.info("Hello world!:" + jobExecutionContext.getJobDetail().getKey() + "-" + (time++));}
}

对应的自动配置:

@Configuration
http://www.lryc.cn/news/321635.html

相关文章:

  • 四连杆机构运动学仿真 | 【Matlab源码+理论公式文本】| 曲柄滑块 | 曲柄摇杆 | 机械连杆
  • Lightroom Classic 2024 for mac 中文激活:强大的图像后期处理软件
  • 程序员下班以后做什么副业合适?
  • HSE化工应急安全生产管理平台:衢州某巨大型化工企业的成功应用
  • 塑料工厂5G智能制造数字孪生可视化平台,推进塑料行业数字化转型
  • HTML万字学习总结
  • Linux网络编程: 以太网帧Frame/ARP/RARP详解
  • 【SpringCloud微服务实战09】Elasticsearch 搜索引擎
  • Leetcode 31. 删除无效的括号
  • 首页效果炫酷的wordpress免费主题模板
  • 网络安全的几个关键领域
  • Vue 计算属性和监视属性
  • 【Python】反编译PyInstaller打包的exe
  • 【数据结构】哈希表与哈希桶
  • 幼儿教育管理系统|基于jsp 技术+ Mysql+Java的幼儿教育管理系统设计与实现(可运行源码+数据库+设计文档)
  • 【赠书第21期】游戏力:竞技游戏设计实战教程
  • 基于VMware虚拟机安装MacOS BigSur系统
  • C++特性三:多态的基本语法及原理剖析
  • Windows下的TCP/IP实例
  • 硬件学习件Cadence day15 allegro 查看state 后发现有网络未连接怎么办, shape 有问题怎么办,
  • nginx 中 user 配置的作用
  • 愚人节礼物(C++)
  • Lua 学习
  • YOLOv7 | 添加GSConv,VoVGSCSP等多种卷积,有效提升目标检测效果,代码改进(超详细)
  • 『运维心得』BPC-EPM-AddIn专家看过来
  • 论文浅尝 | GPT-RE:基于大语言模型针对关系抽取的上下文学习
  • Rust语言:告诉编译器允许存在未使用的代码(Rust保留未使用的实现)
  • Winform数据绑定
  • DeprecationWarning: currentThread() is deprecated, use current_thread() instead
  • 2024届 C++ 刷题 笔试强训 Day 03