当前位置: 首页 > ds >正文

nacos:服务无法注册到nacos服务中心

目录

    • 简介
    • 依赖
    • 异常情况
    • 排查
      • 断点调试
      • 补充
    • 原因
    • 解决
      • NacosRegisterOnWar
      • 结果


简介

1、程序在本机用启动类启动,服务可以正常注册到nacos

2、程序在Linux服务器用tomcat启动,服务无法注册到nacos


依赖

<!--客户端负载均衡loadbalancer-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId><version>4.1.3</version>
</dependency>
<!-- nacos -->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId><version>${spring-cloud-alibaba.version}</version>
</dependency>
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId><version>${spring-cloud-alibaba.version}</version>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-bootstrap</artifactId><version>${spring-cloud-bootstrap.version}</version>
</dependency>
<!-- sentinel -->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId><version>${spring-cloud-alibaba.version}</version>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId><version>${spring-cloud-openfeign.version}</version>
</dependency>

异常情况

服务启动后无法注册到服务中心

在这里插入图片描述


排查

1、检查本机与Linux服务器程序配置文件是否存在差异,导致服务无法注册

结果:配置完全相同

2、查看Linux日志,发现程序对nacos配置文件的读取是正常的,可以正常访问nacos的配置中心读取配置文件

结果:nacos配置文件可以读取,服务无法注册到nacos

3、查看Linux服务器其他程序是否可以注册到nacos

结果:同一台Linux服务器其他程序可以正常注册到nacos

4、查看可以正常注册的程序,使用的依赖版本与当前无法注册的程序依赖版本是否一致

结果:openFeign、Nacos、Spring Cloud、Spring Boot依赖版本完全一致

5、将当前程序tomcat放到其他Linux服务器启动,服务依旧无法注册到nacos

结果:排除是Linux服务器本身的问题

6、将程序放到可以正常注册的程序所在的tomcat

结果:原先可以正常注册的程序依旧正常,当前程序还是无法正常注册到nacos,排除tomcat的问题

断点调试

1、本机用启动类启动服务,可以正常触发AbstractAutoServiceRegistration监听的WebServerInitializedEvent事件,会执行服务注册逻辑onApplicationEvent()

2、Linux服务器tomcat启动,无法触发AbstractAutoServiceRegistration监听的WebServerInitializedEvent事件,没有执行服务注册逻辑onApplicationEvent()

补充

不了解nacos注册原理的可以参考一下:nacos服务注册原理


原因

无法触发AbstractAutoServiceRegistration监听的WebServerInitializedEvent事件,没有执行服务注册逻辑onApplicationEvent()

根本原因不明!!!


解决

既然无法自动触发WebServerInitializedEvent事件,从而自动进行服务注册,那就手动进行注册

实现ApplicationRunner接口,监听服务启动事件,从而主动进行服务注册

将以下类添加到程序中即可

NacosRegisterOnWar

package com.xxx.nacosregister;import com.alibaba.cloud.nacos.ConditionalOnNacosDiscoveryEnabled;
import com.alibaba.cloud.nacos.registry.NacosAutoServiceRegistration;
import com.alibaba.cloud.nacos.registry.NacosRegistration;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.stereotype.Component;import javax.management.MBeanServer;
import javax.management.ObjectName;
import javax.management.Query;
import java.lang.management.ManagementFactory;
import java.util.Set;@Component
@ConditionalOnNacosDiscoveryEnabled
@Slf4j
public class NacosRegisterOnWar implements ApplicationRunner {@Autowiredprivate NacosRegistration registration;@Autowiredprivate NacosAutoServiceRegistration nacosAutoServiceRegistration;@Value("${server.port}")Integer port;@Overridepublic void run(ApplicationArguments args) throws Exception {if (registration != null && port != null) {Integer registerPort = port;try {String tomcatPort = getTomcatPort();if(StringUtils.isNotBlank(tomcatPort)){registerPort = new Integer(tomcatPort);}} catch (Exception e) {log.warn("{nacos 注册} 获取外部Tomcat端口异常:",e);}registration.setPort(registerPort);nacosAutoServiceRegistration.start();}}/***	获取外部tomcat端口*/public String getTomcatPort() throws Exception {MBeanServer beanServer = ManagementFactory.getPlatformMBeanServer();Set<ObjectName> objectNames = beanServer.queryNames(new ObjectName("*:type=Connector,*"),Query.match(Query.attr("protocol"),Query.value("HTTP/1.1")));String port = "";for (ObjectName objectName : objectNames) {port = objectName.getKeyProperty("port");if(StringUtils.isNotBlank(port)){return port;}}return port;}
}

结果

服务可以正常注册到nacos

在这里插入图片描述

http://www.xdnf.cn/news/6316.html

相关文章:

  • Linux 动静态库详解
  • JS 中 Object.keys() 和 Object.values() 的深度解析与应用
  • 蓝桥杯 17. 修改数组
  • 【Linux高级IO】多路转接之epoll
  • Linux——mysql主从复制与读写分离
  • 人工智能+ERP:政策新规下企业智能化转型路径
  • 【vue】axios网络请求介绍
  • 【2025版】Spring Boot面试题
  • C语言_自定义类型:结构体
  • (4)python开发经验
  • (十七)Java日期时间API全面解析:从传统Date到现代时间处理
  • Ros2 - Moveit2 - DeepGrasp(深度抓握)
  • golang -- 如何让main goroutine等一等
  • 数智驱动——AI:企业数字化转型的“超级引擎”
  • FreeRTOS学习笔记
  • 【Java学习笔记】finalize方法
  • 前后端分离博客 Weblog 项目实战
  • 【AI大模型】赋能【传统业务】
  • Java基础语法之数组
  • Windows下Docker安装portainer
  • 64. 最小路径和
  • Shell 脚本中的通道号(文件描述符)
  • maven项目, idea右上角一直显示gradle的同步标识, 如何去掉
  • 计算机网络:什么是计算机网络?它的定义和组成是什么?
  • 开源Heygem本地跑AI数字人视频教程
  • python使用matplotlib画图
  • IDEA编辑器设置的导出导入
  • why FPGA喜欢FMC子卡?
  • Vue3学习(组合式API——计算属性computed详解)
  • 使用Word2Vec算法实现古诗自动生成实战