From 56e254f4c6a3eab1218a4fbea3f60609d209ff95 Mon Sep 17 00:00:00 2001 From: 潘志宝 <979469083@qq.com> Date: 星期五, 27 六月 2025 14:19:26 +0800 Subject: [PATCH] 鞍信平均值 --- iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdb.java | 214 ++++++++++++----------------------------------------- 1 files changed, 49 insertions(+), 165 deletions(-) diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdb.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdb.java index 6b34fec..f8fc261 100644 --- a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdb.java +++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/channel/http/collector/asdb/HttpCollectorForAsdb.java @@ -8,18 +8,16 @@ 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 com.iailab.module.data.point.common.MeasurePointValueType; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.data.redis.core.BoundHashOperations; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; import org.springframework.util.CollectionUtils; import java.math.BigDecimal; -import java.math.RoundingMode; import java.util.*; import java.util.concurrent.*; -import java.util.stream.Collectors; /** * AnSteelDB采集 @@ -29,7 +27,6 @@ @Slf4j @Component public class HttpCollectorForAsdb { - private static Map<String, HttpApiEntity> apiMap = new HashMap<>(); @Autowired private HttpApiService httpApiService; @@ -37,109 +34,47 @@ @Autowired private RedisTemplate redisTemplate; - ThreadPoolExecutor threadPool = new ThreadPoolExecutor(18, 36, 30, TimeUnit.SECONDS, - new ArrayBlockingQueue<Runnable>(36), new ThreadPoolExecutor.AbortPolicy()); + @Autowired + private HttpCollectorForAsag httpCollectorForAsag; - private static final String STA_TRUE = "true"; - - private static final int GROUP_MAX_COUNT = 300; - - private static final int MAX_WAIT = 30; - - private static final String pattern = "yyyyMMddHHmm00"; - - private static final String IS_SUCCESS = "isSuccess"; - - /** - * tagName - */ - private static final String N = "n"; - - /** - * dimension - */ - private static final String D = "d"; - - /** - * 类型 - */ - private static final String P = "p"; - - /** - * dataValue - */ - private static final String V = "v"; - - /** - * dataTime - */ - private static final String T = "t"; - - /** - * 数据质量G:good,B:bad - */ - private static final String Q = "q"; + 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; + return httpApiService.getFromCatch(id); } - public BigDecimal getTagValue(String sourceId, String tagNo, Integer dimension, String valueType) { + public BigDecimal getTagValue(String sourceId, String tagNo) { BigDecimal value = CommonConstant.BAD_VALUE; HttpApiEntity httpApi = this.getHttpApi(sourceId); - String responseStr = HttpUtils.sendGet(httpApi.getUrl(), null, ""); - if (responseStr == null) { - return value; + //先查缓存 + 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); - value = Objects.requireNonNull(dataList.stream().filter(data -> tagNo.equals(data.getPoint())).findFirst().orElse(null)).getValue(); + log.info("存入IailabData缓存: " + catchKey); + dataList.forEach(item -> { + redisTemplate.opsForValue().set("IailabData:" + httpApi.getCode() + ":" + item.getPoint(), 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> getLastValues(String sourceId, List<String> tagNames) { + public Map<String, Object> getTagValues(String sourceId, List<String> tagNames) { Map<String, Object> result = new HashMap<>(); - HttpApiEntity httpApi = this.getHttpApi(sourceId); try { if (CollectionUtils.isEmpty(tagNames)) { return result; } - List<String> noCacheTagNames = new ArrayList<>();//未缓存的tag - for (int i = 0; i < tagNames.size(); i++) { - //先查缓存 - BoundHashOperations<String, String, Object> ops = redisTemplate.boundHashOps(tagNames.get(i)); - if (ops.get(V) != null) { - BigDecimal value = new BigDecimal(ops.get(V).toString()); - result.put(tagNames.get(i), value.setScale(3, RoundingMode.HALF_UP)); - } else { - noCacheTagNames.add(tagNames.get(i)); - } - } - if (CollectionUtils.isEmpty(noCacheTagNames)) { - log.info("全部读取缓存"); - return result; - } - log.info("查询未缓存的数据"); - String responseStr = HttpUtils.sendGet(httpApi.getUrl(), null, ""); - List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class); - List<HttpAsdbRespDataVO> noCacheDataList = dataList.stream().filter(data -> noCacheTagNames.contains(data.getPoint())).collect(Collectors.toList()); - for (HttpAsdbRespDataVO data : noCacheDataList ){ - if (data.getValue() != null){ - //存缓存 - BoundHashOperations<String, String, Object> ops = redisTemplate.boundHashOps(data.getValue().toString()); - ops.put(V, data.getValue().toString()); - //设置过期时间 - redisTemplate.expire(data.getValue().toString(), 10, TimeUnit.SECONDS); - //把查询到的数据插入结果集 - BigDecimal value = new BigDecimal(data.getValue().toString()); - result.put(data.getPoint(), value.setScale(3, RoundingMode.HALF_UP)); - } else { - result.put(data.getPoint(), CommonConstant.BAD_VALUE); - } + for (String tagName : tagNames) { + result.put(tagName, getTagValue(sourceId, tagName)); } } catch (Exception ex) { log.info("getCurrentValue异常"); @@ -155,93 +90,42 @@ return new HashMap<>(); } try { - Map<Integer, List<Object[]>> measurePointsCountGroup = new HashMap<>(); - int pointListSize = params.size(); - int groupCount = pointListSize / GROUP_MAX_COUNT + ((pointListSize % GROUP_MAX_COUNT) > 0 ? 1 : 0); - log.info("groupCount=" + groupCount); - for (int i = 0; i < groupCount; i++) { - int end = (i + 1) * GROUP_MAX_COUNT; - if (end > pointListSize) { - end = pointListSize; + List<Object[]> paramsSim = new ArrayList<>(); + List<Object[]> paramsDig = new ArrayList<>(); + for (Object[] param : params) { + if (((String) param[3]).equals(MeasurePointValueType.DIGITAL.getCode()) || (Integer) param[2] == 0) { + paramsDig.add(param); + } else { + paramsSim.add(param); } - measurePointsCountGroup.put(i, params.subList(i * GROUP_MAX_COUNT, end)); } - log.info("measurePointsCountGroup.size()=" + measurePointsCountGroup.size()); - result = new ConcurrentHashMap<>(params.size()); - CountDownLatch countDownLatch = new CountDownLatch(measurePointsCountGroup.size()); - for (Map.Entry<Integer, List<Object[]>> measurePointsItem : measurePointsCountGroup.entrySet()) { - HttpApiEntity httpApi = this.getHttpApi(measurePointsItem.getValue().get(0)[0].toString()); - // 并发 - Thread.sleep(1000); - threadPool.submit(new Task(httpApi.getUrl(), httpApi.getCode(), result, measurePointsItem.getValue(), - collectTime, countDownLatch)); - // 顺序 - //this.getByHtp(result, measurePointsItem.getValue(), collectTime); + if (!CollectionUtils.isEmpty(paramsDig)) { + log.info("查询数字量,paramsDig.size(): " + paramsDig.size()); + HttpApiEntity httpApi = this.getHttpApi(params.get(0)[0].toString()); + this.getByHtp(httpApi.getUrl(), httpApi.getCode(), result, params); } - countDownLatch.await(MAX_WAIT, TimeUnit.SECONDS); - + if (!CollectionUtils.isEmpty(paramsSim)) { + log.info("查询模拟量,paramsSim.size(): " + paramsSim.size()); + httpCollectorForAsag.getTagValues(paramsSim, collectTime, result); + } } catch (Exception ex) { ex.printStackTrace(); } return result; } - /** - * 异步采集任务 - */ - private class Task implements Runnable { - String url; - String sourceName; - Date collectTime; - Map<String, Object> result; - List<Object[]> params; - CountDownLatch countDownLatch; - - public Task(String url, String sourceName, Map<String, Object> result, List<Object[]> params, - Date collectTime, CountDownLatch countDownLatch) { - this.url = url; - this.sourceName = sourceName; - this.result = result; - this.collectTime = collectTime; - this.params = params; - this.countDownLatch = countDownLatch; + private void getByHtp(String url, String sourceName, Map<String, Object> result, List<Object[]> params) { + String responseStr = HttpUtils.sendGet(url, null, ""); + List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class); + Map<String, HttpAsdbRespDataVO> valueGroup = new HashMap<>(); + for (HttpAsdbRespDataVO data : dataList) { + valueGroup.put(data.getPoint(), data); } - - @Override - public void run() { - try { - log.info("请求的Tag数量:" + params.size()); - this.getByHtp(url, sourceName, result, params, collectTime); - log.info("请求结束:url=" + url); - } catch (Exception ex) { - log.info("获取采集值失败," + ex.getMessage()); - ex.printStackTrace(); - } finally { - countDownLatch.countDown(); - } - } - - /** - * getTagDataByHttp - * - * @param url - * @param sourceName - * @param result - * @param params - * @param collectTime - */ - private void getByHtp(String url, String sourceName, Map<String, Object> result, List<Object[]> params, Date collectTime) { - String responseStr = HttpUtils.sendGet(url, null, ""); - List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class); - for (HttpAsdbRespDataVO data : dataList){ + 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()); } } } - - private void getByHtp(String url, String sourceName, Map<String, Object> result, List<Object[]> params, Date collectTime) {String responseStr = HttpUtils.sendGet(url, null, ""); - List<HttpAsdbRespDataVO> dataList = JSON.parseArray(responseStr, HttpAsdbRespDataVO.class); - for (HttpAsdbRespDataVO data : dataList){ - result.put(TagUtils.genTagId(DataSourceType.HTTP.getCode(), sourceName, data.getPoint()), data.getValue()); - }} } \ No newline at end of file -- Gitblit v1.9.3