From 45be44fb95325305373647231ef74e72d1501f8c Mon Sep 17 00:00:00 2001 From: 沈斌 <bluelazysb@hotmail.com> Date: Sat, 11 Nov 2017 08:08:22 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- src/main/java/com/moral/monitor/listener/TaskListener.java | 70 ++++++++++++++--------------------- 1 files changed, 28 insertions(+), 42 deletions(-) diff --git a/src/main/java/com/moral/monitor/listener/TaskListener.java b/src/main/java/com/moral/monitor/listener/TaskListener.java index a3c85fb..93462e8 100644 --- a/src/main/java/com/moral/monitor/listener/TaskListener.java +++ b/src/main/java/com/moral/monitor/listener/TaskListener.java @@ -31,6 +31,7 @@ import com.moral.monitor.dao.TaskDao; import com.moral.monitor.entity.History; import com.moral.monitor.entity.Sensor; +import com.moral.monitor.service.RedisService; import com.moral.monitor.util.RedisUtil; public class TaskListener implements MessageListener { @@ -51,7 +52,8 @@ protected MongoTemplate mongoTemplate; private Logger logger = LoggerFactory.getLogger(TaskListener.class); - + @Resource + RedisService redisService; @Override public void onMessage(Message msg) { @@ -69,17 +71,9 @@ if(StringUtils.isEmpty(ver) || StringUtils.isEmpty(mac)) { return; } - - Map<String, Float> adjustMap; - String adjust_key = "adjust_" + mac; - if(RedisUtil.hasKey(redisTemplate, adjust_key)) { - adjustMap = JSON.parseObject(RedisUtil.get(redisTemplate, adjust_key), new TypeReference<Map<String, Float>>() {}); - } else { - adjustMap = getAdjustData(mac); - RedisUtil.set(redisTemplate, adjust_key, JSON.toJSONString(adjustMap)); - } - - if(!adjustMap.isEmpty()) { + //���������������������������map + Map<String, Float> adjustMap = redisService.getAdjustsByMac(mac); + if(adjustMap!=null&&!adjustMap.isEmpty()) { for (Map.Entry<String, Float> entry : adjustMap.entrySet()) { String key = entry.getKey(); if(msgData.containsKey(key)) { @@ -89,12 +83,12 @@ } } } - // System.out.println(message); // System.out.println(JSON.toJSONString(msgData)); - rabbitTemplate.convertAndSend("monitors_data2", "", JSON.toJSONString(msgData).getBytes()); -// rabbitTemplate.send("monitors_data_3", "", new Message(JSON.toJSONString(msgData).getBytes(), new MessageProperties())); + String new_message = JSON.toJSONString(msgData); + rabbitTemplate.convertAndSend("monitors_data2", "", new_message.getBytes()); +// rabbitTemplate.send("monitors_data2", "", new Message(JSON.toJSONString(msgData).getBytes(), new MessageProperties())); // int state = (new Random()).nextInt(4) % 5; //TODO int state = detEquState(msgData); @@ -124,29 +118,16 @@ } } jobDao.batchInsertHistory(histories); - } - private Map<String, Float> getAdjustData(String mac) { - List<Map<String, String>> adjusts = jobDao.findAdjustByMac(mac); - Map<String, Float> dataMap = new HashMap<String, Float>(); - for (int i = 0; i < adjusts.size(); i++) { - Map adjust = adjusts.get(i); - if(adjust.get("value") != null) { - String key = String.valueOf(adjust.get("key")); - String data = String.valueOf(adjust.get("value")); - BigDecimal value = new BigDecimal(data); - value.setScale(3, BigDecimal.ROUND_HALF_UP); - dataMap.put(key, value.floatValue()); - } - } - return dataMap; + //mongoTemplate.insert(JSON.toJSONString(histories), "data"); + mongoTemplate.insert(new_message, "data"); } //��������������������� private static Map<String,Double[]> alarmLevles =new HashMap<String, Double[]>(); /* * ������������������������,���map��������������������������������� */ - @Value(value="alarmLevels.json") + @Value(value= "system/alarmLevels.json") public void setAlarmLevles(String path) throws IOException { org.springframework.core.io.Resource resource = new ClassPathResource(path); InputStreamReader reader=new InputStreamReader(resource.getInputStream()); @@ -160,7 +141,7 @@ double level2 = levels.get("level2"); double level3 = levels.get("level3"); //������������������������������������������ - if(level1!=0&&level2!=0&&level3!=0) { + if(levels.get("enable")!=null&&levels.get("enable")==1) { //������������������ Double arr[] = {0.0,level1,level2,level3}; alarmLevles.put(key, arr); @@ -170,6 +151,7 @@ //��������������������������������������������� private int detEquState(Map<String,String> data) { int state = 0; + Map<String, Object> equMap = new HashMap<String, Object>(); if(data!=null) { for(String key:alarmLevles.keySet()) { String value = data.get(key); @@ -181,21 +163,25 @@ if(val>=arr[index]) { //��������������������������������������������������������������������������� state = (index>state)?index:state; - break; + String e_key = "level"+Integer.toString(index); + Object e_States = equMap.get(e_key); + if(e_States!=null&&e_States instanceof List) { + ((List)e_States).add(key); + }else { + e_States = new ArrayList<String>(); + equMap.put(e_key, e_States); + ((List)e_States).add(key); + + } + equMap.put(e_key, e_States); + break; } - } - //��������������������������������������������������������� - if(state == (arr.length-1)) { - break; } } } } + equMap.put("state", state);//������������ + redisService.setEquState(data.get("mac"),equMap); return state; - } - private String getDate() { - Date d = new Date(); - SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); - return formatter.format(d); } } -- Gitblit v1.8.0