简单读取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

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h