Nacos是什么?
官方是这么说的 🔈
1.nacos是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
2.服务(Service)是Nacos世界的一等公民。
怎么去理解这两句话呢?也就是说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 能异军突起的主要因素。
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
解压安装包,解压完成后直接运行bin目录下的startup.cmd
运行成功后直接访问 http://localhost:8848/nacos
- 默认账号密码都是
nacos
如需使用Docker下载安装Nacos并完成持久化配置点击后方链接进行跳转 👉 Docker下载安装Nacos并完成持久化配置
Nacos领域模型
由于项目应用环境的复杂度,同时考虑到各类数据的有效存储管理,在Nacos中对于数据的归类存储提供了不同的模型结构。
- Namespace(命名空间):对不同的环境进⾏隔离,⽐如隔离开发环境、测试环境和⽣产环境。
- Group(分组):,将若⼲个服务或者若⼲个配置集归为⼀组,通常习惯⼀个系统归为⼀个组。推荐命名格式:
产品名称+分组名称
- Service(服务):某⼀个服务,例如会员微服务。
在下图的分级存储模型可以看到,在服务级别,保存了健康检查开关、元数据、路由机制、保护阈值等设置,而集群保存了健康检查模式、元数据、同步机制等数据,实例保存了该实例的ip、端口、权重、健康检查状态、下线状态、元数据、响应时间。
- Cluster(集群):集群是一个逻辑概念,可以区分不同的服务节点所处的网络环境。
- Instance(实例):保存具体的微服务注册数据,每一个服务节点对应一个实例数据。
- DataId(配置数据ID):自定义的配置数据集推荐命名格式:
包名称.类名称(小写字母)
可以在nacos控制台看到与之对应的界面
如果还无法理解,我们可以直接从代码层面来看看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作为注册中心
注册中心可以说是微服务架构中的通讯录
,它记录了服务和服务地址的映射关系。在分布式架构中,服务会注册到这里,当服务需要调用其它服务时,就到这里找到服务的地址,进行调用。
注册中心主要有三部分组成服务注册中心、服务提供者、服务消费者
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。