tufei1846 2023-03-28 14:09 采纳率: 33.3%
浏览 59
已结题

关于#java#的问题:nacos客户端有什么方法可以在网络断掉的时候自动读取本地缓存配置文件,网络恢复会自动连接线上的配置

nacos客户端有什么方法可以在网络断掉的时候自动读取本地缓存配置文件,网络恢复会自动连接线上的配置

  • 写回答

8条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2023-03-29 05:33
    关注
    不知道你这个问题是否已经解决, 如果还没有解决的话:
    • 这篇文章:nacos配置本地数据库报错问题 也许能够解决你的问题,你可以看下
    • 除此之外, 这篇博客: 【Nacos源码之配置管理 九】客户端获取配置数据的流程中的 获取指定配置数据 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:

                  Properties properties = new Properties();
                  properties.put("serverAddr", serverAddr);
                  properties.put("namespace","dev");
                  ConfigService configService = NacosFactory.createConfigService(properties);
                  String content = configService.getConfig(dataId, group, 5000);
                  System.out.println(content);
      

      配置中设置了serverAddr 和命名空间namespace
      这个命名空间可以在管理后台自己新建的
      在这里插入图片描述

      获取配置的核心代码

      private String getConfigInner(String tenant, String dataId, String group, long timeoutMs) throws NacosException {
              group = null2defaultGroup(group);
              ParamUtils.checkKeyParam(dataId, group);
              ConfigResponse cr = new ConfigResponse();
      
              cr.setDataId(dataId);
              cr.setTenant(tenant);
              cr.setGroup(group);
      
              // 优先使用本地配置
              String content = LocalConfigInfoProcessor.getFailover(agent.getName(), dataId, group, tenant);
              if (content != null) {
                  LOGGER.warn("[{}] [get-config] get failover ok, dataId={}, group={}, tenant={}, config={}", agent.getName(),
                      dataId, group, tenant, ContentUtils.truncateContent(content));
                  cr.setContent(content);
                  configFilterChainManager.doFilter(null, cr);
                  content = cr.getContent();
                  return content;
              }
      
              try {
                  content = worker.getServerConfig(dataId, group, tenant, timeoutMs);
      
                  cr.setContent(content);
      
                  configFilterChainManager.doFilter(null, cr);
                  content = cr.getContent();
      
                  return content;
              } catch (NacosException ioe) {
                  if (NacosException.NO_RIGHT == ioe.getErrCode()) {
                      throw ioe;
                  }
                  LOGGER.warn("[{}] [get-config] get from server error, dataId={}, group={}, tenant={}, msg={}",
                      agent.getName(), dataId, group, tenant, ioe.toString());
              }
      
              LOGGER.warn("[{}] [get-config] get snapshot ok, dataId={}, group={}, tenant={}, config={}", agent.getName(),
                  dataId, group, tenant, ContentUtils.truncateContent(content));
              content = LocalConfigInfoProcessor.getSnapshot(agent.getName(), dataId, group, tenant);
              cr.setContent(content);
              configFilterChainManager.doFilter(null, cr);
              content = cr.getContent();
              return content;
          }
      

    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(7条)

报告相同问题?

问题事件

  • 系统已结题 4月6日
  • 已采纳回答 3月29日
  • 创建了问题 3月28日

悬赏问题

  • ¥15 输入的char字符转为int类型,不是对应的ascall码,如何才能使之转换为对应ascall码?或者使输入的char字符可以正常与其他字符比较?
  • ¥15 解决websocket跟c#客户端通信
  • ¥30 Python调用dll文件输出Nan重置dll状态
  • ¥15 浮动div的高度控制问题。
  • ¥66 换电脑后应用程序报错
  • ¥50 array数据同步问题
  • ¥15 pic16F877a单片机的外部触发中断程序仿真失效
  • ¥15 Matlab插值拟合差分微分规划图论
  • ¥15 keil5 target not created
  • ¥15 C/C++数据与算法请教