简单读取nacos配置,服务注册,订阅的代码

2024-08-29 00:28

本文主要是介绍简单读取nacos配置,服务注册,订阅的代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以下配置文件具体可以看nacos 动态读取nacos配置中心项目配置这篇博客中的配置文件(配置文件是统一用的)
简单读取nacos配置中心配置:

package com.richfit.richfit.controller.nacos;import com.alibaba.nacos.api.NacosFactory;
import com.alibaba.nacos.api.PropertyKeyConst;
import com.alibaba.nacos.api.config.ConfigService;
import com.alibaba.nacos.api.config.annotation.NacosValue;
import com.alibaba.nacos.api.config.listener.Listener;
import com.alibaba.nacos.api.exception.NacosException;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.util.Properties;
import java.util.concurrent.Executor;@RestController
@RequestMapping("/nacos")
public class nacosController {//使用@nacosValue注解获取值,并开启自动更新@NacosValue(value = "${spring.datasource.password}", autoRefreshed = true)private String urlheadAutoRefresh;/*** @NacosValue注解,这种的不能实时读取更新nacos中修改的配置,除非重启项目或者重启nacos。下面这个方法就可以实时更新返回* @return*/@GetMapping("getNacosValue1")public String getValue1(){return "getNacosValue1:"+urlheadAutoRefresh;//输出:getNacosValue1:hlr2261226HLR}@Value("${spring.application.name}")private String name;@Value("${spring.cloud.nacos.config.file-extension}")private String extension;@Value("${spring.cloud.nacos.config.group}")private String group;@Value("${spring.cloud.nacos.config.namespace}")private String namespace;@Value("${spring.cloud.nacos.config.username}")private String username;@Value("${spring.cloud.nacos.config.password}")private String password;/**** @return* @throws NacosException* @throws InterruptedException*/@GetMapping("getNacosValue")public String getValue() throws NacosException, InterruptedException {String dataId = name + "."+extension;Properties properties = new Properties();properties.put(PropertyKeyConst.SERVER_ADDR, "localhost");//这一定是命名空间id不能是名称properties.put(PropertyKeyConst.NAMESPACE, namespace);properties.put(PropertyKeyConst.USERNAME, username);properties.put(PropertyKeyConst.PASSWORD, password);properties.put(PropertyKeyConst.SERVER_NAME,name);ConfigService configService = NacosFactory.createConfigService(properties);System.out.println("是否已经连接服务:"+configService.getServerStatus());//是否已经连接服务:UP 代表已连接if ("UP".equalsIgnoreCase(configService.getServerStatus())) {System.out.println("Nacos服务状态正常,服务可用。");// 进行其他业务逻辑处理} else {System.out.println("Nacos服务状态异常,服务不可用。");// 进行错误处理或重试逻辑}String content = configService.getConfig(dataId, group, 5000);System.out.println(content);//下面为监听器,只要客户端中配置改了,下面的addListener就会触发configService.addListener(dataId, group, new Listener() {@Overridepublic void receiveConfigInfo(String configInfo) {System.out.println("receive:" + configInfo);}@Overridepublic Executor getExecutor() {return null;}});//content 是 配置的内容,配置后在发布
//        boolean isPublishOk = configService.publishConfig(dataId, group, "脸脸真可爱,悦悦很可爱,妞妞太可爱");
//        System.out.println(isPublishOk);
//
//        Thread.sleep(3000);
//        //配置完后在获取
//        content = configService.getConfig(dataId, group, 5000);
//        System.out.println(content);return content;}
}

@NacosValue 读取客户端配置的关键注解

简单读取nacos服务注册和订阅:

package com.richfit.richfit.controller.nacos;import com.alibaba.nacos.api.NacosFactory;
import com.alibaba.nacos.api.PropertyKeyConst;
import com.alibaba.nacos.api.exception.NacosException;
import com.alibaba.nacos.api.naming.NamingService;
import com.alibaba.nacos.api.naming.listener.Event;
import com.alibaba.nacos.api.naming.listener.EventListener;
import com.alibaba.nacos.api.naming.listener.NamingEvent;
import com.alibaba.nacos.api.naming.pojo.Instance;
import com.alibaba.nacos.api.naming.pojo.ServiceInfo;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.util.List;
import java.util.Properties;/*** 获取nacos上的服务列表** Nacos为服务注册与发现提供了一个SDK类 NamingService,* 通过该类,可以实现服务的注册与发现、订阅服务的动态变化、* 获取服务实例、获取注册中心的健康状态等等** <dependency>*     <groupId>com.alibaba.nacos</groupId>*     <artifactId>nacos-client</artifactId>*     <version>1.4.2</version>* </dependency>** namingService.registerInstance():注册实例* namingService.deregisterInstance():取消注册* namingService.getAllInstances(String serviceName):获取服务的所有实例* namingService.getServicesOfServer(int pageNo, int pageSize):分页查询,从服务器获取所有服务名称* namingService.getSubscribeServices():获取当前客户端所有订阅的服务* namingService.selectInstances():根据条件获取服务实例* namingService.selectOneHealthyInstance():根据条件选择一个健康的实例* namingService.subscribe():订阅服务以接收实例更改事件* namingService.unsubscribe():取消订阅* namingService.getServerStatus():获取服务器健康状态*/
@RestController
@RequestMapping("/nacosClient")
public class NacosClient {@Value("${spring.application.name}")private String name;@Value("${spring.cloud.nacos.config.file-extension}")private String extension;@Value("${spring.cloud.nacos.config.group}")private String group;@Value("${spring.cloud.nacos.config.namespace}")private String namespace;@Value("${spring.cloud.nacos.config.username}")private String username;@Value("${spring.cloud.nacos.config.password}")private String password;/**** @return* @throws NacosException* @throws InterruptedException*/@GetMapping("getNacosFuwu")public String getNacosFuwu(){try {Properties properties = new Properties();properties.put(PropertyKeyConst.SERVER_ADDR, "localhost:8848");//这一定是命名空间id不能是名称properties.put(PropertyKeyConst.NAMESPACE, namespace);properties.put(PropertyKeyConst.USERNAME, username);properties.put(PropertyKeyConst.PASSWORD, password);// 服务名String serviceName = "richfit.properties";//properties.put(PropertyKeyConst.SERVER_NAME, serviceName);NamingService namingService = NacosFactory.createNamingService(properties);//获取服务器健康状态String serverStatus = namingService.getServerStatus();System.out.println("服务器健康状态:"+serverStatus);//服务注册namingService.registerInstance(serviceName, "192.168.1.101:", 8888, "richfit-TEST");//使用namingService获取服务列表List<Instance> instances = namingService.getAllInstances(serviceName);// 输出服务列表for (Instance instance : instances) {System.out.println("IP: " + instance.getIp());System.out.println("Port: " + instance.getPort());//是否健康System.out.println("Healthy: " + instance.isHealthy());//Healthy: true//节点是否存在System.out.println("Enabled: " + instance.isEnabled());System.out.println("Weight: " + instance.getWeight());//Weight: 1.0System.out.println("ClusterName: " + instance.getClusterName());//ClusterName: richfit-TESTSystem.out.println("InstanceId: " + instance.getInstanceId());//InstanceId: 192.168.1.101:#8888#richfit-TEST#DEFAULT_GROUP@@richfit.propertiesSystem.out.println("------------------------");}//订阅服务以接收实例更改事件namingService.subscribe("richfit.properties", new EventListener() {@Overridepublic void onEvent(Event event) {
//                    int removeSize = ((NamingChangeEvent) event).instancesDiff.removedInstances.size();
//                    int addSize = ((NamingChangeEvent) event).instancesDiff.addedInstances.size();
//                    if (removeSize > 0){
//                        System.out.println("已取消订阅的服务名:"+((NamingEvent)event).getServiceName());
//                    }
//                    if (addSize > 0){
//                        System.out.println("已新增订阅的服务名:"+((NamingEvent)event).getServiceName());
//                    }System.out.println("已订阅的实例:"+((NamingEvent)event).getInstances()+"个服务");}});//获取当前客户端所有订阅的服务。服务订阅之后,当客户端服务列表没有显示节点了,但是一段时间内订阅者列表节点不会消失List<ServiceInfo> subscribeServices = namingService.getSubscribeServices();//如果订阅的个数大于0if (subscribeServices.size() > 0){try {//取消服务注册namingService.deregisterInstance(serviceName, "192.168.1.101:", 8888, "richfit-TEST");} catch (NacosException e) {throw new RuntimeException(e);}}System.out.println("获取当前客户端所有订阅的服务个数:"+namingService.getSubscribeServices().size());} catch (Exception e) {e.printStackTrace();}return null;}}

这篇关于简单读取nacos配置,服务注册,订阅的代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1116314

相关文章

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则