From fc4b1e66b241df686dbd7bebb6df6793060a8107 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Sun, 10 Nov 2024 21:36:53 +0800
Subject: [PATCH] 1
---
src/main/java/com/nq/utils/task/news/NewsTask.java | 79 +++++++++++++++++++++++++++++++++++----
1 files changed, 70 insertions(+), 9 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..a6deb29 100644
--- a/src/main/java/com/nq/utils/task/news/NewsTask.java
+++ b/src/main/java/com/nq/utils/task/news/NewsTask.java
@@ -1,12 +1,22 @@
package com.nq.utils.task.news;
+import com.nq.enums.EStockType;
+import com.nq.pojo.SiteNews;
import com.nq.service.ISiteArticleService;
import com.nq.service.ISiteNewsService;
+import com.nq.utils.http.HttpRequest;
+import net.sf.json.JSONArray;
+import net.sf.json.JSONObject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
+
+import java.util.Date;
+import java.util.concurrent.atomic.AtomicBoolean;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
//import org.springframework.scheduling.annotation.Scheduled;
@@ -20,20 +30,71 @@
@Autowired
ISiteArticleService iSiteArticleService;
- /*
- * 新聞資訊抓取
- * */
- @Scheduled(cron = "0 0/30 * * * ?")
- public void NewsInfoTask() {
- this.iSiteNewsService.grabNews();
+ private final AtomicBoolean NewsInfoTask = new AtomicBoolean(false);
+
+
+ private final Lock NewsInfoTaskLock = new ReentrantLock();
+
+ private final AtomicBoolean USNewsInfoTask = new AtomicBoolean(false);
+
+
+ private final Lock USNewsInfoTaskLock = new ReentrantLock();
+
+
+ /*
+ * 新聞資訊抓取
+ * */
+ @Scheduled(cron = "0 0/5 * * * ?")
+ public void NewsInfoTask() {
+ if (NewsInfoTask.get()) { // 判断任务是否在处理中
+ return;
+ }
+ if (NewsInfoTaskLock.tryLock()) { // 加锁
+ try {
+ NewsInfoTask.set(true); // 设置处理中标识为true
+ System.out.println("新闻定时任务---->开始");
+ iSiteNewsService.grabNews();
+ } catch (Exception e) {
+ System.err.println("新闻抓取出现异常: " + e.getMessage()); // 打印具体的异常信息
+ } finally {
+ NewsInfoTaskLock.unlock(); // 释放锁
+ NewsInfoTask.set(false); // 设置处理中标识为false
+ System.out.println("新闻定时任务---->结束");
+ }
+ }
}
+//
+// /*
+// * 新聞資訊抓取
+// * */
+// @Scheduled(cron = "0 0/10 * * * ?")
+// public void USNewsInfoTask() {
+// if (USNewsInfoTask.get()) { // 判断任务是否在处理中
+// return;
+// }
+// if (USNewsInfoTaskLock.tryLock()) { // 加锁
+// try {
+// USNewsInfoTask.set(true); // 设置处理中标识为true
+// System.out.println("美国新闻定时任务---->开始");
+// iSiteNewsService.grabNews();
+// } catch (Exception e) {
+// System.err.println("美国新闻抓取出现异常: " + e.getMessage()); // 打印具体的异常信息
+// } finally {
+// USNewsInfoTaskLock.unlock(); // 释放锁
+// USNewsInfoTask.set(false); // 设置处理中标识为false
+// 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