From 3bdd9109b9e1ab9414e2a7a90a0023b3c631a895 Mon Sep 17 00:00:00 2001 From: 潘志宝 <979469083@qq.com> Date: 星期五, 03 一月 2025 16:45:36 +0800 Subject: [PATCH] 压缩空气运行指标 --- shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleAirIndexMonthTask.java | 87 +++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 87 insertions(+), 0 deletions(-) diff --git a/shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleAirIndexMonthTask.java b/shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleAirIndexMonthTask.java new file mode 100644 index 0000000..1d66298 --- /dev/null +++ b/shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleAirIndexMonthTask.java @@ -0,0 +1,87 @@ +package com.iailab.module.shasteel.job.task; + +import com.iailab.module.model.api.mcs.McsApi; +import com.iailab.module.model.api.mcs.dto.StScheduleSchemeDTO; +import com.iailab.module.model.api.mdk.MdkApi; +import com.iailab.module.model.api.mdk.dto.MdkScheduleReqDTO; +import com.iailab.module.model.api.mdk.dto.MdkScheduleRespDTO; +import com.iailab.module.model.enums.ScheduleTriggerMethodEnum; +import org.apache.commons.lang3.StringUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; +import org.springframework.util.CollectionUtils; + +import javax.annotation.Resource; +import java.time.LocalDate; +import java.time.LocalDateTime; +import java.time.temporal.ChronoUnit; +import java.util.*; + +/** + * 压缩空气运行指标(月) + * 动态数据长度,月初到当天 + * 每天更新,10 0 0 1/1 * ? + * + * @author PanZhibao + * @Description + * @createTime 2024年12月31日 + */ +@Component("runScheduleAirIndexMonthTask") +public class RunScheduleAirIndexMonthTask implements ITask { + private Logger logger = LoggerFactory.getLogger(getClass()); + + @Resource + private McsApi mcsApi; + + @Autowired + private MdkApi mdkApi; + + @Override + public void run(String params) { + logger.info("RunScheduleAirIndexMonthTask,参数为:{}", params); + try { + Calendar calendar = Calendar.getInstance(); + calendar.set(Calendar.MILLISECOND, 0); + calendar.set(Calendar.SECOND, 0); + Date scheduleTime = calendar.getTime(); + if (StringUtils.isEmpty(params)) { + logger.info("参数为空"); + return; + } + // 根据条件查找方案 + List<StScheduleSchemeDTO> schemeList = mcsApi.listScheduleScheme(ScheduleTriggerMethodEnum.JOB.getCode(), params); + if (CollectionUtils.isEmpty(schemeList)) { + logger.info("方案为空"); + return; + } + + for (StScheduleSchemeDTO scheme : schemeList) { + MdkScheduleReqDTO dto = new MdkScheduleReqDTO(); + dto.setScheduleTime(scheduleTime); + dto.setScheduleCode(scheme.getCode()); + LocalDateTime now = LocalDateTime.now(); + LocalDate startOfMonth = LocalDate.now().withDayOfMonth(1); + LocalDateTime startOfMonthAtMidnight = startOfMonth.atStartOfDay(); + long timeDifference = ChronoUnit.MINUTES.between(startOfMonthAtMidnight, now); + Map<Integer, Integer> dynamicDataLength = new HashMap<>(); + dynamicDataLength.put(1, (int) timeDifference); + dynamicDataLength.put(2, (int) timeDifference); + dynamicDataLength.put(3, (int) timeDifference); + dto.setDynamicDataLength( dynamicDataLength); + Map<String, String> dynamicSettings = new HashMap<>(); + dynamicSettings.put("embedDim", String.valueOf(timeDifference)); + dto.setDynamicSettings(dynamicSettings); + MdkScheduleRespDTO mdkScheduleRespDTO = mdkApi.doSchedule(dto); + // 结果写入测点 + mdkApi.scheduleModelOut(mdkScheduleRespDTO); + } + logger.info(params + "调度方案执行完成"); + } catch (Exception ex) { + logger.error("RunScheduleAirIndexMonthTask运行异常"); + ex.printStackTrace(); + } + logger.info("RunScheduleAirIndexMonthTask运行完成"); + } +} \ No newline at end of file -- Gitblit v1.9.3