From 12253875406a93c2cc0f02d4abc87505e9898b15 Mon Sep 17 00:00:00 2001 From: ludc Date: 星期日, 12 十一月 2023 20:20:03 +0800 Subject: [PATCH] 历史数据导入,单次导入超过800条报错变量溢出bug --- Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java | 81 ++++++++++++++++++++++++++++++++++++++++ 1 files changed, 81 insertions(+), 0 deletions(-) diff --git a/Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java b/Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java new file mode 100644 index 0000000..c4c7eb4 --- /dev/null +++ b/Source/UBCS/ubcs-service-api/ubcs-system-api/src/main/java/com/vci/ubcs/system/cache/NacosConfigCache.java @@ -0,0 +1,81 @@ +package com.vci.ubcs.system.cache; + +import com.alibaba.nacos.api.config.ConfigFactory; +import com.alibaba.nacos.api.config.ConfigService; +import com.alibaba.nacos.api.exception.NacosException; +import com.vci.ubcs.common.constant.LauncherConstant; +import org.springblade.core.log.exception.ServiceException; +import org.springblade.core.cache.utils.CacheUtil; +import org.springblade.core.secure.BladeUser; +import org.springblade.core.tool.utils.Func; +import org.springframework.stereotype.Component; +import org.yaml.snakeyaml.Yaml; + +import java.util.Map; + +/** + * redis涓瓨鍌ㄧ殑nacos涓婇厤缃殑瓒呯閰嶇疆淇℃伅 + * @author ludc + * @date 2023/8/31 13:02 + */ +@Component +public class NacosConfigCache { + + private static final String NACOS_CONFIG_CACHE = "nacos:config"; + + private static final String ADMIN_INFO_CODE = "admin:info:"; + + private static ConfigService configService; + + private static final String GROUP_ID = "DEFAULT_GROUP"; + private static final String DATA_ID = "ubcs.yaml"; + + static { + try { + configService = ConfigFactory.createConfigService(LauncherConstant.NACOS_DEV_ADDR); + } catch (NacosException e) { + e.printStackTrace(); + } + } + + /** + * 闈欐�佹柟娉曚腑鑾峰彇閰嶇疆 + * @return + */ + public static Map<String, Map<String,String>> getConfig() { + try { + String config = configService.getConfig(DATA_ID, GROUP_ID, 5000); + Yaml yaml = new Yaml(); + return yaml.load(config); + } catch (NacosException e) { + e.printStackTrace(); + return null; + } + } + + /** + * 鑾峰彇瀛樺叆redis涓� + * nacos涓婇厤缃殑瓒呯淇℃伅 + * @return + */ + public static BladeUser getAdminUserInfo() { + try { + BladeUser user = CacheUtil.getCache(NACOS_CONFIG_CACHE).get(ADMIN_INFO_CODE,BladeUser.class); + Map<String, Map<String,String>> configMap = getConfig(); + String tenantId = configMap.get("user-info").get("tenant-id"); + //浠庣紦瀛樹腑鏈幏鍙栧埌瓒呯骇绠$悊鍛橀厤缃俊鎭垨鑰呭拰nacos涓婇厤缃殑绉熸埛涓嶄竴鑷达紝浠巒acos涓婇噸鏂拌幏鍙栧苟瀛樺叆缂撳瓨銆� + if(Func.isEmpty(user) || !user.getTenantId().equals(tenantId)){ + BladeUser adminUser = new BladeUser(); + adminUser.setTenantId(tenantId); + adminUser.setUserName(configMap.get("user-info").get("user-name")); + adminUser.setUserId(Func.toLong(configMap.get("user-info").get("id"))); + CacheUtil.getCache(NACOS_CONFIG_CACHE).put(ADMIN_INFO_CODE,adminUser); + return adminUser; + } + return user; + }catch (Exception e){ + throw new ServiceException("浠巒acos涓婅幏鍙栬秴绾х鐞嗗憳閰嶇疆澶辫触锛�"); + } + } + +} -- Gitblit v1.9.3