Spring Boot 整合 ShedLock 处理定时任务重复

SpringBoot整合ShedLock处理定时任务重复问题⏰🔒

在分布式系统中,定时任务重复执行是一个常见问题😫。当多个服务实例同时运行时,每个实例上的定时任务可能会同时触发,导致数据不一致或重复处理。今天我们就来聊聊如何使用ShedLock解决这个问题!✨

什么是ShedLock?🤔

ShedLock是一个轻量级的分布式锁库,确保你的定时任务在同一时间只在一个实例上执行🚀。它支持多种存储方式,包括JDBC、Redis、MongoDB等。

整合步骤🛠️

1.首先添加依赖:

```xml

net.javacrumbs.shedlock
shedlock-spring
4.42.0

net.javacrumbs.shedlock
shedlock-provider-jdbc-template
4.42.0

```

2.创建数据库表(以MySQL为例):

```sql
CREATETABLEshedlock(
nameVARCHAR(64)NOTNULL,
lock_untilTIMESTAMP(3)NOTNULL,
locked_atTIMESTAMP(3)NOTNULL,
locked_byVARCHAR(255)NOTNULL,
PRIMARYKEY(name)
);
```

3.配置ShedLock:

```java
@Configuration
@EnableScheduling
@EnableSchedulerLock(defaultLockAtMostFor="PT30S")
publicclassSchedulerConfig{

@Bean
publicLockProviderlockProvider(DataSourcedataSource){
returnnewJdbcTemplateLockProvider(dataSource);
}
}
```

4.使用@SchedulerLock注解定时任务:

```java
@Service
publicclassScheduledTaskService{

@Scheduled(cron="0/5")//每5分钟执行一次
@SchedulerLock(name="scheduledTaskName",
lockAtLeastFor="PT5M",
lockAtMostFor="PT10M")
publicvoidscheduledTask(){
//你的业务逻辑
System.out.println("任务执行时间:"+newDate());
}
}
```

关键参数说明📝

-`name`:锁的唯一名称,相同名称的任务会被互斥
-`lockAtLeastFor`:最短锁定时间,防止任务执行过快导致重复
-`lockAtMostFor`:最大锁定时间,防止节点崩溃导致锁无法释放

总结🎯

通过ShedLock,我们轻松解决了分布式环境下的定时任务重复执行问题💪。它配置简单、支持多种存储方式,是处理分布式定时任务的绝佳选择!下次遇到类似问题,不妨试试ShedLock吧!😊

相关推荐
章豪Mrrey nical6 小时前
前后端分离工作详解Detailed Explanation of Frontend-Backend Separation Work
后端·前端框架·状态模式
超级大只老咪7 小时前
数组相邻元素比较的循环条件(Java竞赛考点)
java
小浣熊熊熊熊熊熊熊丶7 小时前
《Effective Java》第25条:限制源文件为单个顶级类
java·开发语言·effective java
毕设源码-钟学长7 小时前
【开题答辩全过程】以 公交管理系统为例,包含答辩的问题和答案
java·eclipse
啃火龙果的兔子7 小时前
JDK 安装配置
java·开发语言
星哥说事7 小时前
应用程序监控:Java 与 Web 应用的实践
java·开发语言
派大鑫wink7 小时前
【JAVA学习日志】SpringBoot 参数配置:从基础到实战,解锁灵活配置新姿势
java·spring boot·后端
程序员爱钓鱼8 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
xUxIAOrUIII8 小时前
【Spring Boot】控制器Controller方法
java·spring boot·后端
Dolphin_Home8 小时前
从理论到实战:图结构在仓库关联业务中的落地(小白→中级,附完整代码)
java·spring boot·后端·spring cloud·database·广度优先·图搜索算法