From 40c202ae8c30f34a32fb217c458e15a22326c786 Mon Sep 17 00:00:00 2001 From: 潘志宝 <979469083@qq.com> Date: 星期三, 26 三月 2025 12:58:44 +0800 Subject: [PATCH] RunJobScheduleTask --- ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunJobScheduleTask.java | 76 ++++++++++++++++++++++++++++++++++++++ 1 files changed, 76 insertions(+), 0 deletions(-) diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunJobScheduleTask.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunJobScheduleTask.java new file mode 100644 index 0000000..8994484 --- /dev/null +++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/job/task/RunJobScheduleTask.java @@ -0,0 +1,76 @@ +package com.iailab.module.ansteel.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 java.util.Calendar; +import java.util.Date; +import java.util.List; + +/** + * @author PanZhibao + * @Description + * @createTime 2025年03月26日 + */ +@Component("runScheduleModuleTask") +public class RunJobScheduleTask implements ITask { + + private Logger logger = LoggerFactory.getLogger(getClass()); + + @Autowired + private McsApi mcsApi; + + @Autowired + private MdkApi mdkApi; + + @Override + public void run(String params) { + logger.info("RunJobScheduleTask,参数为:{}", 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()); + MdkScheduleRespDTO mdkScheduleRespDTO = mdkApi.doSchedule(dto); + logger.info(scheme.getCode() + "调度方案执行完成," + mdkScheduleRespDTO); + logger.info("调度方案结果开始下发"); + if (mdkApi.scheduleModelOut(mdkScheduleRespDTO)) { + logger.info("调度方案结果下发成功"); + } else { + logger.error("调度方案结果下发失败"); + } + } + } catch (Exception ex) { + logger.error("RunJobScheduleTask运行异常"); + ex.printStackTrace(); + } + logger.info("RunJobScheduleTask运行完成"); + + } +} \ No newline at end of file -- Gitblit v1.9.3