当前位置: 首页 > news >正文

Nacos介绍以及使用

目录

    • 一、概述
      • 1.1. Nacos是什么?能干嘛?
      • 1.2. 去哪下载
      • 1.3. 各个注册中心比较
    • 二、Nacos作为服务注册中心
      • 2.1. 基于Nacos的服务提供者
      • 2.2. 基于Nacos的服务消费者
    • 三、Nacos作为服务配置中心
      • 3.1. Nacos作为配置中心-基础配置
      • 3.2. Data Id命名规则
      • 3.3. Namespace + Group + Data ID
      • 3.4. Nacos作为配置中心-分类配置
      • 3.5. Nacos服务注册命名空间
    • 四、Nacos集群和持久化配置

本篇文章所涉及到的demo练习 使用的 cloud-alibaba 2021.0.1.0+ springboot2.6.8

一、概述

1.1. Nacos是什么?能干嘛?

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service(动态命名和配置服务)的首字母简称。一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

Nacos作用就是 注册中心 + 配置中心 ,跟Consul其实是差不多的,Consul也具备这两个功能,当然Consul的界面我个人认为是没有Nacos的界面好用的。

Nacos(Consul) = Eureka + Config + Bus

官网介绍:https://nacos.io/zh-cn/docs/what-is-nacos.html

Nacos官网做的有国际化,本身也就是中国开发的,所以官网写的特别符合我们国人的网站风格。基本上想找什么,快速就能找到。学习任何一个框架,都要以博客为辅,官网为主的理念来学习。

在这里插入图片描述

1.2. 去哪下载

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

在这里插入图片描述

我这里下载的windows版本的,不需要安装,下载好直接解压,然后到bin目录下,执行startup.cmd -m standalone启动即可。

在这里插入图片描述

命令运行成功后直接访问http://localhost:8848/nacos
默认账号密码都是nacos

在这里插入图片描述

1.3. 各个注册中心比较

在这里插入图片描述

Nacos支持AP和CP模式的切换:C是所有节点在同一时间看到的数据是一致的;而A的定义是所有的请求都会收到响应。

CAP即:

  • Consistency(一致性)
  • Availability(可用性)
  • Partition tolerance(分区容忍性)

何时选择使用何种模式?

一般来说,如果不需要存储服务级别的信息且服务实例是通过nacos-client注册,并能够保持心跳上报,那么就可以选择AP模式。当前主流的服务如 Spring cloud 和 Dubbo 服务,都适用于AP模式,AP模式为了服务的可能性而减弱了一致性,因此AP模式下只支持注册临时实例。

如果需要在服务级别编辑或者存储配置信息,那么 CP 是必须,K8S服务和DNS服务则适用于CP模式。
CP模式下则支持注册持久化实例,此时则是以 Raft 协议为集群运行模式,该模式下注册实例之前必须先注册服务,如果服务不存在,则会返回错误。

一句话,使用Nacos作为配置中心,而且经常会修改配置, 那么就需要保证一致性,所以选cp。

Nacos默认是AP,可以通过调用API进行修改为CP:

curl -X PUT "$NACOS_SERVER:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP"

在这里插入图片描述

二、Nacos作为服务注册中心

官网文档:https://spring-cloud-alibaba-group.github.io/github-pages/2021/en-us/index.html#_spring_cloud_alibaba_nacos_discovery

测试注册中心,我们就需要创建两个服务,并且两个服务都注册到注册中心当中,然后通过服务名称来进行远程调用。

2.1. 基于Nacos的服务提供者

1.创建项目
2.引入pom依赖

<properties>
    <maven.compiler.source>8</maven.compiler.source>
    <maven.compiler.target>8</maven.compiler.target>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <springboot.version>2.6.8</springboot.version>
    <springcloud.alibaba.version>2021.0.1.0</springcloud.alibaba.version>
</properties>

<dependencyManagement>
    <dependencies>
        <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-dependencies</artifactId>
           <version>${springboot.version}</version>
           <type>pom</type>
           <scope>import</scope>
       </dependency>
        <dependency>
           <groupId>com.alibaba.cloud</groupId>
           <artifactId>spring-cloud-alibaba-dependencies</artifactId>
           <version>${springcloud.alibaba.version}</version>
           <type>pom</type>
           <scope>import</scope>
        </dependency>
   </dependencies>        
</dependencyManagement>

<dependencies>
    <!--SpringCloud ailibaba nacos -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <!-- SpringBoot整合Web组件 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
</dependencies>

3.添加yml配置文件

server:
  port: 9001

spring:
  application:
    name: nacos-payment-provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # ip:端口

management:
  endpoints:
    web:
      exposure:
        include: '*'

4.启动类添加注解@EnableDiscoveryClient
5.添加测试接口

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class PaymentController {

    @Value("${server.port}")
    private String serverPort;

    @GetMapping(value = "/payment/nacos/{id}")
    public String getPayment(@PathVariable("id") Integer id) {
        return "nacos registry, serverPort: " + serverPort + "\t id" + id;
    }
}

6.启动测试访问http://localhost:9001/payment/nacos/222

在这里插入图片描述

如下就成功注册到注册中心了:

在这里插入图片描述

2.2. 基于Nacos的服务消费者

1.创建项目
2.引入pom依赖(和上面依赖一样),基于上面的依赖再添加一个spring-cloud-starter-loadbalancer,不添加RestTemplate通过服务名称来调用会报错的。

原因:https://blog.csdn.net/weixin_43888891/article/details/126690022?spm=1001.2014.3001.5502

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

3.添加yml配置文件

server:
  port: 83

spring:
  application:
    name: nacos-order-consumer
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

#消费者将要去访问的微服务名称(注册成功进nacos的微服务提供者,注意这个是自定义的配置)
service-url:
  nacos-user-service: http://nacos-payment-provider

4.启动类添加注解@EnableDiscoveryClient
5.添加RestTemplate配置,注入到容器,添加负载均衡@LoadBalanced

@Configuration
public class ApplicationContextBean {
    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }
}

6.添加测试接口

@RestController
public class OrderNacosController {
    @Resource
    private RestTemplate restTemplate;

    @Value("${service-url.nacos-user-service}")
    private String serverURL;

    @GetMapping("/consumer/payment/nacos/{id}")
    public String paymentInfo(@PathVariable("id") Long id) {
        return restTemplate.getForObject(serverURL + "/payment/nacos/" + id, String.class);
    }
}

7.测试:测试RestTemplate 根据名称调用,然后并且是负载均衡的,那么我们就需要准备两个提供者。如下方式即可启动两个提供者,一个是9001,一个是9002。

在这里插入图片描述

这时候注册中心会一共有3个服务,如下:

在这里插入图片描述

启动两个提供者,然后也启动83消费者,测试访问http://localhost:83/consumer/payment/nacos/777

访问两次会发现他是轮询调用的:

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

三、Nacos作为服务配置中心

3.1. Nacos作为配置中心-基础配置

1.创建项目
2.引入pom依赖

<properties>
    <maven.compiler.source>8</maven.compiler.source>
    <maven.compiler.target>8</maven.compiler.target>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <springboot.version>2.6.8</springboot.version>
    <springcloud.alibaba.version>2021.0.1.0</springcloud.alibaba.version>
</properties>

<dependencyManagement>
    <dependencies>
        <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-dependencies</artifactId>
           <version>${springboot.version}</version>
           <type>pom</type>
           <scope>import</scope>
       </dependency>
        <dependency>
           <groupId>com.alibaba.cloud</groupId>
           <artifactId>spring-cloud-alibaba-dependencies</artifactId>
           <version>${springcloud.alibaba.version}</version>
           <type>pom</type>
           <scope>import</scope>
        </dependency>
   </dependencies>        
</dependencyManagement>

<dependencies>
    <!--nacos-config-->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>
    <!--nacos-discovery-->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <!--web + actuator-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
    <!--cloud新版本默认将bootstrap移除了,所以需要添加如下依赖-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-bootstrap</artifactId>
    </dependency>
</dependencies>

3.添加yml配置文件

这里我用了两个yml,一个bootstrap.yml,一个application.ymlNacosspringcloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取配置之后,才能保证项目的正常启动。springboot中配置文件的加载是存在优先级顺序的,bootstrap优先级高于application,所以涉及到nacos配置中心的相关配置一定要放到bootstrap当中,其他的我个人感觉随意,可以选择放在application当中。

bootstrap.yml

server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服务注册中心地址
      config:
        server-addr: localhost:8848 #Nacos作为配置中心地址
        file-extension: yaml #指定yaml格式的配置

application.yml:

spring:
  profiles:
    active: dev # 表示开发环境

4.启动类添加注解@EnableDiscoveryClient
5.添加测试接口,只要涉及到读取配置文件当中的配置,一定要加@RefreshScope

@RestController
@RefreshScope //在控制器类加入@RefreshScope注解使当前类下的配置支持Nacos的动态刷新功能。
public class ConfigClientController {
    @Value("${config.info}")
    private String configInfo;

    @GetMapping("/config/info")
    public String getConfigInfo() {
        return configInfo;
    }
}

6.nacos当中添加配置:nacos-config-client-dev.yaml

在这里插入图片描述

在这里插入图片描述

7.启动测试访问:http://localhost:3377/config/info
在这里插入图片描述

当我们修改Nacos配置文件的配置,接口能立马拿到最新的。cloud config配置中心需要配合bus来实现动态刷新配置功能,而Nacos和Consul一样本身就具备动态刷新功能。之所以config需要通过bus是因为config是单纯的配置中心,而Nacos和Consul本身就是注册中心,所以他们拥有着注册服务的ip和端口,也就是一旦消息配置修改了,他直接可以通知到他们。

Nacos会记录配置文件的历史版本默认保留30天,此外还有一键回滚功能,回滚操作将会触发配置更新。

在这里插入图片描述

3.2. Data Id命名规则

官网说明:https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html

注意Data Id在Nacos官网当中是有固定命名规则的

公式:${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}

在这里插入图片描述

3.3. Namespace + Group + Data ID

问题1:

实际开发中,通常一个系统会准备:dev开发环境、test测试环境、prod生产环境。
如何保证指定环境启动时服务能正确读取到Nacos上相应环境的配置文件呢?

问题2:

一个大型分布式微服务系统会有很多微服务子项目,每个微服务项目又都会有相应的开发环境、测试环境、预发环境、正式环境…那怎么对这些微服务配置进行管理呢?

在这里插入图片描述

默认的命名空间:public并不是我们创建的,是自带的!

在这里插入图片描述

Namespace+Group + Data ID三者关系? 为什么这么设计?

默认情况:Namespace=public,Group=DEFAULT_GROUP, 默认Cluster是DEFAULT

Nacos默认的命名空间是public,Namespace主要用来实现隔离。

比方说我们现在有三个环境:开发、测试、生产环境,我们就可以创建三个Namespace,不同的Namespace之间是隔离的。

Group默认是DEFAULT_GROUP,Group可以把不同的微服务划分到同一个分组里面去

Service就是微服务;一个Service可以包含多个Cluster(集群),比方说为了容灾,将Service微服务分别部署在了杭州机房和广州机房,这时就可以给杭州机房的Service微服务起一个集群名称(HZ),给广州机房的Service微服务起一个集群名称(GZ),还可以尽量让同一个机房的微服务互相调用,以提升性能,也就是可以根据集群的区域来进行分组。

Data ID:就是微服务的实例。

3.4. Nacos作为配置中心-分类配置

(1)DatalD方案

指定spring.profile.active和配置文件的DatalD来使不同环境下读取不同的配置

默认空间+默认分组+新建dev和test两个DatalD

在这里插入图片描述

这样我们spring.profile.active设置为test的时候就是读取的nacos-config-client-test.yaml,如果是dev则读取的nacos-config-client-dev.yaml

在这里插入图片描述

(2)Group方案:通过Group实现环境区分

在这里插入图片描述

在这里插入图片描述

在config下增加一条group的配置即可。可配置为DEV_GROUP或TEST_GROUP

在这里插入图片描述

(3)Namespace方案

新建dev/test的Namespace

在这里插入图片描述

回到服务管理-服务列表查看,然后再命名空间创建配置。

在这里插入图片描述

在这里插入图片描述
(4)总结

说白了Nacos相当于是给我们提供了三级目录,Namespace是一级目录,group是二级目录,公式:${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}是具体的文件。而至于我们怎么应用这三级目录,可以自己做决定,总之就是为了区分配置文件的。

3.5. Nacos服务注册命名空间

Nacos在服务注册的时候也是区分命名空间的,默认是public,可以通过如下设置,设置的是命名空间ID

在这里插入图片描述

在这里插入图片描述

四、Nacos集群和持久化配置

由于篇幅已经很长了,Nacos集群和持久化配置选择在后续文章当中讲解。


如果本篇文章对您有所帮助,麻烦您给小编留个赞,您的每一个赞,将是博主继续努力前进的动力!

相关文章:

  • 数字孪生在工业制造中的应用领域及技术体系构建
  • 9.4-学习ing
  • Docker 学习笔记总结(二)
  • 标准地图获取及使用
  • Kubernetes控制平面组件:Controller-Manager控制器管理
  • 数据备份必备知识与策略设计方法
  • Checkerboard Artifacts(棋盘伪影)的发生以及解决方案:
  • 【算法题解】拓扑序计数+树形DP
  • 优雅编码之——传统项目中,使用openfeign替换掉项目中的httpclient
  • 【ENVI精讲】处理专题五:基于像元二分模型的植被覆盖度反演
  • Docker 官方镜像Tomcat 无法访问 解决方案
  • Qt使用OpenCv
  • 【JavaEE进阶系列 | 从小白到工程师】泛型的详细介绍使用与类型通配符,直接上手
  • java毕业设计论坛管理系统mybatis+源码+调试部署+系统+数据库+lw
  • k8s对接ceph,ceph-csi方式
  • php的引用
  • [数据结构]链表的实现在PHP中
  • CentOS学习笔记 - 12. Nginx搭建Centos7.5远程repo
  • Docker: 容器互访的三种方式
  • Java小白进阶笔记(3)-初级面向对象
  • js算法-归并排序(merge_sort)
  • Nginx 通过 Lua + Redis 实现动态封禁 IP
  • Shadow DOM 内部构造及如何构建独立组件
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • Web设计流程优化:网页效果图设计新思路
  • win10下安装mysql5.7
  • 包装类对象
  • 笨办法学C 练习34:动态数组
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • 第十八天-企业应用架构模式-基本模式
  • 记一次和乔布斯合作最难忘的经历
  • 前端技术周刊 2018-12-10:前端自动化测试
  • 区块链共识机制优缺点对比都是什么
  • 中国人寿如何基于容器搭建金融PaaS云平台
  • 浅谈sql中的in与not in,exists与not exists的区别
  • ​DB-Engines 11月数据库排名:PostgreSQL坐稳同期涨幅榜冠军宝座
  • # 睡眠3秒_床上这样睡觉的人,睡眠质量多半不好
  • #pragma once
  • ${ }的特别功能
  • (2015)JS ES6 必知的十个 特性
  • (C#)Windows Shell 外壳编程系列9 - QueryInfo 扩展提示
  • (html转换)StringEscapeUtils类的转义与反转义方法
  • (一)Thymeleaf用法——Thymeleaf简介
  • .NET 6 在已知拓扑路径的情况下使用 Dijkstra,A*算法搜索最短路径
  • .net core webapi 部署iis_一键部署VS插件:让.NET开发者更幸福
  • .NET Core实战项目之CMS 第一章 入门篇-开篇及总体规划
  • .NET Framework .NET Core与 .NET 的区别
  • .Net 中的反射(动态创建类型实例) - Part.4(转自http://www.tracefact.net/CLR-and-Framework/Reflection-Part4.aspx)...
  • .NET 中小心嵌套等待的 Task,它可能会耗尽你线程池的现有资源,出现类似死锁的情况
  • .NET/C# 获取一个正在运行的进程的命令行参数
  • .NET/C# 项目如何优雅地设置条件编译符号?
  • .NET:自动将请求参数绑定到ASPX、ASHX和MVC(菜鸟必看)
  • .Net8 Blazor 尝鲜
  • .Net接口调试与案例
  • .Net中的设计模式——Factory Method模式