From 852ff7e01904ee5c8552b5dd30fa75125546be7f Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Fri, 07 Jun 2024 10:40:55 +0800
Subject: [PATCH] 购买节点

---
 src/main/java/cc/mrbird/febs/job/ChainListenerJob.java |   25 ++++++++++++++-----------
 1 files changed, 14 insertions(+), 11 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java b/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
index c1efb2c..d9b8978 100644
--- a/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
+++ b/src/main/java/cc/mrbird/febs/job/ChainListenerJob.java
@@ -10,11 +10,9 @@
 import org.springframework.boot.ApplicationArguments;
 import org.springframework.boot.ApplicationRunner;
 import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
-import org.springframework.scheduling.annotation.Async;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
-import javax.annotation.PostConstruct;
 import java.math.BigInteger;
 
 @Slf4j
@@ -23,17 +21,15 @@
 public class ChainListenerJob implements ApplicationRunner {
 
     @Autowired
-    private ContractEventService bscCoinContractEvent;
-
-    @Autowired
     private ContractEventService bscUsdtContractEvent;
+    @Autowired
+    private ContractEventService bscCoinContractEvent;
 
     @Autowired
     private RedisUtils redisUtils;
 
     @Scheduled(cron = "0 0/5 * * * ? ")
     public void chainBlockUpdate() {
-        log.info("最新区块更新");
         BigInteger blockNumber = ChainService.getInstance(ChainEnum.BSC_TFC.name()).blockNumber();
 
         redisUtils.set(AppContants.REDIS_KEY_BLOCK_ETH_NEWEST_NUM, blockNumber);
@@ -79,20 +75,27 @@
             block = (BigInteger) incrementObj;
         }
 
+//        ChainService.wssContractEventListener(block, bscUsdtContractEvent, ChainEnum.BSC_USDT_LISTENER.name());
+//        ChainService.wssContractEventListener(block, bscCoinContractEvent, ChainEnum.BSC_TFC_LISTENER.name());
+
         BigInteger section = BigInteger.valueOf(5000);
         while (newest.subtract(block).compareTo(section) > -1) {
             BigInteger end = block.add(section);
-            log.info("监听:[{} - {}]", block, end);
-            ChainService.contractEventListener(block, end, bscUsdtContractEvent, ChainEnum.BSC_USDT.name());
-            ChainService.contractEventListener(block, end, bscCoinContractEvent, ChainEnum.BSC_TFC.name());
+
+            BigInteger finalBlock = block;
+            new Thread(() -> {
+                log.info("监听:[{} - {}]", finalBlock, end);
+                ChainService.contractEventListener(finalBlock, end, bscUsdtContractEvent, ChainEnum.BSC_USDT_LISTENER.name());
+//                ChainService.contractEventListener(finalBlock, end, bscCoinContractEvent, ChainEnum.BSC_TFC_LISTENER.name());
+            }).start();
 
             block = block.add(section);
             if (block.compareTo(newest) > 0) {
                 block = newest;
             }
         }
-        ChainService.contractEventListener(block, bscUsdtContractEvent, ChainEnum.BSC_USDT.name());
-        ChainService.contractEventListener(block, bscCoinContractEvent, ChainEnum.BSC_TFC.name());
+        ChainService.contractEventListener(block, bscUsdtContractEvent, ChainEnum.BSC_USDT_LISTENER.name());
+//        ChainService.contractEventListener(block, bscCoinContractEvent, ChainEnum.BSC_TFC_LISTENER.name());
 
         long end = System.currentTimeMillis();
         log.info("区块链监听启动完成, 消耗时间{}", end - start);

--
Gitblit v1.9.1