From 0cde5bc8719ef589a9290a9d29f5fbd5e9d3c5be Mon Sep 17 00:00:00 2001
From: 沈斌 <bluelazysb@hotmail.com>
Date: Wed, 15 Nov 2017 14:48:56 +0800
Subject: [PATCH] test

---
 src/main/java/com/moral/monitor/listener/TaskListener.java |   91 ++++++++++++++++++++++++++++++++-------------
 1 files changed, 65 insertions(+), 26 deletions(-)

diff --git a/src/main/java/com/moral/monitor/listener/TaskListener.java b/src/main/java/com/moral/monitor/listener/TaskListener.java
index 3dfe83a..201718a 100644
--- a/src/main/java/com/moral/monitor/listener/TaskListener.java
+++ b/src/main/java/com/moral/monitor/listener/TaskListener.java
@@ -52,8 +52,12 @@
     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 {
@@ -126,34 +130,69 @@
 		     logger.error(e.getMessage());
 		}
     }
-    //���������������������
-    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 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,String> data) {
+    private int detEquState(Map<String,String> data) throws IOException {
+
+        Map<String,Double[]> alarmLevles = getAlarmLevels();
+
     	int state = 0;
     	Map<String, Object> equMap = new HashMap<String, Object>();
     	String mac = data.get("mac");

--
Gitblit v1.8.0