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

相关文章

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Mysql DATETIME 毫秒坑的解决

《MysqlDATETIME毫秒坑的解决》本文主要介绍了MysqlDATETIME毫秒坑的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 今天写代码突发一个诡异的 bug,代码逻辑大概如下。1. 新增退款单记录boolean save = s

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

解决Cron定时任务中Pytest脚本无法发送邮件的问题

《解决Cron定时任务中Pytest脚本无法发送邮件的问题》文章探讨解决在Cron定时任务中运行Pytest脚本时邮件发送失败的问题,先优化环境变量,再检查Pytest邮件配置,接着配置文件确保SMT... 目录引言1. 环境变量优化:确保Cron任务可以正确执行解决方案:1.1. 创建一个脚本1.2. 修

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

Mysql8.0修改配置文件my.ini的坑及解决

《Mysql8.0修改配置文件my.ini的坑及解决》使用记事本直接编辑my.ini文件保存后,可能会导致MySQL无法启动,因为MySQL会以ANSI编码读取该文件,解决方法是使用Notepad++... 目录Myhttp://www.chinasem.cnsql8.0修改配置文件my.ini的坑出现的问题

SpringBoot项目删除Bean或者不加载Bean的问题解决

《SpringBoot项目删除Bean或者不加载Bean的问题解决》文章介绍了在SpringBoot项目中如何使用@ComponentScan注解和自定义过滤器实现不加载某些Bean的方法,本文通过实... 使用@ComponentScan注解中的@ComponentScan.Filter标记不加载。@C

MySQL8.0找不到my.ini如何解决

《MySQL8.0找不到my.ini如何解决》在配置MySQL主从复制时,发现找不到my.ini配置文件,通过检查路径和打开隐藏文件夹,最终在C:ProgramDataMySQLMySQLSer... 目录问题描述解决方法总结问题描述今天在配置mysql主从复制的时候发现,找不到my.ini这个配置文件。