1.代码优化

This commit is contained in:
xy
2024-10-14 09:39:34 +08:00
parent de0d35f23d
commit 515ae0107c
5 changed files with 145 additions and 57 deletions

View File

@@ -105,17 +105,17 @@ public class RedisKeyExpirationListener extends KeyExpirationEventMessageListene
ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1); ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
executeMainTask(scheduler,nDid,version); executeMainTask(scheduler,nDid,version);
} }
//自动接入 // //自动接入
else if (expiredKey.startsWith("autoAccess")) { // else if (expiredKey.startsWith("autoAccess")) {
List<CsEquipmentDeliveryPO> list = csEquipmentDeliveryService.getAll(); // List<CsEquipmentDeliveryPO> list = csEquipmentDeliveryService.getAll();
list.forEach(item->{ // list.forEach(item->{
String version = csTopicService.getVersion(item.getNdid()); // String version = csTopicService.getVersion(item.getNdid());
if (!Objects.isNull(version)){ // if (!Objects.isNull(version)){
csDeviceService.devAccessAskTemplate(item.getNdid(),version,1); // csDeviceService.devAccessAskTemplate(item.getNdid(),version,1);
redisUtil.saveByKey(AppRedisKey.DEVICE_MID + item.getNdid(),1); // redisUtil.saveByKey(AppRedisKey.DEVICE_MID + item.getNdid(),1);
} // }
}); // });
} // }
} }
//主任务 //主任务
@@ -147,15 +147,17 @@ public class RedisKeyExpirationListener extends KeyExpirationEventMessageListene
} catch (InterruptedException e) { } catch (InterruptedException e) {
throw new RuntimeException(e); throw new RuntimeException(e);
} }
csLogsFeignClient.addUserLog(logDto);
} }
//客户端不在线则修改装置状态,进入定时任务 //客户端不在线则修改装置状态,进入定时任务
else { else {
//装置下线 //装置下线
csEquipmentDeliveryService.updateRunStatusBynDid(nDid, AccessEnum.OFFLINE.getCode()); csEquipmentDeliveryService.updateRunStatusBynDid(nDid, AccessEnum.OFFLINE.getCode());
logDto.setOperate("主任务执行失败,装置下线,进入定时任务");
csLogsFeignClient.addUserLog(logDto);
log.info("客户端离线进入定时任务...");
startScheduledTask(scheduler,nDid,version); startScheduledTask(scheduler,nDid,version);
logDto.setOperate(nDid + "客户端离线进入定时任务");
} }
csLogsFeignClient.addUserLog(logDto);
} }
private void startScheduledTask(ScheduledExecutorService scheduler, String nDid, String version) { private void startScheduledTask(ScheduledExecutorService scheduler, String nDid, String version) {
@@ -212,7 +214,7 @@ public class RedisKeyExpirationListener extends KeyExpirationEventMessageListene
onlineLogsService.updateById(record); onlineLogsService.updateById(record);
} }
csLogsFeignClient.addUserLog(logDto); csLogsFeignClient.addUserLog(logDto);
}, 0, 2, TimeUnit.MINUTES); }, 0, 2, TimeUnit.SECONDS);
} }
} }

View File

@@ -1,5 +1,10 @@
package com.njcn.access.runner; package com.njcn.access.runner;
import com.njcn.access.service.ICsEquipmentDeliveryService;
import com.njcn.access.service.ICsTopicService;
import com.njcn.access.service.impl.CsDeviceServiceImpl;
import com.njcn.csdevice.pojo.po.CsEquipmentDeliveryPO;
import com.njcn.redis.pojo.enums.AppRedisKey;
import com.njcn.redis.utils.RedisUtil; import com.njcn.redis.utils.RedisUtil;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.ApplicationArguments; import org.springframework.boot.ApplicationArguments;
@@ -7,6 +12,11 @@ import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.util.List;
import java.util.Objects;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
/** /**
* 类的介绍:用来重新发起设备的接入,存在程序意外停止了,缓存失效导致无法更新装置的状态,所以需要在程序启动时发起设备的接入 * 类的介绍:用来重新发起设备的接入,存在程序意外停止了,缓存失效导致无法更新装置的状态,所以需要在程序启动时发起设备的接入
@@ -21,10 +31,30 @@ public class AccessApplicationRunner implements ApplicationRunner {
@Resource @Resource
private RedisUtil redisUtil; private RedisUtil redisUtil;
@Resource
private ICsEquipmentDeliveryService csEquipmentDeliveryService;
@Resource
private ICsTopicService csTopicService;
@Resource
private CsDeviceServiceImpl csDeviceService;
ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
private static final long ACCESS_TIME = 60L;
@Override @Override
public void run(ApplicationArguments args) { public void run(ApplicationArguments args) {
redisUtil.saveByKeyWithExpire("autoAccess",null,60L); //项目启动60s后发起自动接入
Runnable task = () -> {
List<CsEquipmentDeliveryPO> list = csEquipmentDeliveryService.getAll();
list.forEach(item->{
String version = csTopicService.getVersion(item.getNdid());
if (!Objects.isNull(version)){
csDeviceService.devAccessAskTemplate(item.getNdid(),version,1);
redisUtil.saveByKey(AppRedisKey.DEVICE_MID + item.getNdid(),1);
}
});
};
scheduler.schedule(task, ACCESS_TIME, TimeUnit.SECONDS);
// 关闭调度程序
scheduler.shutdown();
} }
} }

View File

@@ -1,26 +1,26 @@
package com.njcn.zlevent.init; //package com.njcn.zlevent.init;
//
import com.njcn.redis.utils.RedisUtil; //import com.njcn.redis.utils.RedisUtil;
import lombok.AllArgsConstructor; //import lombok.AllArgsConstructor;
import lombok.extern.slf4j.Slf4j; //import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.CommandLineRunner; //import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component; //import org.springframework.stereotype.Component;
//
//
/** ///**
* @author xy // * @author xy
* // *
* 程序重启设置任务,消费历史录波文件 // * 程序重启设置任务,消费历史录波文件
*/ // */
@Slf4j //@Slf4j
@Component //@Component
@AllArgsConstructor //@AllArgsConstructor
public class InitEventFiles implements CommandLineRunner { //public class InitEventFiles implements CommandLineRunner {
//
private final RedisUtil redisUtil; // private final RedisUtil redisUtil;
//
@Override // @Override
public void run(String... args) { // public void run(String... args) {
redisUtil.saveByKeyWithExpire("startFile",null,120L); // redisUtil.saveByKeyWithExpire("startFile",null,120L);
} // }
} //}

View File

@@ -11,7 +11,6 @@ import com.njcn.access.pojo.dto.file.FileRedisDto;
import com.njcn.common.pojo.exception.BusinessException; import com.njcn.common.pojo.exception.BusinessException;
import com.njcn.csdevice.api.EquipmentFeignClient; import com.njcn.csdevice.api.EquipmentFeignClient;
import com.njcn.csdevice.enums.AlgorithmResponseEnum; import com.njcn.csdevice.enums.AlgorithmResponseEnum;
import com.njcn.csdevice.pojo.po.CsEquipmentDeliveryPO;
import com.njcn.redis.pojo.enums.AppRedisKey; import com.njcn.redis.pojo.enums.AppRedisKey;
import com.njcn.redis.utils.RedisUtil; import com.njcn.redis.utils.RedisUtil;
import com.njcn.stat.enums.StatResponseEnum; import com.njcn.stat.enums.StatResponseEnum;
@@ -99,17 +98,17 @@ public class RedisKeyExpirationListener extends KeyExpirationEventMessageListene
downloadFile(missingList,dto.getNDid(),fileName); downloadFile(missingList,dto.getNDid(),fileName);
} }
} }
//项目重启或者接入经过120s开始处理历史录波文件 // //项目重启或者接入经过120s开始处理历史录波文件
else if (expiredKey.startsWith("startFile")) { // else if (expiredKey.startsWith("startFile")) {
List<CsEquipmentDeliveryPO> list = equipmentFeignClient.getAll().getData(); // List<CsEquipmentDeliveryPO> list = equipmentFeignClient.getAll().getData();
if (CollectionUtil.isNotEmpty(list)) { // if (CollectionUtil.isNotEmpty(list)) {
list.forEach(item->{ // list.forEach(item->{
redisUtil.delete("handleEvent:" + item.getNdid()); // redisUtil.delete("handleEvent:" + item.getNdid());
//处理缓存数据 // //处理缓存数据
csWaveAnalysisService.channelWave(item.getNdid()); // csWaveAnalysisService.channelWave(item.getNdid());
}); // });
} // }
} // }
//手动文件下载 //手动文件下载
else if (expiredKey.startsWith(AppRedisKey.FILE_DOWN_TIME)) { else if (expiredKey.startsWith(AppRedisKey.FILE_DOWN_TIME)) {
List<Integer> missingList = new ArrayList<>(); List<Integer> missingList = new ArrayList<>();
@@ -205,11 +204,11 @@ public class RedisKeyExpirationListener extends KeyExpirationEventMessageListene
*/ */
public void webSendNextStep(String fileName, String id, int mid,int step) { public void webSendNextStep(String fileName, String id, int mid,int step) {
try { try {
for (int i = 1; i <= 30; i++) { for (int i = 1; i <= 15; i++) {
if (step == 0 ){ if (step == 0 ){
Thread.sleep(5000); Thread.sleep(8000);
} else { } else {
Thread.sleep(2000); Thread.sleep(4000);
} }
FileRedisDto fileRedisDto = (FileRedisDto) redisUtil.getObjectByKey(AppRedisKey.DOWNLOAD + fileName + mid); FileRedisDto fileRedisDto = (FileRedisDto) redisUtil.getObjectByKey(AppRedisKey.DOWNLOAD + fileName + mid);
if (Objects.isNull(fileRedisDto)) { if (Objects.isNull(fileRedisDto)) {

View File

@@ -0,0 +1,57 @@
package com.njcn.zlevent.runner;
import cn.hutool.core.collection.CollectionUtil;
import com.njcn.csdevice.api.EquipmentFeignClient;
import com.njcn.csdevice.pojo.po.CsEquipmentDeliveryPO;
import com.njcn.redis.utils.RedisUtil;
import com.njcn.zlevent.service.ICsWaveAnalysisService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Component;
import javax.annotation.Resource;
import java.util.List;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
/**
* 类的介绍项目重启或者接入经过120s开始处理历史录波文件
*
* @author xuyang
* @version 1.0.0
* @createTime 2024/9/18 13:57
*/
@Component
@Slf4j
public class ZlEventApplicationRunner implements ApplicationRunner {
@Resource
private RedisUtil redisUtil;
@Resource
private EquipmentFeignClient equipmentFeignClient;
@Resource
private ICsWaveAnalysisService csWaveAnalysisService;
ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
private static final long EVENT_TIME = 120L;
@Override
public void run(ApplicationArguments args) {
//项目启动120s后开始消费缓存的波形文件
Runnable task = () -> {
log.info("开始消费缓存的波形文件");
List<CsEquipmentDeliveryPO> list = equipmentFeignClient.getAll().getData();
if (CollectionUtil.isNotEmpty(list)) {
list.forEach(item->{
redisUtil.delete("handleEvent:" + item.getNdid());
//处理缓存数据
csWaveAnalysisService.channelWave(item.getNdid());
});
}
};
scheduler.schedule(task, EVENT_TIME, TimeUnit.SECONDS);
// 关闭调度程序
scheduler.shutdown();
}
}