Spring Cloud Alibaba 之 Nacos精讲

news2025/1/11 9:49:36

🍓 简介:java系列技术分享(👉持续更新中…🔥)
🍓 初衷:一起学习、一起进步、坚持不懈
🍓 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正🙏
🍓 希望这篇文章对你有所帮助,欢迎点赞 👍 收藏 ⭐留言 📝

🍓 更多文章请点击
在这里插入图片描述在这里插入图片描述

文章目录

  • 一、Nacos简介
  • 二、版本选择
  • 三、下载安装 nacos
  • 四、注册中心
    • 4.1 服务注册
      • 4.1.1 父工程引入Spirng-Cloud-Alibaba的管理依赖`
      • 4.1.2 添加Nacos的客户端依赖
      • 4.1.3 注册成功
      • 4.1.4 测试接口远程调用
    • 4.2 集群配置
    • 4.3 负载均衡
    • 4.4 权重
    • 4.5 名称空间/环境隔离
    • 4.6 Nacos注册中心原理(临时实例和非临时实例)
    • 4.7 Nacos与Eureka对比
  • 五、配置中心
    • 5.1 Nacos添加配置信息
    • 5.2 读取配置信息步骤
      • 5.2.1 引入Nacos的配置管理客户端依赖
      • 5.2.2 bootstrap.yml添加配置
      • 5.2.3 调用测试
    • 5.3 自动刷新-热更新
      • 5.3.1 方式一
      • 5.3.2 方式二
    • 5.4 多环境配置共享

在这里插入图片描述

一、Nacos简介

官网 : http://nacos.io/

官方文档:https://nacos.io/zh-cn/docs/what-is-nacos.html
在这里插入图片描述

Nacos是Alibaba微服务生态组件中的重要组件之一,主要用它实现应用的动态服务发现配置管理服务管理

Nacos 是 Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。

Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。

二、版本选择

使用spring cloud alibaba时特别需要注意版本间的兼容关系
请查看github官网wiki首页的: 版本说明文档

在这里插入图片描述

三、下载安装 nacos

下载 nacos-server :地址 https://github.com/alibaba/nacos/releases

  1. Windows直接下载zip包

  2. Linux下载tar.gz包

  3. docker在线安装查看文档: Docker如何安装Nacos

在这里插入图片描述Windows目录如下:

在这里插入图片描述bin : 存储的就是可执行文件
conf:存储的是nacos的配置文件

启动

进入nacos/bin目录中,执行如下命令启动

.\startup.cmd -m standalone  #以单机模式启动

输出nacos is starting with standalone 即为成功。
在这里插入图片描述

  • 进入可视化页面http://localhost:8848/nacos/ ,账号密码都是nacos,进行登录即可

在这里插入图片描述在这里插入图片描述
搭建成功,Linux 安装逻辑一致

四、注册中心

Nacos Discovery文档

自己项目根据 版本选择进行确定

首先声明:该文章的版本为:

  1. Spring Boot ------------>2.6.3
  2. Spring Cloud ------------>2021.0.1
  3. Spring Cloud-Alibaba--------->2021.0.1.0

4.1 服务注册

4.1.1 父工程引入Spirng-Cloud-Alibaba的管理依赖`

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.6.3</version>
        <relativePath/>
    </parent>
    
    <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>2021.0.1</spring-cloud.version>
        <spring-cloud-alibaba.version>2021.0.1.0</spring-cloud-alibaba.version>
    </properties>

    <dependencyManagement>
        <!-- springCloud -->
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <!-- spring cloud alibaba是阿里巴巴集团针对服务开发所提供的一套解决方案 -->
            <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>

    <dependencies>
        <!--web-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
    </dependencies>


    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.4.2</version>
                    <executions>
                        <execution>
                            <goals>
                                <goal>repackage</goal>
                            </goals>
                        </execution>
                    </executions>
            </plugin>
        </plugins>
    </build>

</project>

4.1.2 添加Nacos的客户端依赖

        <!-- nacos作为注册中心的依赖 -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

application.yml:添加配置

spring:
  application:
    name: consumer-server
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848  #nacos注册中心的IP地址和端口号

服务调用可能会报如下错误:

ERROR 7776 --- [io-20087-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.web.client.ResourceAccessException: I/O error on GET request for "http://provider-server/provider/1": provider-server; nested exception is java.net.UnknownHostException: provider-server] with root cause

所以添加以下依赖:

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-loadbalancer</artifactId>
        </dependency>

4.1.3 注册成功

在这里插入图片描述在这里插入图片描述

4.1.4 测试接口远程调用

这里主要介绍Nacos所以使用RestTemplate进行远程调用,后续会讲解其他远程调用方式

        //2远程查询用户信息
        String url="http://provider-server/provider/"+order.getUserId();

        //2. 发起调用
        User user = restTemplate.getForObject(url, User.class);

消费者这里使用服务名provider-server进行调用

  • 测试服务提供者:

    在这里插入图片描述

  • 测试消费者

    在这里插入图片描述

4.2 集群配置

大型应用,可能存在多机房部署,例如:上海 深圳 杭州,那么服务调用的规则是什么呢?

  • 跨集群延迟高,同集群不可访问,再访问其他集群

默认情况下是 DEFAULT
在这里插入图片描述配置集群属性

spring:
  cloud:
    nacos:
      discovery:
        cluster-name: HZ

启动后查看如下;
在这里插入图片描述

  • 服务调用还是采用:轮训策略,
  • 要想实现同集群的负载均衡规则则需修改负载均衡策略,如下

4.3 负载均衡

该负载均衡策略:优先选择与自己相同集群的服务,若该集群存在多个服务,则采用随机方式进行负载均衡

provider-server:       #给某个微服务配置负载均衡规则,这里是 provider-server 服务
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

4.4 权重

**权重配置来控制访问频率,权重越大则访问频率越高,范围:0-1之间 **

设置为0,则不访问
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

4.5 名称空间/环境隔离

  1. namespace 用来做环境隔离
  2. 每个名称空间有自己的唯一ID
  3. 不同空间下的服务不可见

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

spring:
  cloud:
    nacos:
      discovery:
        namespace: 646ec6d4-03e4-40d1-a387-452ba9bae995 #名称空间 ID

4.6 Nacos注册中心原理(临时实例和非临时实例)

在这里插入图片描述

临时实例和非临时实例:

spring:
  cloud:
    nacos:
      discovery:
        ephemeral: false                               #设置为非临时实例

临时实例宕机,会从Nacos的服务列剔除,二非临时实例不会剔除

4.7 Nacos与Eureka对比

相同点:

  1. 都支持服务住的和服务拉取
  2. 都支持服务提供者心跳方式做健康检测

不同点:

  1. Nacos的状态检测:
    • 临时实例采用心跳
    • 非临时实例采用主动检测模式
  2. 临时实例心跳不正常会被剔除,非临时实例不会剔除
  3. Nacos支持服务列表变更的消息推送模式,服务列表更新更即时
  4. Nacos集群默认采用AP方式当集群中存在非临时实例时,采用CP模式 Eureka采用AP模式

五、配置中心

Nacos Config文档

5.1 Nacos添加配置信息

不是所有配置文件都添加到nacos,只需添加经常需要改变的配置信息即可

在这里插入图片描述ID设置规则通常为:[服务名称]-[profile].yaml
在这里插入图片描述

在这里插入图片描述

5.2 读取配置信息步骤

5.2.1 引入Nacos的配置管理客户端依赖

    <!-- nacos作为配置中心的依赖 -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>

5.2.2 bootstrap.yml添加配置

bootstrap.yml文件配置,优先级高于application.yml

spring:
  application:
    name: provider-server #服务名称
  profiles:
    active: test #测试环境
  cloud:
    nacos:
      server-addr: localhost:8848  #Nacos地址
      config:
        file-extension: yaml  #文件后缀名

启动发现nacos做配置中心读取不到配置,且启动类一直加载不出来,一直报错:
在这里插入图片描述添加以下依赖即可

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>

启动成功
在这里插入图片描述

5.2.3 调用测试

@RestController
@RequestMapping("/provider")
public class ProviderController {

    @Autowired
    private ProviderService providerService;

    @Value("${pattern.dateformat}")
    private String dateformat;
    
    @GetMapping("/now")
    public String now() {
        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat));
    }

}

在这里插入图片描述

5.3 自动刷新-热更新

Nacos中配置文件更新后,微服务无需重启就可以感知

5.3.1 方式一

  • 通过@Value注解方式注入结合@RefreshScope进行刷新
    @RestController
    @RequestMapping("/provider")
    @RefreshScope
    public class ProviderController {
        @Value("${pattern.dateformat}")
        private String dateformat;
        
        @GetMapping("/now")
        public String now() {
            return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat));
        }
    }
    

5.3.2 方式二

通过@ConfigurationProperties注入,自动刷新

  • 自定义读取配置文件对象
    @Data
    @ConfigurationProperties(prefix = "pattern")
    public class PatternProperties {
    
        private String dateformat;
    }
    
  • 配置类或者启动类增加@EnableConfigurationProperties(PatternProperties.class)
  • 对象注入
    @RestController
    @RequestMapping("/provider")
    public class ProviderController {
    		@Autowired
       		private PatternProperties patternProperties;
       	
    	    @GetMapping("/now")
    	    public String now() {
    	        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(patternProperties.getDateformat()));
    	    }
    }
    

5.4 多环境配置共享

微服务启动时会从nacos读取多个文件
无论profile如何变化,[spring.application.name].yaml文件一定会加载,因此多环境共享可以写入这个文件

优先级:在这里插入图片描述

在这里插入图片描述在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ChatGPT炒股:批量自动提取股票公告中的表格并合并数据

首先&#xff0c;在ChatGPT中输入提示词&#xff1a; 写一段Python代码&#xff1a; F盘文件夹“新三板 2023年日常性关联交易20230704”中很多个PDF文件&#xff0c;用 Tabula提取这些PDF文件中第1页中的第2个表格&#xff0c;然后保存到表格文件中&#xff0c;文件标题名和…

选读SQL经典实例笔记03_DML和元数据

1. 复制数据到另一个表 1.1. sql insert into dept_east (deptno,dname,loc)select deptno,dname,locfrom deptwhere loc in ( NEW YORK,BOSTON ) 2. 复制表定义 2.1. 复制表结构&#xff0c;而不复制数据 2.2. MySQL 2.3. PostgreSQL 2.4. Oracle 2.5. sql create ta…

递归--Fibonacci数列 I

描述 众所周知&#xff0c;Fibonacci数列是一个著名数列。它的定义是&#xff1a; 本组题目共有 5 题&#xff0c;请分别用 5 种不同的方式来完成&#xff0c;并比较这些做法的时间。 本题要求采用第一种方法&#xff1a;递归&#xff0c;且不得使用数组记忆结果。 输入描述 …

备忘录方法--Fibonacci数列 IV

描述 众所周知&#xff0c;Fibonacci数列是一个著名数列。它的定义是&#xff1a; 本题要求采用第四种方法&#xff1a;备忘录方法&#xff0c;即记忆化搜索。 具体做法是&#xff1a;用数组把曾经求出来的 Fibonacci 数列保存下来&#xff0c;以后要的时候直接取出来。 输入…

【剑指offer】5.重建二叉树(java)

文章目录 重建二叉树描述示例1示例2示例3思路完整代码 重建二叉树 描述 给定节点数为 n 的二叉树的前序遍历和中序遍历结果&#xff0c;请重建出该二叉树并返回它的头结点。 例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6}&#xff0c;则重建出如下…

vue+electron项目实战总结(遇到了哪些问题,是如何解决的,哪个阶段需要做什么,附带一些常用方法)

electron作为一个将网页打包成桌面应用的工具 非常强大&#xff0c;在使用electron的时候 要相信 它可以实现所有现代软件能够支撑的功能&#xff0c;下面我总结一下我在 vueelectron经过4次 大版本更新才趋于稳定的开发经验。 一、开发套路&#xff1a; 消息通信数据驱动 使用…

LIN总线与RS485总线

LIN&#xff08;Local Interconnect Network&#xff0c;局部互连网络&#xff09;总线和RS485都是用于设备间通信的串行通信协议。下面我将分别列出它们的优势和劣势。 LIN总线的优势&#xff1a; 简单性&#xff1a;LIN总线的硬件和协议简单&#xff0c;易于实现和维护。成…

多元回归预测 | Matlab基于逻辑回归(Logistic Regression)的数据回归预测,多输入单输出模型

文章目录 效果一览文章概述部分源码参考资料效果一览 文章概述 多元回归预测 | Matlab基于逻辑回归(Logistic Regression)的数据回归预测,多输入单输出模型 评价指标包括:MAE、RMSE和R2等,代码质量极高,方便学习和替换数据。要求2018版本及以上。 部分源码 %% 清空环境变量…

炸裂了…京东一面索命40问,过了就50W+

说在前面 在40岁老架构师尼恩的&#xff08;50&#xff09;读者社区中&#xff0c;经常有小伙伴&#xff0c;需要面试京东、阿里、 百度、头条、美团等大厂。 下面是一个小伙伴成功拿到通过了京东一次技术面试&#xff0c;最终&#xff0c;小伙伴通过后几面技术拷问、灵魂拷问…

MySQL的存储引擎与基本使用

目录 一、前言 1.MySQL的介绍 二、存储引擎 1.什么是存储引擎 2.常见存储引擎 2.1.InnoDB(MySQL默认引擎) 2.1.1.四种隔离级别 2.2.MyISAM存储引擎 2.3.Memory存储引擎 3.ACID事务 三、CRUD操作 1.插入数据 2.查询数据 3.修改数据 4.删除数据 四、数据库 1.默认…

C#学习之路-基本语法

C# 是一种面向对象的编程语言。在面向对象的程序设计方法中&#xff0c;程序由各种相互交互的对象组成。相同种类的对象通常具有相同的类型&#xff0c;或者说&#xff0c;是在相同的 class 中。 using System; using System.Collections.Generic; using System.Linq; using S…

OpenCV库进行图像旋转、仿射变换和透视变换

#include <iostream> #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp>

解决Linux操作系统ping不同www.baidu.com问题

首先给自己管理员权限 输入代码 su然后输入密码密码不会显示打完直接回车 输入下面代码配置网络 cd /etc/sysconfig/network-scripts 输入以下代码进入ens33管理 vim ifcfg-ens33 输入 i i用方向键把光标移到 ONBOOT NO 把 no 改为 yes 按下 ESC 退出编辑模式 直接敲…

二叉树前中后序的非递归实现

前言 &#xff1a; 递归我们会有一些问题的 为什么有递归就一定有非递归呢&#xff1f;&#xff1f;首先递归是有一定缺陷的 递归真正的缺陷是&#xff0c;每一个程序运行起来呢都是一个线程的形式&#xff0c;但是每一个线程都会有独立的栈空间&#xff0c;但是栈空间是很…

Spring Boot 中的 Future 接口是什么,如何使用

Spring Boot 中的 Future 接口是什么&#xff0c;如何使用 在异步编程中&#xff0c;我们通常需要处理一些耗时的操作。一种常见的做法是使用 Future 接口来代表一个异步操作的结果。在 Spring Boot 中&#xff0c;Future 接口被广泛应用于异步编程中&#xff0c;本文将介绍 S…

【C++】VSCode 使用 C/C++ Compile Run 插件时,设置默认运行的编译参数的方法

为什么要设置参数 最近在学习C&#xff0c;在学习多线程的时候&#xff0c;发现使用C11中的thread类写的代码编译会报错&#xff1a; * 正在执行任务: g -Wall -Wextra -g3 /Users/anweiyang/studySrc/C/ThreadTest.cpp -o /Users/anweiyang/studySrc/C/output/ThreadTest /U…

OpenCV使用putText将文字绘制到图像上

#include <opencv2/opencv.hpp>int main(int argc, char **argv) {cv::Mat image = cv::imread(

开发实例:实现一个时间轮算法

时间轮算法是一种比较常见的时间计数器算法&#xff0c;它主要用于定时器的处理。在Java开发中&#xff0c;我们可以使用这种算法来实现非常高效且精准的定时器功能。下面&#xff0c;我将为大家介绍一个基于时间轮算法的定时器实现方法。 1、定义时间轮的数据结构 首先&…

spring 详解一 IOC(BeanFactory和ApplicationContext)

spring概述 重要部分 Spring是一个容器&#xff0c;用来管理java对象的创建以及其他功能的扩展&#xff0c;目前java的生态已经离不开spring&#xff0c;所以spring在java领域是一个极其重要的框架&#xff0c;在spring的思想中IOC(控制反转&#xff09;和AOP(切面编程)是重要…

Portraiture最新PS/LR 4.1.0.3皮肤修饰插件

Portraiture是一款惹人喜爱的PS磨皮插件。它能智能地对图像中的皮肤材质、头发、眉毛、睫毛等部位进行平滑和减少疵点处理&#xff0c;相对于Camera RAW&#xff0c;它能选择肌肤的色彩范围&#xff0c;对选择的部分进行单独处理。这样避免了其他部分同时被美化。 Portraiture…