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

相关文章

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin