Nacos 服务状态监听四种写发

简介: Nacos 服务状态监听四种写发

监听服务的四种实现方式,以监听 Nacos 服务为例

1. 传统方式

public void subscribe() {
    try {
            NamingService namingService = NamingFactory.createNamingService("127.0.0.1:8848"); 
            namingService.subscribe("serverName","groupName",new EventListener() {
                @Override
                public void onEvent(Event event) {
                   if (event instanceof NamingEvent) {
                        System.out.println("服务名:"+((NamingEvent)event).getServiceName());
                        System.out.println("实例:"+((NamingEvent)event).getInstances());
                    }
                }
            });
    } catch (NacosException e) {
        logger.error(e.getMessage(), e);
    }
}

2. 简写方式

public void subscribe() {
    try {
            NamingService namingService = NamingFactory.createNamingService("127.0.0.1:8848"); 
            namingService.subscribe("serverName","groupName", event -> {
                if (event instanceof NamingEvent) {
                    System.out.println("服务名:"+((NamingEvent)event).getServiceName());
                    System.out.println("实例:"+((NamingEvent)event).getInstances());
                }
            });
    } catch (NacosException e) {
        logger.error(e.getMessage(), e);
    }
}

3. 独立方法

public void subscribe() {
    try {
            NamingService namingService = NamingFactory.createNamingService("127.0.0.1:8848"); 
            namingService.subscribe("serverName","groupName", serviceListener);
    } catch (NacosException e) {
        logger.error(e.getMessage(), e);
    }
} 
EventListener serviceListener = (event) ->
{
    if (event instanceof NamingEvent) {
        System.out.println("服务名:"+((NamingEvent)event).getServiceName());
        System.out.println("实例:"+((NamingEvent)event).getInstances());
    }
};

4. 独立文件

public void subscribe() {
    try {
            NamingService namingService = NamingFactory.createNamingService("127.0.0.1:8848"); 
            namingService.subscribe("serverName","groupName", new NacosListener());
    } catch (NacosException e) {
        logger.error(e.getMessage(), e);
    }
} 
//单独Class类
public class NacosListener implements EventListener {
    @Override
    public void onEvent(Event event) {
        if (event instanceof NamingEvent) {
            System.out.println(((NamingEvent)event).getServiceName());
            System.out.println(((NamingEvent)event).getInstances());
        }
    }
}

 

目录
相关文章
|
消息中间件 缓存 资源调度
【Java项目】使用Nacos实现动态线程池技术以及Nacos配置文件更新监听事件
【Java项目】使用Nacos实现动态线程池技术以及Nacos配置文件更新监听事件
654 0
|
5月前
|
存储 Kubernetes 安全
Nacos-Controller 2.0:使用 Nacos 高效管理你的 K8s 配置
无论是使用 Nacos-Controller 实现配置的双向同步,还是直接在应用中接入 Nacos SDK 以获得更高级的配置管理特性,都能显著提升配置管理的灵活性、安全性和可维护性。使用 Nacos,您能够更好地管理和优化您的应用配置,从而提高系统的稳定性和可靠性。
501 49
|
9月前
|
存储 网络协议 Nacos
高效搭建Nacos:实现微服务的服务注册与配置中心
Nacos(Dynamic Naming and Configuration Service)是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署和管理分布式系统,特别是在微服务架构中。
1675 82
高效搭建Nacos:实现微服务的服务注册与配置中心
|
9月前
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
890 147
|
5月前
|
存储 人工智能 测试技术
Nacos托管LangChain应用Prompts和配置,助力你的AI助手快速进化
AI 应用开发中,总有一些让人头疼的问题:敏感信息(比如 API-KEY)怎么安全存储?模型参数需要频繁调整怎么办?Prompt 模板改来改去,每次都得重启服务,太麻烦了!别急,今天我们就来聊聊如何用 Nacos 解决这些问题。
|
10月前
|
监控 Java 测试技术
Nacos 配置中心变更利器:自定义标签灰度
本文是对 MSE Nacos 应用自定义标签灰度的功能介绍,欢迎大家升级版本进行试用。
1020 214
|
7月前
|
Cloud Native Java Nacos
springcloud/springboot集成NACOS 做注册和配置中心以及nacos源码分析
通过本文,我们详细介绍了如何在 Spring Cloud 和 Spring Boot 中集成 Nacos 进行服务注册和配置管理,并对 Nacos 的源码进行了初步分析。Nacos 作为一个强大的服务注册和配置管理平台,为微服务架构提供
3006 14
|
10月前
|
负载均衡 应用服务中间件 Nacos
Nacos配置中心
Nacos配置中心
562 1
Nacos配置中心
|
10月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评。然而,“客户端不发送心跳检测”是使用中常见的问题之一。本文详细探讨了该问题的原因及解决方法,包括检查客户端配置、网络连接、日志、版本兼容性、心跳检测策略、服务实例注册状态、重启应用及环境变量等步骤,旨在帮助开发者快速定位并解决问题,确保服务正常运行。
176 5
|
10月前
|
网络安全 Nacos 开发者
Nacos作为流行的微服务注册与配置中心,“节点提示暂时不可用”是常见的问题之一
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,“节点提示暂时不可用”是常见的问题之一。本文将探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务的正常运行。通过检查服务实例状态、网络连接、Nacos配置、调整健康检查策略等步骤,可以有效解决这一问题。
235 4