SpringCloud-Alibaba的Nacos究竟有多好用?(上)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: SpringCloud-Alibaba的Nacos究竟有多好用?

Nacos是什么?


92cd0f7a41db40f084c14387f394723e.png


官方是这么说的 🔈


1.nacos是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

2.服务(Service)是Nacos世界的一等公民。

官网:https://nacos.io/zh-cn/


怎么去理解这两句话呢?也就是说Nacos不仅提供了服务注册与发现功能,还提供了配置管理的功能,同时还提供了可视化的管理平台。而Nacos又是围绕着Service转的。


如果大家查看源码,会发现Nacos的核心API中定义了两个接口NamingService和ConfigService。服务注册与发现围绕着NamingService展开,而配置管理则围绕着ConfigService展开。


概括:Nacos就是注册中心+配置中心的组合


等价:Nacos = Eureka+Config+Bus


Nacos的4个核心特性 👇


服务发现和服务健康监测

  • Nacos使服务更容易注册,并通过DNS或HTTP接口发现其他服务,Nacos还提供服务的实时健康检查,以防止向不健康的主机或服务实例发送请求。

动态配置服务

  • 动态配置服务允许您在所有环境中以集中和动态的方式管理所有服务的配置。Nacos消除了在更新配置时重新部署应用程序,这使配置的更改更加高效和灵活。

动态DNS服务

  • Nacos提供基于DNS协议的服务发现能力,旨在支持异构语言的服务发现,支持将注册在Nacos上的服务以域名的方式暴露端点,让三方应用方便的查阅及发现。

服务和元数据管理

  • Nacos能让您从微服务平台建设的视角管理数据中心的所有服务及元数据,包括管理服务的描述,生命周期,服务的静态依赖分析,服务的健康状态,服务的流量管理,路由及安全策略。

nacos config对比springcloud config有何优势? 👇

  • springcloud config大部分场景结合git 使用, 动态变更还需要依赖Spring Cloud Bus 消息总线来通过所有的客户端变化。
  • springcloud config不提供可视化界面。
  • nacos config使用长连接更新配置, 一旦配置有变动后,通知Provider的过程非常的迅速, 从速度上秒杀springcloud原来的config几条街。

注册中心有了Eureka ,为何还要用Nacos? 👇

  • eureka 2.0闭源码了。
  • 从官网来看nacos 的注册的实例数是大于eureka的。
  • 因为nacos使用的raft协议,nacos集群的一致性要远大于eureka集群。


raft协议

分布式一致性协议 Raft,自 2013 年论文发表,之后就受到了技术领域的热捧,与其他的分布式一致性算法比,Raft 相对比较简单并且易于实现,这也是 Raft 能异军突起的主要因素。

7de6e5c5bf004d2e98fa29f493428b2e.png


Raft 协议强依赖 Leader 节点来确保集群数据一致性。即 client 发送过来的数据均先到达 Leader 节点,Leader 接收到数据后,先将数据标记为 uncommitted 状态,随后 Leader 开始向所有 Follower 复制数据并等待响应,在获得集群中大于 N/2 个 Follower 的已成功接收数据完毕的响应后,Leader 将数据的状态标记为 committed,随后向 client 发送数据已接收确认,在向 client 发送出已数据接收后,再向所有 Follower 节点发送通知表明该数据状态为committed。


下载安装Nacos

  • 下载前确保本地Java8+Maven环境已经ok

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

c7771bdc15c44468bf795fb280883cb6.png


解压安装包,解压完成后直接运行bin目录下的startup.cmd

4c8e6289be294943a9a784f3428b0aad.png


373972bb158d416aa80615332770e1f5.png

运行成功后直接访问 http://localhost:8848/nacos

  • 默认账号密码都是 nacos

e32f83acf22b446eb6c1461846f90599.png

94327a49ef414526a3d4f17ed93b25d8.png

如需使用Docker下载安装Nacos并完成持久化配置点击后方链接进行跳转 👉 Docker下载安装Nacos并完成持久化配置


Nacos领域模型

由于项目应用环境的复杂度,同时考虑到各类数据的有效存储管理,在Nacos中对于数据的归类存储提供了不同的模型结构。

d4dc76887ecc4001b022bcfee8d4234f.png


  • Namespace(命名空间):对不同的环境进⾏隔离,⽐如隔离开发环境、测试环境和⽣产环境。
  • Group(分组):,将若⼲个服务或者若⼲个配置集归为⼀组,通常习惯⼀个系统归为⼀个组。推荐命名格式:产品名称+分组名称
  • Service(服务):某⼀个服务,例如会员微服务。

在下图的分级存储模型可以看到,在服务级别,保存了健康检查开关、元数据、路由机制、保护阈值等设置,而集群保存了健康检查模式、元数据、同步机制等数据,实例保存了该实例的ip、端口、权重、健康检查状态、下线状态、元数据、响应时间。

40b5fd65df27438789223e6876dea0a4.png


  • Cluster(集群):集群是一个逻辑概念,可以区分不同的服务节点所处的网络环境。
  • Instance(实例):保存具体的微服务注册数据,每一个服务节点对应一个实例数据。
  • DataId(配置数据ID):自定义的配置数据集推荐命名格式:包名称.类名称(小写字母)


可以在nacos控制台看到与之对应的界面


791308652ef8472486f97089e10de057.png

如果还无法理解,我们可以直接从代码层面来看看Namespace、Group和Service是如何存储的。


/** 
 * Map(namespace, Map(group::serviceName, Service)). 
 */ 
private final Map<String, Map<String, Service>> serviceMap = new ConcurrentHashMap<>();

Nacos服务注册表结构为 Map。这个双层Map的key分别是namespace和group::serviceName,Nacos基于namespace的设计是为了做多环境以及多租户数据(配置和服务)隔离的。如果用户有多套环境(开发、测试、生产等环境),则可以分别建三个不同的namespace。


在此我们先忽略掉一对多的情况,假如只有一个命名空间它的整个层级包含关系为Namespace包含多个Group、Group可包含多个Service、Service可包含多个Cluster、Cluster中包含Instance集合。


// ServiceManager类,Map(namespace, Map(group::serviceName, Service)) 
private final Map<String, Map<String, Service>> serviceMap = new ConcurrentHashMap<>(); 
// Service类,Map(cluster,Cluster) 
private Map<String, Cluster> clusterMap = new HashMap<>(); 
// Cluster类 
private Set<Instance> persistentInstances = new HashSet<>(); 
private Set<Instance> ephemeralInstances = new HashSet<>(); 
// Instance类 
private String instanceId; 
private String ip; 
private int port; 
private double weight = 1.0D; 

其中,实例又分为临时实例和持久化实例。它们的区别关键是健康检查的方式。临时实例使用客户端上报模式,而持久化实例使用服务端反向探测模式。


临时实例需要能够自动摘除不健康实例,而且无需持久化存储实例。持久化实例使用服务端探测的健康检查方式,因为客户端不会上报心跳,自然就不能去自动摘除下线的实例。


Nacos作为注册中心


注册中心可以说是微服务架构中的通讯录,它记录了服务和服务地址的映射关系。在分布式架构中,服务会注册到这里,当服务需要调用其它服务时,就到这里找到服务的地址,进行调用。


注册中心主要有三部分组成服务注册中心、服务提供者、服务消费者

ff90c15783ba4eb98094f626e0de41b7.png


Nacos注册中心实例剔除策略


服务注册的策略的是每5秒向nacos server发送一次心跳,心跳带上了服务名,服务ip,服务端口等信息。同时 nacos server也会向client 主动发起健康检查,支持tcp/http检查。如果15秒内无心跳且健康检查失败则认为实例不健康,如果30秒内健康检查失败则剔除实例。


Nacos的Server与Client


Nacos注册中心分为Server与Client,Nacos提供SDK和openApi,如果没有SDK也可以根据openApi手动写服务注册与发现和配置拉取的逻辑。


Server采用Java编写,基于Spring Boot框架,为Client提供注册发现服务与配置服务。Client支持包含了目前已知的Nacos多语言客户端及Spring生态的相关客户端。Client与微服务嵌套在一起。


Nacos的DNS实现依赖了CoreDNS,其项目为nacos-coredns-plugin。该插件提供了基于CoreDNS的DNS-F客户端,开发语言为go。


e6a10ef711804713b7d3f7de4be16d53.png


相关文章
|
2月前
|
存储 Java Nacos
Spring Cloud+Nacos+KMS 动态配置最佳实践
本文讲述了 Spring Cloud 应用中结合 Nacos 实现了运行期配置动态更新的功能,以及在此基础上结合 KMS 在不改动代码的情况下对应用使用的敏感配置进行保护,解决将配置迁移到 Nacos 中可能存在的数据安全顾虑,并对其底层工作原理做了简单介绍。
538 14
|
5月前
|
Cloud Native Java Nacos
微服务时代的新宠儿!Spring Cloud Nacos实战指南,带你玩转服务发现与配置管理,拥抱云原生潮流!
【8月更文挑战第29天】Spring Cloud Nacos作为微服务架构中的新兴之星,凭借其轻量、高效的特点,迅速成为服务发现、配置管理和治理的首选方案。Nacos(命名和配置服务)由阿里巴巴开源,为云原生应用提供了动态服务发现及配置管理等功能,简化了服务间的调用与依赖管理。本文将指导你通过五个步骤在Spring Boot项目中集成Nacos,实现服务注册、发现及配置动态管理,从而轻松搭建出高效的微服务环境。
321 0
|
6月前
|
NoSQL Java Nacos
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
206 3
|
3月前
|
JSON SpringCloudAlibaba Java
Springcloud Alibaba + jdk17+nacos 项目实践
本文基于 `Springcloud Alibaba + JDK17 + Nacos2.x` 介绍了一个微服务项目的搭建过程,包括项目依赖、配置文件、开发实践中的新特性(如文本块、NPE增强、模式匹配)以及常见的问题和解决方案。通过本文,读者可以了解如何高效地搭建和开发微服务项目,并解决一些常见的开发难题。项目代码已上传至 Gitee,欢迎交流学习。
213 1
Springcloud Alibaba + jdk17+nacos 项目实践
|
8月前
|
Unix Shell Linux
SpringCloud Nacos使用
SpringCloud Nacos使用
61 0
|
8月前
|
存储 Nacos 数据安全/隐私保护
【SpringCloud】Nacos的安装、Nacos注册、Nacos服务多级存储模型
【SpringCloud】Nacos的安装、Nacos注册、Nacos服务多级存储模型
96 1
|
4月前
|
负载均衡 Java Nacos
SpringCloud基础2——Nacos配置、Feign、Gateway
nacos配置管理、Feign远程调用、Gateway服务网关
SpringCloud基础2——Nacos配置、Feign、Gateway
|
4月前
|
负载均衡 Java Nacos
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
微服务介绍、SpringCloud、服务拆分和远程调用、Eureka注册中心、Ribbon负载均衡、Nacos注册中心
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
|
5月前
|
Cloud Native Java Nacos
Spring Cloud Config、Apollo、Nacos和Archaius对比
这篇文章对比了Spring Cloud Config、Apollo、Nacos和Archaius这四种配置中心的适应场景、优缺点。文中讨论了它们的功能特点,例如Spring Cloud Config的集中化配置管理和动态刷新能力,Apollo的实时配置推送和权限治理,Nacos的服务发现和管理功能,以及Archaius的动态配置更新能力。文章指出选择配置中心应根据项目需求和架构来决定,并提供了一个对比图来帮助读者更直观地理解这些工具的差异。
162 1
Spring Cloud Config、Apollo、Nacos和Archaius对比
|
3月前
|
负载均衡 算法 Nacos
SpringCloud 微服务nacos和eureka
SpringCloud 微服务nacos和eureka
83 0