From 7d43a7f0a3ea90a152a9d0e52fde1e0f13272c10 Mon Sep 17 00:00:00 2001
From: PC-202403201522\Administrator <1041918560@qq.com>
Date: Mon, 13 May 2024 17:37:10 +0800
Subject: [PATCH] 定时任务阻塞
---
src/main/java/com/nq/utils/task/YEBTask.java | 33 +++++++++++++++++++++++++--------
1 files changed, 25 insertions(+), 8 deletions(-)
diff --git a/src/main/java/com/nq/utils/task/YEBTask.java b/src/main/java/com/nq/utils/task/YEBTask.java
index de9d595..12d22a2 100644
--- a/src/main/java/com/nq/utils/task/YEBTask.java
+++ b/src/main/java/com/nq/utils/task/YEBTask.java
@@ -6,29 +6,46 @@
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
-import org.springframework.stereotype.Controller;
+
+import java.util.concurrent.TimeUnit;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
/**
* 余额宝定时任务
- * */
+ */
@Slf4j
@Component
public class YEBTask {
-
@Autowired
IEchoServices echoServices;
+ boolean sendYEBMoney = true;
+
+ private final Lock sendYEBMoneyLock = new ReentrantLock();
/**
* 余额宝发放利息
- * */
+ */
@Scheduled(cron = "0 0/1 * * * ?")
- public void sendYEBMoney(){
- log.info("基金定时任务-------开始");
- echoServices.sendMoney();
- log.info("基金定时任务-------结束");
+ public void sendYEBMoney() {
+ if (sendYEBMoney)
+ sendYEBMoney = false;
+ else return;
+ if (sendYEBMoneyLock.tryLock()) {
+ try {
+
+ log.info("基金定时任务-------开始");
+ echoServices.sendMoney();
+ log.info("基金定时任务-------结束");
+
+ } finally {
+ sendYEBMoneyLock.unlock();
+ sendYEBMoney = true;
+ }
+ }
}
}
--
Gitblit v1.9.3