From e1da0c20d163f12837809dd6a32c1e4168811abb Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Tue, 14 May 2024 14:33:35 +0800
Subject: [PATCH] 1
---
src/main/java/com/nq/utils/task/news/NewsTask.java | 31 +++++++++++++++++++++++++------
1 files changed, 25 insertions(+), 6 deletions(-)
diff --git a/src/main/java/com/nq/utils/task/news/NewsTask.java b/src/main/java/com/nq/utils/task/news/NewsTask.java
index ba80a08..098d874 100644
--- a/src/main/java/com/nq/utils/task/news/NewsTask.java
+++ b/src/main/java/com/nq/utils/task/news/NewsTask.java
@@ -7,6 +7,9 @@
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
+
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
//import org.springframework.scheduling.annotation.Scheduled;
@@ -20,20 +23,36 @@
@Autowired
ISiteArticleService iSiteArticleService;
+ boolean NewsInfoTask = true;
+
+ private final Lock NewsInfoTaskLock = new ReentrantLock();
/*
* 新聞資訊抓取
* */
- @Scheduled(cron = "0 0/30 * * * ?")
+ @Scheduled(cron = "0 0/5 * * * ?")
public void NewsInfoTask() {
- this.iSiteNewsService.grabNews();
-
+ if (NewsInfoTask)
+ NewsInfoTask = false;
+ else return;
+ if (NewsInfoTaskLock.tryLock()) {
+ try {
+ System.out.println("新闻定时任务---->开始");
+ this.iSiteNewsService.grabNews();
+ } catch (Exception e) {
+ e.printStackTrace();
+ } finally {
+ NewsInfoTaskLock.unlock();
+ NewsInfoTask = true;
+ }
+ System.out.println("新闻定时任务---->结束");
+ }
}
/*
* 新聞公告抓取
* */
- @Scheduled(cron = "0 0/30 9-20 * * ?")
- public void ArtInfoTask() {
+// @Scheduled(cron = "0 0/30 9-20 * * ?")
+// public void ArtInfoTask() {
// this.iSiteArticleService.grabArticle();
- }
+// }
}
--
Gitblit v1.9.3