首页 > 其他分享 >【Spring Cloud Alibaba】Nacos 注册中心

【Spring Cloud Alibaba】Nacos 注册中心

时间:2023-07-04 18:23:55浏览次数:55  
标签:spring Nacos nacos alibaba Spring Alibaba cloud 客户端

目录

1. NacosServer 的安装和启动

NacosServer 相当于 EurekaServer,只不过 eurekaServer 使我们自己搭建的一个项目,而 NacosServer 别人已经提供好了,本次使用:alibaba 的 2.2.6.RELEASE 对应的 nacos 版本为 1.4.2

nacos下载地址:https://github.com/alibaba/nacos/releases/tag/1.4.2

1. 解压以及目录说明

  • bin:可执行文件夹目录,包含:启动、停止命令等等

  • conf:配置文件目录

2. 修改配置文件

进入${Nacos}/conf 目录里面,使用文件编辑器打开 application.properties 文件

Nacos 默认使用嵌入式数据库实现数据的存储,并不方便观察数据存储的基本情况,这里面我们修改为使用 Mysql 数据库做数据的存储,方便我们观察数据的结构。

在配置文件末尾添加如下配置:

spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://localhost:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=1234

3. Mysql 表的导入

在 config 目录下找到对应的 sql 脚本(nacos-mysql.sql)

创建数据库,运行 sql 脚本。

提示:Nacos 建议使用 5.7 的 Mysql 数据库,版本较低或者较高可能存储兼容性问题

4. NacosServer 启动

启动一个单机版的 Nacos 服务器:进入到${Nacos}/bin 目录里面,

  • 可以直接 startup.cmd -m standalone 启动单击版本

  • 或者 使用 nodepad++打开 startup.cmd 修改默认参数将 set MODE=”cluster”修改为 standalone,然后双击 startup.cmd 文件,完成 nacosServer 的启动。

5. 登录 Nacos

http://localhost:8848/nacos,即可访问启动 Nacos 实例。

Nacos 默认用户名和密码都是 nacos。如果想修改密码,可以直接修改数据库的 user 表。

2. Nacos 服务注册

1. 搭建两个 nacos 的客户端

alibaba-nacos-consumer 和 alibaba-nacos-provider,就是一个消费者一个提供者

2. 选择依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.powernode</groupId>
    <artifactId>01-alibaba-nacos-consumer</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>alibaba-nacos-consumer</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
        <!-- spring-cloud-alibaba 的当前稳定发行版本 2.2.6 -->
        <spring-cloud-alibaba.version>2.2.6.RELEASE</spring-cloud-alibaba.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 添加 nacos 的依赖 -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <!-- 添加 alibaba 的依赖管理 -->
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring-cloud-alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

3. 修改配置文件

application.yml

server:
	port: 8001
spring:
	application:
		name: alibaba-nacos-consumer
	cloud:
		nacos: # 客户端注册的地址
			server-addr: localhost:8848
			username: nacos
			password: nacos
			# discovery: # 命名空间 可以做项目隔离
			# namespace: car-namespace
			# group: dev # 在命名空间下的组别,可以用来做细粒度的隔离

4. 修改启动类

@EnableDiscoveryClient //开启服务发现客户端 也就是 nacosServer 的客户端

@SpringBootApplication
@EnableDiscoveryClient //开启服务发现客户端 也就是 nacosServer 的客户端
public class AlibabaNacosConsumerApplication {
	public static void main(String[] args) {
	SpringApplication.run(AlibabaNacosConsumerApplication.class, args);
	}
}

5. 启动测试

启动后去看 nacosServer 的控制台,已经有实例注册上去了

3. Nacos 服务发现

3.1 DiscoveryClient

注入服务发现组件 与在 eureka 中使用方式一样

/**
* 注入服务发现组件 在 eureka 中也用过
*/
@Autowired
private DiscoveryClient discoveryClient;


/**
* 服务发现的接口
*
* @param serviceId
* @return
*/
@GetMapping("discovery")
public String discoveryService(String serviceId) {
	// 根据实例名称拿到实例集合
	List<ServiceInstance> instances = discoveryClient.getInstances(serviceId);
	// 从实例集合列表中获取一个实例对象
	ServiceInstance serviceInstance = instances.get(0);
	System.out.println(serviceInstance.getHost() + ":" + serviceInstance.getPort());
  	return serviceInstance.getHost() + ":" + serviceInstance.getPort();
	}
}

访问测试 http://localhost:8001/discovery?serviceId=alibaba-nacos-provider

3.2 集成 openfeign 做远程调用和负载均衡

  1. 添加openFegin的依赖

    <dependency>
    	<groupId>org.springframework.cloud</groupId>
    	<artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
    
  2. 修改启动类,添加注解

    @SpringBootApplication
    @EnableDiscoveryClient //开启服务发现客户端 也就是 nacosServer 的客户端
    @EnableFeignClients //开启 feign 的客户端
    
  3. 添加一个 feign 的接口,注意和提供者一致

    @FeignClient(value = "alibaba-nacos-provider")
    public interface ProviderFeign {
    	/**
    	* 远程调用打招呼的接口
    	*
    	* @param name
    	* @return
    	*/
    	@GetMapping("hello")
    	String hello(@RequestParam("name") String name);
    }
    
  4. 添加一个 controller

    private ProviderFeign providerFeign;
    	/**
    	* 测试远程调用
    	* @return
    	*/
    	@GetMapping("rpc")
    	public String testRpc() {
    	String bjpowernode = providerFeign.hello("bjpowernode");
    	System.out.println(bjpowernode);
    	return bjpowernode;
    }
    
  5. 访问:http://localhost:8001/rpc

    nacos 做注册中心,服务发现,以及远程调用都完成了

4. Nacos Discovery Starter 更多的配置项

配置项 Key 默认值
服务端地址 spring.cloud.nacos.discovery.server-addr
服务名 spring.cloud.nacos.discovery.service ${spring.application.name}
服务分组 spring.cloud.nacos.discovery.group DEFAULT_GROUP
权重 spring.cloud.nacos.discovery.weight 1
集群 spring.cloud.nacos.discovery.cluster-name DEFAULT

标签:spring,Nacos,nacos,alibaba,Spring,Alibaba,cloud,客户端
From: https://www.cnblogs.com/lihw/p/17526675.html

相关文章

  • 【Spring Cloud Alibaba】Nacos 配置中心
    目录1.Nacos配置中心快速入门1.1导入依赖1.2在Nacos中新建一个powernode的命名空间1.3NacosServer里面添加一个配置文件1.4项目中添加一个配置文件bootstrap.yml2.Nacos获取多配置文件3.NacosConfig常用的配置3.1Config常用配置3.2bootstrap.yml模板1.Naco......
  • 条件注解之@ConditionalOnProperty注解:通过配置文件的配置来控制配置类是否加入spring
    一、条件注解分类常见的@ConditionalOnxxx开头的注解我们称之为条件注解,常见的条件注解有class条件注解:@ConditionalOnClassbean条件注解:@ConditionalOnBean属性条件注解:@ConditionalOnProperty…@ConditionalOnProperty:如果有指定的配置,条件生效;@ConditionalOnBean:如果......
  • rabbitmq在springboot中实战技巧
    一.简介rabbitmq是基于AMQP(AdvancedMessageQueuingProtocol:高级消息队列协议),采用Erlang语言编写的消息队列。二、mq能用来做什么异步处理:将非核心业务(比如日志、邮件、监控等)从主流程剥离,提升主流程的响应时效。削峰:当并发大的情况下,可以将消息暂存在消息队列中,消费者按照......
  • Springboot : 连接ldap超时问题
    Err:java.net.ConnectException:Connectiontimedoutwhenconnectingtoldap使用springbootldap连接账号所属ldap目录验证时,出现如上报错经检查,host,username,password等信息均无误,如下为代码中的配置信息示例hashEnv.put(Context.SECURITY_AUTHENTICATION,"simple"......
  • 面试题-Spring 面试集
    Spring面试集基于SpringFramework4.x总结的常见面试题,系统学习建议还是官方文档走起:https://spring.io/projects/spring-framework#learn一、一般问题开发中主要使用Spring的什么技术?IOC容器管理各层的组件使用AOP配置声明式事务整合其他框架Spring有哪些优......
  • 面试题-SpringBoot
    概述说说SpringBoot和Spring的关系springboot我理解就是把springspringmvcspringdatajpa等等的一些常用的常用的基础框架组合起来,提供默认的配置,然后提供可插拔的设计,就是各种starter,来方便开发者使用这一系列的技术,套用官方的一句话,spring家族发展到今天,已经......
  • 通过Spring Boot三分钟创建Spring Web项目
    SpringBoot简介接下来我们所有的Spring代码实例将会基于SpringBoot,因此我们先来了解一下SpringBoot这个大杀器。Spring早期使用XML配置的方式来配置SpringBeans之间的关系,比如AOP和依赖注入的配置。随着功能以及业务逻辑的日益复杂,应用便会伴随大量的XML配置文件以及复杂的Bean......
  • 实战项目:构建基于Spring Boot和Vue.js的金融项目分享
    学习SpringBoot和Vue.js结合的前后端分离项目可以按照以下步骤进行:掌握SpringBoot:学习SpringBoot的基本概念和核心特性,如自动配置、起步依赖、注解驱动等。了解Spring框架的基本知识,如IoC容器、AOP、MVC模式等。学习Vue.js:学习Vue.js的基本语法、指令和组件,理解Vue实例、数据绑......
  • nacos-sdk-go/v2版本 提示客户端连接不上
    nacos-sdk-gov2报错提示客户端连接不上标签(空格分隔):nacos前言nacos版本:v2nacos-sdk-go版本:v2背景:使用nacos-sdk-go来获取配置,发现一直在找缓存目录的文件,但使用openapi可以获取到配置报错信息clientnotconnected,currentstatus:STARTING提示客户端连接失败???1999-0......
  • springboot封装redission的分布式锁逻辑为注解
    场景概述使用分布式锁的时候,每次都需要使用trycatch处理方法中的逻辑。考虑是否可以这块逻辑抽离出来。实现在自定义的注解中添加属性来设置锁的等待时间、租赁时间和时间单位importjava.lang.annotation.*;@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTI......