From 20e49829a15a4419bdae33a06a090d2f31ad6104 Mon Sep 17 00:00:00 2001
From: dengzedong <dengzedong@email>
Date: 星期二, 11 二月 2025 16:34:58 +0800
Subject: [PATCH] 删除旧配置

---
 shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java |  154 ++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 150 insertions(+), 4 deletions(-)

diff --git a/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java b/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java
index fac7816..bc5631a 100644
--- a/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java
+++ b/shasteel-biz/src/main/java/com/iailab/module/shasteel/mq/consumer/ModelPredictFinishConsumer.java
@@ -1,12 +1,30 @@
 package com.iailab.module.shasteel.mq.consumer;
 
+import com.alibaba.fastjson.JSONObject;
+import com.iailab.framework.common.util.date.DateUtils;
+import com.iailab.module.model.api.mcs.McsApi;
+import com.iailab.module.model.api.mcs.dto.AlarmConfigRespDTO;
+import com.iailab.module.model.api.mcs.dto.AlarmMessageRespDTO;
+import com.iailab.module.model.api.mcs.dto.PreDataJsonReqVO;
+import com.iailab.module.shasteel.mq.common.constant.CommonConstant;
+import com.iailab.module.shasteel.mq.common.constant.RoutingConstant;
 import com.iailab.module.shasteel.mq.config.QueuePredictFinishConfig;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.amqp.core.Message;
 import org.springframework.amqp.rabbit.annotation.RabbitListener;
+import org.springframework.amqp.rabbit.core.RabbitTemplate;
 import org.springframework.stereotype.Component;
+import org.springframework.util.CollectionUtils;
+
+import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.util.*;
+import java.util.stream.Collectors;
 
 /**
+ * 监听预测完成
+ * 根据预警配置产生预警信息
+ *
  * @author PanZhibao
  * @Description
  * @createTime 2024年12月11日
@@ -15,16 +33,144 @@
 @Component
 public class ModelPredictFinishConsumer {
 
+    @Resource
+    private McsApi mcsApi;
+
+    @Resource
+    private RabbitTemplate rabbitTemplate;
+
+    private static String lastRunAlarm = "";
+
+    /**
+     * 监听预测完成,产生预警消息
+     *
+     * @param message
+     */
     @RabbitListener(queues = QueuePredictFinishConfig.QUEUE_NAME)
     public void listen(Message message) {
-        String routingKey = message.getMessageProperties().getReceivedRoutingKey();
-        log.info("routingKey:" + routingKey);
-        String messageBody = new String(message.getBody());
-        log.info("messageBody:" + messageBody);
+        try {
+            String routingKey = message.getMessageProperties().getReceivedRoutingKey();
+            log.info("routingKey:" + routingKey);
+            String messageBody = new String(message.getBody());
+            log.info("messageBody:" + messageBody);
+            JSONObject messageJson = JSONObject.parseObject(messageBody);
+            if (CollectionUtils.isEmpty(messageJson)) {
+                return;
+            }
+            // 预测时间
+            Date predictTime = DateUtils.parse(messageJson.get("predictTime").toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND);
+            // 预测模块/预测管网
+            String moduleType = messageJson.get("moduleType").toString();
+            // 查询相关预警配置
+            List<AlarmConfigRespDTO> configList = mcsApi.listAlarmConfig(new HashMap<String, Object>());
+            if (CollectionUtils.isEmpty(configList)) {
+                log.info("AlarmConfigList is empty");
+                return;
+            }
+            List<String> outputIdList = configList.stream().map(item -> {
+                return item.getOutId();
+            }).collect(Collectors.toList());
+            List<AlarmMessageRespDTO> alarmList = new ArrayList<>();
+            if (moduleType.equals(CommonConstant.NET_BFG) || moduleType.equals(CommonConstant.NET_COG) ||
+                    moduleType.equals(CommonConstant.NET_LDG)) {
+                String runKey = "GasAlarm_" +  predictTime.getTime();
+                log.info("runKey:" + runKey);
+                log.info("lastRunAlarm:" + lastRunAlarm);
+                if (lastRunAlarm.equals(runKey)) {
+                    return;
+                }
+                lastRunAlarm = runKey;
+                for (AlarmConfigRespDTO configItem : configList) {
+                    PreDataJsonReqVO reqVO = new PreDataJsonReqVO();
+                    reqVO.setPredictTime(predictTime);
+                    reqVO.setOutputIdList(outputIdList);
+                    Map<String, List<Object[]>> preData = mcsApi.getPreDataCur(reqVO);
+                    if (CollectionUtils.isEmpty(preData)) {
+                        return;
+                    }
+                    Map<String, BigDecimal> culData = new HashMap<>();
+                    preData.forEach((key, value) -> {
+                        double nv = value.stream().map(v1 -> {
+                            return Double.parseDouble(v1[1].toString());
+                        }).collect(Collectors.toList()).stream().mapToDouble(Double::doubleValue).sum();
+                        culData.put(key, new BigDecimal(nv));
+                    });
 
+                    List<Object[]> result = preData.get(configItem.getOutId());
+                    if (CollectionUtils.isEmpty(result)) {
+                        continue;
+                    }
+                    // 累计值
+                    BigDecimal culValue = new BigDecimal(result.stream().map(v1 -> {
+                        return Double.parseDouble(v1[1].toString());
+                    }).collect(Collectors.toList()).stream().mapToDouble(Double::doubleValue).sum());
+                    log.info("culValue:" + culValue);
 
+                    // 生成预警信息
+                    AlarmMessageRespDTO alarmMessage = new AlarmMessageRespDTO();
+                    alarmMessage.setConfigId(configItem.getId());
+                    alarmMessage.setTitle(configItem.getTitle());
+                    alarmMessage.setAlarmObj(configItem.getAlarmObj());
+                    alarmMessage.setAlarmTime(predictTime);
+                    log.info("对比累计值是否超限");
+                    StringBuilder content = new StringBuilder();
+                    content.append(configItem.getTitle().replace("预警", ""));
+                    if (configItem.getCulUpper() != null && culValue.compareTo(configItem.getCulUpper()) > 0) {
+                        content.append("即将超出累计值上限");
+                        alarmMessage.setAlarmType(CommonConstant.EXCEEDING_UPPER_LIMIT);
+                        alarmMessage.setContent(content.toString());
+                        mcsApi.createAlarmMessage(alarmMessage);
+                        alarmList.add(alarmMessage);
+                        continue;
+                    }
+                    if (configItem.getCulLower() != null && culValue.compareTo(configItem.getCulLower()) < 0) {
+                        content.append("即将低于累计值下限");
+                        alarmMessage.setAlarmType(CommonConstant.EXCEEDING_LOWER_LIMIT);
+                        alarmMessage.setContent(content.toString());
+                        mcsApi.createAlarmMessage(alarmMessage);
+                        alarmList.add(alarmMessage);
+                        continue;
+                    }
 
+                    log.info("对比预测值是否超限");
+                    int toIndex = result.size();
+                    int fromIndex = result.size() - configItem.getCompLength();
+                    List<Object[]> predictList = result.subList(fromIndex, toIndex);
+                    for (Object[] data : predictList) {
+                        BigDecimal dataValue = new BigDecimal(Double.parseDouble(data[1].toString())).setScale(2, BigDecimal.ROUND_HALF_UP);
+                        if (dataValue.compareTo(configItem.getLowerLimit()) >= 0 && dataValue.compareTo(configItem.getUpperLimit()) <= 0) {
+                            log.info("预测值不超限");
+                            continue;
+                        }
+                        alarmMessage.setOutTime(DateUtils.parse(data[0].toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND));
+                        content.append(DateUtils.format(alarmMessage.getOutTime(), DateUtils.FORMAT_SIMPLE_TIME));
+                        content.append(",");
+                        content.append("即将");
+                        if (dataValue.compareTo(configItem.getLowerLimit()) < 0) {
+                            content.append("低与下限");
+                            alarmMessage.setAlarmType(CommonConstant.EXCEEDING_LOWER_LIMIT);
 
+                        } else if (dataValue.compareTo(configItem.getUpperLimit()) > 0) {
+                            content.append("超出上限");
+                            alarmMessage.setAlarmType(CommonConstant.EXCEEDING_UPPER_LIMIT);
+                        }
+                        alarmMessage.setContent(content.toString());
+                        mcsApi.createAlarmMessage(alarmMessage);
+                        alarmList.add(alarmMessage);
+                        break;
+                    }
+                }
+            }
+            if (!CollectionUtils.isEmpty(alarmList)) {
+                log.info("发送预警消息");
+                Map<String, Object> msg = new HashMap<>(2);
+                msg.put("predictTime", DateUtils.format(predictTime, DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND));
+                msg.put("alarmList", alarmList);
+                rabbitTemplate.convertAndSend(RoutingConstant.EXCHANGE, RoutingConstant.Iailab_Model_Alarm, msg);
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
 
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3