From e0ce7bc8678e771d13090d9b262eb833aef114b9 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 04 Jul 2025 18:44:31 +0800
Subject: [PATCH] 新增websocket美国、墨西哥客户端 多线程执行同步股票、新闻咨询抓取
---
src/main/java/com/nq/utils/task/YEBTask.java | 40 ++++++++++++++++++++++++++++------------
1 files changed, 28 insertions(+), 12 deletions(-)
diff --git a/src/main/java/com/nq/utils/task/YEBTask.java b/src/main/java/com/nq/utils/task/YEBTask.java
index fd8b1b0..23f68b5 100644
--- a/src/main/java/com/nq/utils/task/YEBTask.java
+++ b/src/main/java/com/nq/utils/task/YEBTask.java
@@ -1,29 +1,45 @@
package com.nq.utils.task;
-
import com.nq.service.IEchoServices;
+import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
-import org.springframework.stereotype.Controller;
+import org.springframework.stereotype.Component;
+
+import java.util.concurrent.locks.ReentrantLock;
+import java.util.concurrent.atomic.AtomicBoolean;
/**
* 余额宝定时任务
- * */
-@Controller
+ */
+@Slf4j
+@Component
public class YEBTask {
-
-
@Autowired
- IEchoServices echoServices;
+ private IEchoServices echoServices;
+ private final ReentrantLock sendYEBMoneyLock = new ReentrantLock();
+ private final AtomicBoolean isSendYEBMoney = new AtomicBoolean(false);
/**
* 余额宝发放利息
- * */
- @Scheduled(cron = "0 0/1 * * * ?")
- public void sendYEBMoney(){
- echoServices.sendMoney();
+ */
+// @Scheduled(cron = "0 0/1 * * * ?")
+ public void sendYEBMoney() {
+ if (isSendYEBMoney.get()) { // 判断任务是否在处理中
+ return;
+ }
+ if (sendYEBMoneyLock.tryLock()) { // 尝试获取锁
+ isSendYEBMoney.set(true); // 设置处理中标识为true
+ try {
+ log.info("基金定时任务-------开始");
+ echoServices.sendMoney();
+ log.info("基金定时任务-------结束");
+ } finally {
+ sendYEBMoneyLock.unlock(); // 释放锁
+ isSendYEBMoney.set(false); // 设置处理中标识为false
+ }
+ }
}
-
}
--
Gitblit v1.9.3