From 8d53c609a6589158d68b5945cdb3061460a43d47 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Thu, 15 Aug 2024 04:02:17 +0800
Subject: [PATCH] 1
---
websocketSerivce/src/main/java/org/example/task/GateStock.java | 11 ++++++++---
1 files changed, 8 insertions(+), 3 deletions(-)
diff --git a/websocketSerivce/src/main/java/org/example/task/GateStock.java b/websocketSerivce/src/main/java/org/example/task/GateStock.java
index 96aae37..7fc0921 100644
--- a/websocketSerivce/src/main/java/org/example/task/GateStock.java
+++ b/websocketSerivce/src/main/java/org/example/task/GateStock.java
@@ -47,7 +47,7 @@
/**
* 同步gate交易所交易对
*/
- @Scheduled(cron = "0 0/40 * * * ?")
+ @Scheduled(cron = "0 0/35 * * * ?")
// @Scheduled(cron = "0/10 * * * * ?")
public void syncCurrency() {
// 使用Lock来确保同步
@@ -77,7 +77,9 @@
getList.parallelStream().forEach(person -> person.setId(StringUtils.remove(person.getId(), "_")));
List<Currency> dbList = currencyService.list(new LambdaQueryWrapper<Currency>().eq(Currency::getSource, "gate"));
- Set<String> symbolSet = dbList.stream().map(Currency::getSymbol).collect(Collectors.toSet());
+
+ // 删除已经下架的币种
+ Set<String> symbolSet = getList.stream().map(CurrencyGateBo::getId).collect(Collectors.toSet());
List<Currency> removeList = dbList.stream()
.filter(currency -> !symbolSet.contains(currency.getSymbol()))
.collect(Collectors.toList());
@@ -85,14 +87,16 @@
if(CollectionUtils.isNotEmpty(removeList)){
removeList.forEach(f->{
RedisUtil.delete("gate"+f.getSymbol());
+ currencyService.remove(new LambdaQueryWrapper<Currency>().eq(Currency::getSymbol,f.getSymbol()));
});
}
- currencyService.remove(new LambdaQueryWrapper<Currency>().eq(Currency::getSource,"gate"));
// 比对接口返回的数据和数据库中已有的数据,找出新增的数据
+ Set<String> loclSymbolSet = dbList.stream().map(Currency::getSymbol).collect(Collectors.toSet());
List<Currency> saveList = getList.stream()
+ .filter(currency -> !loclSymbolSet.contains(currency.getId()))
.map(currency -> {
Currency newCurrency = new Currency();
newCurrency.setSymbol(currency.getId());
@@ -102,6 +106,7 @@
return newCurrency;
})
.collect(Collectors.toList());
+
// 批量保存新增数据到数据库
if(CollectionUtils.isNotEmpty(saveList)){
currencyService.saveBatch(saveList);
--
Gitblit v1.9.3