vlambda博客
学习文章列表

Nacos入门指南01 - Nacos是什么?

你好,欢迎阅读,本文是系列文章中的第1篇。

Part1 - Nacos 是什么?

Part2 - Nacos 环境搭建

Part3 - Nacos 服务发现实践

Part4 - Nacos 分布式配置实践

本文的目标是理解 Nacos 的概念作用,并理解服务发现与分布式配置的概念。

1. Nacos 介绍

上图为首页截图,已经明确的说明了 Nacos的2个核心作用:

  • 服务发现
  • 配置管理

所以 Nacos 可以作为服务注册中心、配置中心。

Nacos 这个名字怎么读呢?它的音标为 /nɑ:kəʊs/。这个名字不是一个标准的单词,而是以下单词的首字母缩写:

Name and Config Service

从命名中也可以看出 Nacos 的功能了。

从上图中可以看到,Nacos 的网站是中文的,这是因为 Nacos 是国产的,是阿里开源的。

阿里为 SpringCloud 贡献了一个子项目,叫做 SpringCloud Alibaba,其中包括了微服务开发中的几个基础组件,Nacos 就是此项目中的一项技术。

Nacos入门指南01 - Nacos是什么?

SpringCloud Alibaba 可以对标 SpringCloud 中老牌的主流项目 SpringCloud Netflix(包括 Eureka、Hystrix、Zuul 等等),也是一个技术集,包括:

Nacos入门指南01 - Nacos是什么?

可以看到,主要技术有:

  • Sentinel -- 提供流控、服务降级、熔断能力,为体统提供防护。
  • Nacos -- 负责服务注册与发现,还有分布式配置。
  • RocketMQ -- 用于实现事件驱动模式、消息总线,已经整合了 SpringCloud Stream。
  • Seata -- 用于实现分布式事务。
  • Dubbo RPC -- 使用 RPC 进行服务调用。

现在已经清楚 Nacos 是什么了,它是阿里开源的 SpringCloud Alibaba 项目下的一项技术,可以实现服务注册中心、分布式配置中心。

下面大概浏览一下 Nacos 的控制台界面,看看主要的功能。

  • 服务管理
Nacos入门指南01 - Nacos是什么?
Nacos入门指南01 - Nacos是什么?
Nacos入门指南01 - Nacos是什么?
  • 配置管理
Nacos入门指南01 - Nacos是什么?

Nacos入门指南01 - Nacos是什么?

Nacos入门指南01 - Nacos是什么?

2. 服务发现概念简介

分布式系统中,包含多个独立的服务,服务之间存在需要调用的需求,应该如何调用?

服务调用时必须知道目标服务实例的 IP、端口、API 接口。

其中 API 信息可以通过服务接口文档中获知,但 IP、端口 都是动态的,每次部署服务实例的时候可能都会变。

Nacos入门指南01 - Nacos是什么?

此时必须有一种更优的发现机制,就出现了服务注册中心。

Nacos入门指南01 - Nacos是什么?

当某个服务实例停止运行的时候,主动让注册中心销毁自己的信息。

如果服务实例不是主动停止,而是因为故障等原因死掉的,如何处理?需要注册中心能够主动清理。

注册中心要能够实时知道各个服务实例的状态,通过心跳机制来实现,实例定时向注册中心发送请求,表明自己还活着,如果心跳没了,注册中心就可以对其清理。

Nacos入门指南01 - Nacos是什么?

一个服务实例向调用另一个服务时,可以根据服务名称从注册中心获取此服务的实例信息列表,从中选取一个实例进行调用。

以上就是注册中心这种服务发现机制的工作方式。

3. 分布式配置概念简介

每个服务都会有自己的配置信息,例如 SpringBoot 项目中的配置文件,服务运行时会读取配置文件中的配置项。

一个服务通常会启动多个实例,来提供其可靠性,那么每个实例中就都会包含这个配置文件,一个服务的各个实例中配置都是相同的。

如果要改某个配置项的值,怎么办?

修改配置文件,然后重新部署此服务的所有实例。麻烦低效。

如果把服务的配置信息提出来,不放在自己的配置文件中,而是放到一个第三方的配置中心,服务实例从配置中心读取属于自己的配置,而且,在配置中心里面修改配置项之后,所有相关实例都可以立即拿到最新值,不用重新部署了,这样就方便很多。

所以分布式配置有2大好处:

  • 方便维护,集中维护优于分散式维护每个服务的配置文件。
  • 动态更新,配置修改后直接生效,不用重新部署。

此外,Nacos 还可以做配置的版本管理,轻松实现历史版本的回滚。