Nacos 源码启动异常 jmenv.tbsite.net 分析及解决

2024-09-06 18:36

本文主要是介绍Nacos 源码启动异常 jmenv.tbsite.net 分析及解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述

下载 Nacos 源码后,将源码导入 idea,并且在 console 模块的 application.properties 文件中正确配置数据源后,以执行 console 模块中 Nacos 类中 main 方法启动服务。

Nacos 默认以集群模式启动,会出现 jmenv.tbsite.net 相关错误,启动及错误截图如下所示:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

错误原因

1、nacos 启动时,会读取 nacos.core.member.lookup.type 配置,根据配置的值确定是 file 还是 address-server,该配置默认未配置,为空,nacos 通过检测本地是否存在 cluster.conf 配置文件来确定是哪一种方式。如下图所示的源码,从文件路径读取文件,如果读取成功,则认为是 lookup 类型是 file,否则为默认为 address-server。因为我们使用源码启动没有提前配置 cluster.conf 文件,所以默认使用 address-server 方式加载集群成员列表。

在这里插入图片描述

2、如下截图所示,在使用 address-server 方式获取集群成员列表时,默认的 http 接口地址为 http://jmenv.tbsite.net:8080/nacos/serverlist,程序会从这个 url 中获取集群成员列表,并同步保存到 cluster.conf 文件中,同时启动异步的方式来定时更新(默认5秒)。这样做的目的是可以通过一个外部的独立接口来控制对集群成员列表,可以应对集群的弹性热更新。

在这里插入图片描述
在这里插入图片描述

注:serverlist 和 env 环境变量均可以通过配置接口地址的方式来实现热更新。

3、因为 address.server.domain 的默认值是 jmenv.tbsite.net,所以程序调用接口无法正常解析这个 host,对应文初所述的 domain 解析异常。解决方法就是在配置文件中为 address.server.domain 配置一个有效的 domain,并保证该 domain 对应的 http://${domain}:${port}/nacos/serverlist 接口可以被正常调用。否则代码在执行多次重试调用仍旧失败后,抛出异常,程序启动失败!

在这里插入图片描述

解决方法

通过上述原因描述,能让我们正常启动 nacos 服务的方式一共有3种:

1、配置正确的 address.server.domainaddress.server.portaddress.server.url,并确保接口可以被正常调用返回结果。

2、创建 ${nacos.home}/conf/cluster.conf 配置文件,并配置集群成员列表,成员列表每行一个,由IP地址:端口组成。如下图所示:

在这里插入图片描述

#2024-09-06T14:13:41.151
192.168.49.11:8848
192.168.49.12:8848
192.168.49.13:8848

注:如果配置明确配置了 nacos.core.member.lookup.type=address-server,并且 cluster.conf 文件也存在,则以 nacos.core.member.lookup.type 配置优先。

3、通过启动变量设置 nacos 为单实例方式启动,如下图所示:

在这里插入图片描述

如此,即可正常启动服务。


(END)

这篇关于Nacos 源码启动异常 jmenv.tbsite.net 分析及解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142796

相关文章

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

C#文件复制异常:"未能找到文件"的解决方案与预防措施

《C#文件复制异常:未能找到文件的解决方案与预防措施》在C#开发中,文件操作是基础中的基础,但有时最基础的File.Copy()方法也会抛出令人困惑的异常,当targetFilePath设置为D:2... 目录一个看似简单的文件操作问题问题重现与错误分析错误代码示例错误信息根本原因分析全面解决方案1. 确保

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

SpringBoot通过main方法启动web项目实践

《SpringBoot通过main方法启动web项目实践》SpringBoot通过SpringApplication.run()启动Web项目,自动推断应用类型,加载初始化器与监听器,配置Spring... 目录1. 启动入口:SpringApplication.run()2. SpringApplicat

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说