优化CivilCode缓存
parent
e1c8183adf
commit
d4f6ec39b7
|
@ -1,7 +1,7 @@
|
||||||
package com.genersoft.iot.vmp.conf;
|
package com.genersoft.iot.vmp.conf;
|
||||||
|
|
||||||
import com.genersoft.iot.vmp.common.CivilCodePo;
|
import com.genersoft.iot.vmp.common.CivilCodePo;
|
||||||
import org.ehcache.impl.internal.concurrent.ConcurrentHashMap;
|
import com.genersoft.iot.vmp.utils.CivilCodeUtil;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
@ -17,7 +17,8 @@ import java.io.File;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.nio.file.Files;
|
import java.nio.file.Files;
|
||||||
import java.util.Map;
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 启动时读取行政区划表
|
* 启动时读取行政区划表
|
||||||
|
@ -28,8 +29,6 @@ public class CivilCodeFileConf implements CommandLineRunner {
|
||||||
|
|
||||||
private final static Logger logger = LoggerFactory.getLogger(CivilCodeFileConf.class);
|
private final static Logger logger = LoggerFactory.getLogger(CivilCodeFileConf.class);
|
||||||
|
|
||||||
private final Map<String, CivilCodePo> civilCodeMap= new ConcurrentHashMap<>();
|
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
@Lazy
|
@Lazy
|
||||||
private UserSetting userSetting;
|
private UserSetting userSetting;
|
||||||
|
@ -62,6 +61,7 @@ public class CivilCodeFileConf implements CommandLineRunner {
|
||||||
BufferedReader inputStreamReader = new BufferedReader(new InputStreamReader(inputStream));
|
BufferedReader inputStreamReader = new BufferedReader(new InputStreamReader(inputStream));
|
||||||
int index = -1;
|
int index = -1;
|
||||||
String line;
|
String line;
|
||||||
|
List<CivilCodePo> civilCodePoList = new ArrayList<>();
|
||||||
while ((line = inputStreamReader.readLine()) != null) {
|
while ((line = inputStreamReader.readLine()) != null) {
|
||||||
index ++;
|
index ++;
|
||||||
if (index == 0) {
|
if (index == 0) {
|
||||||
|
@ -69,36 +69,15 @@ public class CivilCodeFileConf implements CommandLineRunner {
|
||||||
}
|
}
|
||||||
String[] infoArray = line.split(",");
|
String[] infoArray = line.split(",");
|
||||||
CivilCodePo civilCodePo = CivilCodePo.getInstance(infoArray);
|
CivilCodePo civilCodePo = CivilCodePo.getInstance(infoArray);
|
||||||
civilCodeMap.put(civilCodePo.getCode(), civilCodePo);
|
civilCodePoList.add(civilCodePo);
|
||||||
}
|
}
|
||||||
|
CivilCodeUtil.INSTANCE.add(civilCodePoList);
|
||||||
inputStreamReader.close();
|
inputStreamReader.close();
|
||||||
inputStream.close();
|
inputStream.close();
|
||||||
if (civilCodeMap.size() == 0) {
|
if (civilCodePoList.isEmpty()) {
|
||||||
logger.warn("[行政区划] 文件内容为空,可能造成目录刷新结果不完整");
|
logger.warn("[行政区划] 文件内容为空,可能造成目录刷新结果不完整");
|
||||||
}else {
|
}else {
|
||||||
logger.info("[行政区划] 加载成功,共加载数据{}条", civilCodeMap.size());
|
logger.info("[行政区划] 加载成功,共加载数据{}条", civilCodePoList.size());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public CivilCodePo getParentCode(String code) {
|
|
||||||
if (code.length() > 8) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
if (code.length() == 8) {
|
|
||||||
String parentCode = code.substring(0, 6);
|
|
||||||
return civilCodeMap.get(parentCode);
|
|
||||||
}else {
|
|
||||||
CivilCodePo civilCodePo = civilCodeMap.get(code);
|
|
||||||
if (civilCodePo == null){
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
String parentCode = civilCodePo.getParentCode();
|
|
||||||
if (parentCode == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return civilCodeMap.get(parentCode);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -108,7 +108,7 @@ public class NotifyRequestForCatalogProcessor extends SIPRequestProcessorParent
|
||||||
}else {
|
}else {
|
||||||
event = eventElement.getText().toUpperCase();
|
event = eventElement.getText().toUpperCase();
|
||||||
}
|
}
|
||||||
DeviceChannel channel = XmlUtil.channelContentHandler(itemDevice, device, event, civilCodeFileConf);
|
DeviceChannel channel = XmlUtil.channelContentHandler(itemDevice, device, event);
|
||||||
if (channel == null) {
|
if (channel == null) {
|
||||||
logger.info("[收到目录订阅]:但是解析失败 {}", new String(evt.getRequest().getRawContent()));
|
logger.info("[收到目录订阅]:但是解析失败 {}", new String(evt.getRequest().getRawContent()));
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.response.cmd;
|
package com.genersoft.iot.vmp.gb28181.transmit.event.request.impl.message.response.cmd;
|
||||||
|
|
||||||
import com.genersoft.iot.vmp.conf.CivilCodeFileConf;
|
|
||||||
import com.genersoft.iot.vmp.conf.SipConfig;
|
import com.genersoft.iot.vmp.conf.SipConfig;
|
||||||
import com.genersoft.iot.vmp.gb28181.bean.*;
|
import com.genersoft.iot.vmp.gb28181.bean.*;
|
||||||
import com.genersoft.iot.vmp.gb28181.session.CatalogDataCatch;
|
import com.genersoft.iot.vmp.gb28181.session.CatalogDataCatch;
|
||||||
|
@ -57,9 +56,6 @@ public class CatalogResponseMessageHandler extends SIPRequestProcessorParent imp
|
||||||
@Autowired
|
@Autowired
|
||||||
private ThreadPoolTaskExecutor taskExecutor;
|
private ThreadPoolTaskExecutor taskExecutor;
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private CivilCodeFileConf civilCodeFileConf;
|
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private SipConfig sipConfig;
|
private SipConfig sipConfig;
|
||||||
private AtomicBoolean processing = new AtomicBoolean(false);
|
private AtomicBoolean processing = new AtomicBoolean(false);
|
||||||
|
@ -118,7 +114,7 @@ public class CatalogResponseMessageHandler extends SIPRequestProcessorParent imp
|
||||||
if (channelDeviceElement == null) {
|
if (channelDeviceElement == null) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
DeviceChannel channel = XmlUtil.channelContentHandler(itemDevice, device, null, civilCodeFileConf);
|
DeviceChannel channel = XmlUtil.channelContentHandler(itemDevice, device, null);
|
||||||
if (channel == null) {
|
if (channel == null) {
|
||||||
logger.info("[收到目录订阅]:但是解析失败 {}", new String(evt.getRequest().getRawContent()));
|
logger.info("[收到目录订阅]:但是解析失败 {}", new String(evt.getRequest().getRawContent()));
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -3,10 +3,10 @@ package com.genersoft.iot.vmp.gb28181.utils;
|
||||||
import com.alibaba.fastjson2.JSONArray;
|
import com.alibaba.fastjson2.JSONArray;
|
||||||
import com.alibaba.fastjson2.JSONObject;
|
import com.alibaba.fastjson2.JSONObject;
|
||||||
import com.genersoft.iot.vmp.common.CivilCodePo;
|
import com.genersoft.iot.vmp.common.CivilCodePo;
|
||||||
import com.genersoft.iot.vmp.conf.CivilCodeFileConf;
|
|
||||||
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
||||||
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
|
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
|
||||||
import com.genersoft.iot.vmp.gb28181.event.subscribe.catalog.CatalogEvent;
|
import com.genersoft.iot.vmp.gb28181.event.subscribe.catalog.CatalogEvent;
|
||||||
|
import com.genersoft.iot.vmp.utils.CivilCodeUtil;
|
||||||
import com.genersoft.iot.vmp.utils.DateUtil;
|
import com.genersoft.iot.vmp.utils.DateUtil;
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.apache.commons.lang3.math.NumberUtils;
|
import org.apache.commons.lang3.math.NumberUtils;
|
||||||
|
@ -240,7 +240,7 @@ public class XmlUtil {
|
||||||
CivilCode, BusinessGroup,VirtualOrganization,Other
|
CivilCode, BusinessGroup,VirtualOrganization,Other
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DeviceChannel channelContentHandler(Element itemDevice, Device device, String event, CivilCodeFileConf civilCodeFileConf){
|
public static DeviceChannel channelContentHandler(Element itemDevice, Device device, String event){
|
||||||
DeviceChannel deviceChannel = new DeviceChannel();
|
DeviceChannel deviceChannel = new DeviceChannel();
|
||||||
deviceChannel.setDeviceId(device.getDeviceId());
|
deviceChannel.setDeviceId(device.getDeviceId());
|
||||||
Element channdelIdElement = itemDevice.element("DeviceID");
|
Element channdelIdElement = itemDevice.element("DeviceID");
|
||||||
|
@ -267,7 +267,7 @@ public class XmlUtil {
|
||||||
}
|
}
|
||||||
if(channelId.length() <= 8) {
|
if(channelId.length() <= 8) {
|
||||||
deviceChannel.setHasAudio(false);
|
deviceChannel.setHasAudio(false);
|
||||||
CivilCodePo parentCode = civilCodeFileConf.getParentCode(channelId);
|
CivilCodePo parentCode = CivilCodeUtil.INSTANCE.getParentCode(channelId);
|
||||||
if (parentCode != null) {
|
if (parentCode != null) {
|
||||||
deviceChannel.setParentId(parentCode.getCode());
|
deviceChannel.setParentId(parentCode.getCode());
|
||||||
deviceChannel.setCivilCode(parentCode.getCode());
|
deviceChannel.setCivilCode(parentCode.getCode());
|
||||||
|
|
|
@ -0,0 +1,50 @@
|
||||||
|
package com.genersoft.iot.vmp.utils;
|
||||||
|
|
||||||
|
import com.genersoft.iot.vmp.common.CivilCodePo;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
|
public enum CivilCodeUtil {
|
||||||
|
|
||||||
|
INSTANCE;
|
||||||
|
private final static Logger log = LoggerFactory.getLogger(CivilCodeUtil.class);
|
||||||
|
|
||||||
|
// 用与消息的缓存
|
||||||
|
private final Map<String, CivilCodePo> civilCodeMap = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
|
CivilCodeUtil() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public void add(List<CivilCodePo> civilCodePoList) {
|
||||||
|
if (!civilCodePoList.isEmpty()) {
|
||||||
|
for (CivilCodePo civilCodePo : civilCodePoList) {
|
||||||
|
civilCodeMap.put(civilCodePo.getCode(), civilCodePo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public CivilCodePo getParentCode(String code) {
|
||||||
|
if (code.length() > 8) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
if (code.length() == 8) {
|
||||||
|
String parentCode = code.substring(0, 6);
|
||||||
|
return civilCodeMap.get(parentCode);
|
||||||
|
}else {
|
||||||
|
CivilCodePo civilCodePo = civilCodeMap.get(code);
|
||||||
|
if (civilCodePo == null){
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
String parentCode = civilCodePo.getParentCode();
|
||||||
|
if (parentCode == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return civilCodeMap.get(parentCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue