From 875ade2caa81f3c42554d554ebe1f649c21a3447 Mon Sep 17 00:00:00 2001 From: 沈斌 <bluelazysb@hotmail.com> Date: Wed, 28 Feb 2018 16:41:25 +0800 Subject: [PATCH] test --- src/main/java/com/moral/monitor/listener/TaskListener.java | 373 ++++++++++++++++++++++++++++++++++------------------- 1 files changed, 238 insertions(+), 135 deletions(-) diff --git a/src/main/java/com/moral/monitor/listener/TaskListener.java b/src/main/java/com/moral/monitor/listener/TaskListener.java index e346459..11612fb 100644 --- a/src/main/java/com/moral/monitor/listener/TaskListener.java +++ b/src/main/java/com/moral/monitor/listener/TaskListener.java @@ -1,135 +1,238 @@ -package com.moral.monitor.listener; - -import com.alibaba.fastjson.JSON; -import com.alibaba.fastjson.TypeReference; -import com.moral.monitor.dao.JobDao; -import com.moral.monitor.dao.TaskDao; -import com.moral.monitor.entity.History; -import com.moral.monitor.entity.Sensor; -import com.moral.monitor.util.RedisUtil; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; -import org.springframework.amqp.core.Message; -import org.springframework.amqp.core.MessageListener; -import org.springframework.amqp.core.MessageProperties; -import org.springframework.amqp.rabbit.connection.CachingConnectionFactory; -import org.springframework.amqp.rabbit.connection.Connection; -import org.springframework.amqp.rabbit.core.RabbitTemplate; -import org.springframework.data.redis.core.RedisTemplate; -import org.springframework.util.StringUtils; - -import javax.annotation.Resource; -import java.io.UnsupportedEncodingException; -import java.math.BigDecimal; -import java.text.SimpleDateFormat; -import java.util.*; - -public class TaskListener implements MessageListener { - - @Resource - RabbitTemplate rabbitTemplate; - - @Resource - JobDao jobDao; - - @Resource - TaskDao taskDao; - - @Resource - RedisTemplate<String, String> redisTemplate; - - private Logger logger = LoggerFactory.getLogger(TaskListener.class); - - @Override - public void onMessage(Message msg) { - - String message = null; - try { - message = new String(msg.getBody(), "utf-8"); - } catch (UnsupportedEncodingException e) { - logger.warn(e.getMessage()); - } - - Map<String, String> msgData = JSON.parseObject(message, new TypeReference<Map<String, String>>() {}); - String mac = msgData.get("mac"); - String ver = msgData.get("ver"); - - 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()) { - for (Map.Entry<String, Float> entry : adjustMap.entrySet()) { - String key = entry.getKey(); - if(msgData.containsKey(key)) { - Float value = entry.getValue(); - Float dataValue = Float.valueOf(msgData.get(key)) ; - msgData.put(key, String.valueOf(dataValue + value)); - } - } - } - -// 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())); - - int state = (new Random()).nextInt(4) % 5; //TODO -// rabbitTemplate.convertAndSend("monitors_alarm", "", "{\"mac\": \"" + mac + "\", \"state\": " + state + "}"); - - //������������������ - jobDao.updateStateByMac(mac, state); - - //������������������ - taskDao.insertTologger(mac, message, getDate()); - - //������������������ - List<History> histories = new ArrayList<History>(); - List<Sensor> sensorList = taskDao.selectFromsensorByver(ver); - for (Sensor sensor : sensorList) { - String key = sensor.getMac_key(); - if(msgData.containsKey(key)) { - //taskDao.insertTohistory(mac, sensor.getSensor(), key, msgData.get(key)); - History history = new History(); - history.setMac(mac); - history.setMac_key(key); - history.setSensor(sensor.getSensor()); - history.setMac_value(Double.valueOf(msgData.get(key))); - histories.add(history); - } - } - 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; - } - - private String getDate() { - Date d = new Date(); - SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); - return formatter.format(d); - } -} +package com.moral.monitor.listener; + +import java.io.IOException; +import java.io.InputStreamReader; +import java.io.UnsupportedEncodingException; +import java.math.BigDecimal; +import java.text.SimpleDateFormat; +import java.util.ArrayList; +import java.util.Date; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +import javax.annotation.Resource; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.amqp.core.Message; +import org.springframework.amqp.core.MessageListener; +import org.springframework.amqp.rabbit.core.RabbitTemplate; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.core.io.ClassPathResource; +import org.springframework.data.mongodb.core.MongoTemplate; +import org.springframework.data.redis.core.RedisTemplate; +import org.springframework.util.StringUtils; + +import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.JSONReader; +import com.alibaba.fastjson.TypeReference; +import com.moral.monitor.dao.JobDao; +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 { + + @Resource + RabbitTemplate rabbitTemplate; + + @Resource + JobDao jobDao; + + @Resource + TaskDao taskDao; + + @Resource + RedisTemplate<String, String> redisTemplate; + + @Resource + protected MongoTemplate mongoTemplate; + + private Logger logger = LoggerFactory.getLogger(TaskListener.class); + + @Resource + RedisService redisService; + + private String levelKey = "alarm_level_config"; + + @Override + public void onMessage(Message msg) { + try { + String message = null; + try { + message = new String(msg.getBody(), "utf-8"); + } catch (UnsupportedEncodingException e) { + logger.warn(e.getMessage()); + } + + Map<String, Object> msgData = JSON.parseObject(message, new TypeReference<Map<String, Object>>() {}); + Object obj_mac = msgData.get("mac"); + Object obj_ver = msgData.get("ver"); + if(obj_ver == null || obj_mac == null) { + return; + } + String mac = obj_mac.toString(); + String ver = obj_ver.toString(); + if(StringUtils.isEmpty(ver) || StringUtils.isEmpty(mac)) { + return; + } + //���������������������������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)) { + Float value = entry.getValue(); + Float dataValue = Float.valueOf(msgData.get(key).toString()) ; + msgData.put(key, dataValue + value); + } + } + } +// System.out.println(message); +// System.out.println(JSON.toJSONString(msgData)); + + 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); +// rabbitTemplate.convertAndSend("monitors_alarm", "", "{\"mac\": \"" + mac + "\", \"state\": " + state + "}"); + + //������������������ + jobDao.updateStateByMac(mac, state); + +// //������������������ +// taskDao.insertTologger(mac, message, getDate()); + mongoTemplate.insert(message, "logger"); + + + //������������������ + List<History> histories = new ArrayList<History>(); + List<Sensor> sensorList = taskDao.selectFromsensorByver(ver); + for (Sensor sensor : sensorList) { + String key = sensor.getMac_key(); + if(msgData.containsKey(key)) { + //taskDao.insertTohistory(mac, sensor.getSensor(), key, msgData.get(key)); + History history = new History(); + history.setMac(mac); + history.setMac_key(key); + history.setTime(new Date(Long.parseLong(msgData.get("time").toString()))); + history.setSensor(sensor.getSensor()); + history.setMac_value(Double.valueOf(msgData.get(key).toString())); + histories.add(history); + } + } + jobDao.batchInsertHistory(histories); + + + //mongoTemplate.insert(JSON.toJSONString(histories), "data"); + mongoTemplate.insert(new_message, "data"); + } catch (Exception e) { + //������������ + logger.error(e.getMessage()); + e.printStackTrace(); + } + } +// //��������������������� +// private static Map<String,Double[]> alarmLevles =new HashMap<String, Double[]>(); +// /* +// * ������������������������,���map��������������������������������� +// */ +// @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()); +// JSONReader jsonReader = new JSONReader(reader); +// //��������������������� +// Map<String,Map<String,Double>> alarmLevleMap= jsonReader.readObject(new TypeReference<Map<String,Map<String,Double>>>(){}); +// //���map��������������� +// for(String key:alarmLevleMap.keySet()) { +// Map<String,Double> levels = alarmLevleMap.get(key); +// double level1 = levels.get("level1"); +// double level2 = levels.get("level2"); +// double level3 = levels.get("level3"); +// //������������������������������������������ +// if(levels.get("enable")!=null&&levels.get("enable")==1) { +// //������������������ +// Double arr[] = {0.0,level1,level2,level3}; +// alarmLevles.put(key, arr); +// } +// } +// } + + private Map<String,Double[]> getAlarmLevels() throws IOException { + + Map<String,Map<String,Double>> alarmLevleMap = null; + Map<String,Double[]> alarmLevles = new HashMap<String, Double[]>(); + if(RedisUtil.hasKey(redisTemplate, levelKey)) { + String levelConfigStr = RedisUtil.get(redisTemplate, levelKey); + alarmLevleMap = JSON.parseObject(levelConfigStr, new TypeReference<Map<String, Map<String,Double>>>() {}); + } else { + org.springframework.core.io.Resource resource = new ClassPathResource("system/alarmLevels.json"); + InputStreamReader reader = new InputStreamReader(resource.getInputStream()); + JSONReader jsonReader = new JSONReader(reader); + //��������������������� + alarmLevleMap= jsonReader.readObject(new TypeReference<Map<String,Map<String,Double>>>(){}); + } + + //���map��������������� + for(String key:alarmLevleMap.keySet()) { + Map<String,Double> levels = alarmLevleMap.get(key); + double level1 = levels.get("level1"); + double level2 = levels.get("level2"); + double level3 = levels.get("level3"); + //������������������������������������������ + if(levels.get("enable")!=null&&levels.get("enable")==1) { + //������������������ + Double arr[] = {0.0,level1,level2,level3}; + alarmLevles.put(key, arr); + } + } + return alarmLevles; + } + + //��������������������������������������������� + private int detEquState(Map<String,Object> data) throws IOException { + + Map<String,Double[]> alarmLevles = getAlarmLevels(); + + int state = 0; + Map<String, Object> equMap = new HashMap<String, Object>(); + String mac = data.get("mac").toString(); + equMap.putAll(data); + if(data!=null) { + for(String key:alarmLevles.keySet()) { + String value = data.get(key).toString(); + if(!StringUtils.isEmpty(value)) { + double val = Double.parseDouble(value); + //������������������������ + Double[] arr = alarmLevles.get(key); + for(int index = arr.length-1;index>0;index--) { + if(val>=arr[index]) { + //��������������������������������������������������������������������������� + state = (index>state)?index:state; + 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; + } + } + } + } + } + equMap.put("state", state);//������������ + redisService.setEquState(mac,equMap); + return state; + } +} -- Gitblit v1.8.0