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吧!😊

相关推荐
萧逸才1 天前
【learn-claude-code】S11AutonomousAgents - 自主 Agent:自动认领任务 + 空闲轮询
java·人工智能·ai
李少兄1 天前
优化高负载详情接口:基于字段选择与懒加载的实践
java
简单点了1 天前
mac安装Java环境
java·macos
CHU7290351 天前
在线教学课堂APP功能版块设计方案:重构学习场景的交互逻辑
java·学习·小程序·重构
sTone873751 天前
数据库选型深入 — 从原理到决策
后端
xhuiting1 天前
MQ(专题二)
java·java-rocketmq
码农BookSea1 天前
RAG详解:让大模型看见你的私有知识
人工智能·后端
Echoo华地1 天前
Gatling压测案例
java·jmeter·压力测试·并发·scale·压测·gatling
码云数智-园园1 天前
C# 内存模型的基石:值类型与引用类型的深度博弈
java·开发语言·jvm
rannn_1111 天前
【Redis|实战篇7】黑马点评|附近商铺、用户签到、UV签到
java·数据库·redis·后端·uv