3 天以前 | 潘志宝 | ![]() |
3 天以前 | 潘志宝 | ![]() |
3 天以前 | 潘志宝 | ![]() |
3 天以前 | dengzedong | ![]() |
3 天以前 | dengzedong | ![]() |
3 天以前 | 潘志宝 | ![]() |
iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/HttpCollector.java
@@ -8,6 +8,7 @@ import com.iailab.framework.common.constant.CommonConstant; import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsdb; import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsdc; import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsde; import com.iailab.module.data.channel.http.collector.ihdb.HttpCollectorForIhd; import com.iailab.module.data.channel.http.entity.HttpApiEntity; @@ -37,6 +38,9 @@ @Autowired private HttpCollectorForAsde httpCollectorForAsde; @Autowired private HttpCollectorForAsdc httpCollectorForAsdc; public Object getTagValue(String apiId, String tag) { HttpApiEntity httpApi = httpApiService.getFromCatch(apiId); if (httpApi == null) { @@ -51,6 +55,8 @@ valueMap = httpCollectorForAsdb.getTagValues(apiId, tagNames); } else if (SourceApiEnum.ASDE.getCode().equals(httpApi.getCode())) { valueMap = httpCollectorForAsde.getTagValues(apiId, tagNames); } else if (SourceApiEnum.ASDC.getCode().equals(httpApi.getCode())) { valueMap = httpCollectorForAsdc.getTagValues(apiId, tagNames); } if (valueMap.get(tag) == null) { return CommonConstant.BAD_VALUE; iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/SourceApiEnum.java
@@ -13,7 +13,8 @@ public enum SourceApiEnum { iHyperDB("iHyperDB", "宝信IHD"), ASDB("ASDB", "鞍钢DB"), ASDE("ASDE", "鞍钢电力"); ASDE("ASDE", "鞍钢电力"), ASDC("ASDC", "鞍钢煤气"); private String code; private String desc; iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdc.java
对比新文件 @@ -0,0 +1,124 @@ package com.iailab.module.data.channel.http.collector.asdb; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.iailab.framework.common.constant.CommonConstant; import com.iailab.framework.common.util.http.HttpUtils; import com.iailab.module.data.channel.http.collector.asdb.vo.HttpAsdbRespDataVO; import com.iailab.module.data.channel.http.entity.HttpApiEntity; import com.iailab.module.data.channel.http.service.HttpApiService; import com.iailab.module.data.common.enums.DataSourceType; import com.iailab.module.data.common.utils.TagUtils; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; import org.springframework.util.CollectionUtils; import java.math.BigDecimal; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.concurrent.TimeUnit; /** * @author PanZhibao * @Description * @createTime 2025年03月28日 */ @Slf4j @Component public class HttpCollectorForAsdc { private static Map<String, HttpApiEntity> apiMap = new HashMap<>(); @Autowired private HttpApiService httpApiService; @Autowired private RedisTemplate redisTemplate; public static final long offset = 10; private HttpApiEntity getHttpApi(String id) { if (apiMap.containsKey(id)) { return apiMap.get(id); } HttpApiEntity httpApi = httpApiService.info(id); apiMap.put(id, httpApi); return httpApi; } public BigDecimal getTagValue(String sourceId, String tagNo) { BigDecimal value = CommonConstant.BAD_VALUE; HttpApiEntity httpApi = this.getHttpApi(sourceId); //先查缓存 String catchKey = "IailabData:" + httpApi.getCode() + ":" + tagNo; if (redisTemplate.hasKey(catchKey)) { log.info("查找IailabData缓存: " + catchKey); return new BigDecimal(redisTemplate.opsForValue().get(catchKey).toString()); } String responseStr = HttpUtils.sendGet(httpApi.getUrl(), null, ""); List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class); log.info("存入IailabData缓存: " + catchKey); dataList.forEach(item -> { redisTemplate.opsForValue().set(catchKey, item.getValue().toString(), offset, TimeUnit.SECONDS); }); for (HttpAsdbRespDataVO data : dataList){ if (tagNo.equals(data.getPoint())){ value = data.getValue(); break; } } return value; } public Map<String, Object> getTagValues(String sourceId, List<String> tagNames) { Map<String, Object> result = new HashMap<>(); try { if (CollectionUtils.isEmpty(tagNames)) { return result; } for (String tagName : tagNames) { result.put(tagName, getTagValue(sourceId, tagName)); } } catch (Exception ex) { log.info("getCurrentValue异常"); ex.printStackTrace(); throw ex; } return result; } public Map<String, Object> getTagValues(List<Object[]> params, Date collectTime) { Map<String, Object> result = new HashMap<>(); if (CollectionUtils.isEmpty(params)) { return new HashMap<>(); } try { HttpApiEntity httpApi = this.getHttpApi(params.get(0)[0].toString()); this.getByHtp(httpApi.getUrl(), httpApi.getCode(), result, params); } catch (Exception ex) { ex.printStackTrace(); } return result; } private void getByHtp(String url, String sourceName, Map<String, Object> result, List<Object[]> params) { log.info("HttpCollectorForAsdc.getByHtp:url=" + url); log.info("HttpCollectorForAsdc.getByHtp:params=" + JSONArray.toJSONString(params)); String responseStr = HttpUtils.sendGet(url, null, ""); log.info("HttpCollectorForAsdc.getByHtp:responseStr=" + responseStr); List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class); Map<String, HttpAsdbRespDataVO> valueGroup = new HashMap<>(); for (HttpAsdbRespDataVO data : dataList) { valueGroup.put(data.getPoint(), data); } for (Object[] item : params) { if (valueGroup.containsKey(item[1].toString())) { HttpAsdbRespDataVO data = valueGroup.get(item[1].toString()); result.put(TagUtils.genTagId(DataSourceType.HTTP.getCode(), sourceName, data.getPoint()), data.getValue()); } } } } iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsde.java
@@ -1,6 +1,7 @@ package com.iailab.module.data.channel.http.collector.asdb; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.iailab.framework.common.constant.CommonConstant; import com.iailab.framework.common.util.http.HttpUtils; import com.iailab.module.data.channel.http.collector.asdb.vo.HttpAsdbRespDataVO; @@ -104,7 +105,10 @@ } private void getByHtp(String url, String sourceName, Map<String, Object> result, List<Object[]> params) { log.info("HttpCollectorForAsde.getByHtp:url=" + url); log.info("HttpCollectorForAsde.getByHtp:params=" + JSONArray.toJSONString(params)); String responseStr = HttpUtils.sendGet(url, null, ""); log.info("HttpCollectorForAsde.getByHtp:responseStr=" + responseStr); List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class); Map<String, HttpAsdbRespDataVO> valueGroup = new HashMap<>(); for (HttpAsdbRespDataVO data : dataList) { iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/point/collection/handler/MeasureHandle.java
@@ -3,6 +3,7 @@ import com.iailab.framework.common.util.string.StrUtils; import com.iailab.module.data.channel.http.collector.SourceApiEnum; import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsdb; import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsdc; import com.iailab.module.data.channel.http.collector.asdb.HttpCollectorForAsde; import com.iailab.module.data.channel.http.collector.ihdb.HttpCollectorForIhd; import com.iailab.module.data.channel.opcda.collector.OpcDACollector; @@ -63,6 +64,9 @@ @Autowired private HttpCollectorForAsde httpCollectorForAsde; @Autowired private HttpCollectorForAsdc httpCollectorForAsdc; @Resource private DaPointService daPointService; @@ -83,6 +87,7 @@ List<Object[]> httpTagIhd = new ArrayList<>(); List<Object[]> httpTagAsdb = new ArrayList<>(); List<Object[]> httpTagAsde = new ArrayList<>(); List<Object[]> httpTagAsdc = new ArrayList<>(); dtos.stream().forEach(item -> { if (DataSourceType.OPCUA.getCode().equals(item.getSourceType())) { @@ -105,6 +110,10 @@ } else if (SourceApiEnum.ASDE.getCode().equals(item.getSourceName())) { if (item.getTagNo() != null && item.getDimension() != null && item.getValueType() != null) { httpTagAsde.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()}); } } else if (SourceApiEnum.ASDC.getCode().equals(item.getSourceName())) { if (item.getTagNo() != null && item.getDimension() != null && item.getValueType() != null) { httpTagAsdc.add(new Object[]{item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()}); } } } @@ -132,6 +141,9 @@ if (!CollectionUtils.isEmpty(httpTagAsde)) { tagValues.putAll(httpCollectorForAsde.getTagValues(httpTagAsde, collectTime)); } if (!CollectionUtils.isEmpty(httpTagAsdc)) { tagValues.putAll(httpCollectorForAsdc.getTagValues(httpTagAsdc, collectTime)); } this.toCommonResult(collectTime, dtos, tagValues, dataMap, result,listGood,listBad); log.info("测量点处理结束"); return result; @@ -155,7 +167,7 @@ pojo.setTimestamp(collectTime.toInstant()); result.add(pojo); listBad.add(dto.getPointNo()); System.out.println("值异常!TagId=" + tagId); log.info("值异常!TagId=" + tagId); } }); } @@ -221,6 +233,10 @@ value = httpCollectorForIhd.getTagValue(item.getSourceId(), item.getTagNo(), item.getDimension(), item.getValueType()); } else if (SourceApiEnum.ASDB.getCode().equals(item.getSourceName())) { value = httpCollectorForAsdb.getTagValue(item.getSourceId(), item.getTagNo()); } else if (SourceApiEnum.ASDE.getCode().equals(item.getSourceName())) { value = httpCollectorForAsde.getTagValue(item.getSourceId(), item.getTagNo()); } else if (SourceApiEnum.ASDC.getCode().equals(item.getSourceName())) { value = httpCollectorForAsdc.getTagValue(item.getSourceId(), item.getTagNo()); } } else { log.info("没有匹配的TagNo=" + item.getTagNo()); iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/sche/dao/StScheduleSchemeDao.java
@@ -9,6 +9,7 @@ import com.iailab.module.model.api.mcs.dto.StAlarmAndSuggestRespVO; import com.iailab.module.model.mcs.sche.entity.StScheduleSchemeEntity; import com.iailab.module.model.mcs.sche.vo.StScheduleSchemePageReqVO; import org.apache.ibatis.annotations.Delete; import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Param; @@ -34,4 +35,7 @@ default IPage<StAlarmAndSuggestRespVO> selectAlarmAndSuggestPageList(StAlarmAndSuggestPageReqVO reqVO) { return getAlarmAndSuggestPage(getPage(reqVO), reqVO); } @Delete("DELETE FROM t_st_schedule_scheme WHERE id = #{id}") void physicsDeleteById(String id); } iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/sche/service/impl/StScheduleSchemeServiceImpl.java
@@ -50,7 +50,7 @@ @Override public void delete(String id) { baseDao.deleteById(id); baseDao.physicsDeleteById(id); } @Override