【Nacos】Nacos原理解析

在学习nacos之前,我们先来认识一下什么是nacos。

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

说白了nacos就是实现分布式场景下的配置中心。

1.为什么需要配置中心?

在分布式微服务场景下,我们一个系统往往涉及到多个运行环境,每个运行环境有不同的配置,每个服务之间可能有公用的配置,传统单体开发我们会直接把这些配置放到项目的配置文件下,

然后随着服务启动进行加载,每次改动只需要重启一个服务即可。但是在微服务场景下,一个配置改动往往要改动很多的服务,改完后还要去打包,部署,可能只是添加一个简单的穿透账号,

就要花费一个开发人员的30分钟时间,显然,这是非常麻烦的。于是有了配置中心的出现,所有需要快速变更的配置都扔到配置中心,一旦改变直接修改配置中心,而无需重启服务。

2.常见配置中心的架构是怎样的?

【Nacos】Nacos原理解析_第1张图片

3. nacos的架构是怎样的?

【Nacos】Nacos原理解析_第2张图片

4. Nacos源码阅读(关键部分)

<dependency>
 <groupId>com.alibaba.boot</groupId>
 <artifactId>nacos-config-spring-boot-starter</artifactId>
 <version>0.2.10</version>
 <exclusions>
 <exclusion>
 <groupId>com.alibaba.nacos</groupId>
 <artifactId>nacos-client</artifactId>
 </exclusion>
 </exclusions>
</dependency>
<dependency>
 <groupId>com.alibaba.nacos</groupId>
 <artifactId>hualala-nacos-client</artifactId>
 <version>2.0.4</version>
</dependency>

ClientWorker.java

通过rpcClient 从nacos服务端拉取配置。
【Nacos】Nacos原理解析_第3张图片

LocalConfigInfoProcessor.java

从本地先读取配置,如果读不到,就从远程拿,读到了,就直接返回。

【Nacos】Nacos原理解析_第4张图片

LocalConfigInfoProcessor.java

从远程拉取数据,如果拉到了,就保存到本地。

【Nacos】Nacos原理解析_第5张图片

5. nacos是推数据还是拉数据呢? 答案是拉。为什么是拉?

直接推数据固然可以,但是分布式环境下服务器太多,逐个推送不太现实,浪费资源。

而且通过这种方式,一方面可以校验请求者的权限,另一方面,有时候还是需要调用配置中心的API,比如下载最新的证书之类的。

还有就是,服务启动时是需要从配置中心拉一份数据下来,如果不过不这样,就要先告诉配置中心服务启动起来了,然后配置中心不停的pub数据过来,显然有些浪费资源。

加餐:此文分析略有浅薄,Nacos还有很多设计理念和架构方式值得探究,鄙人也是初学者,如想继续深入,可以阅读源码和参考以下pdf:
Nacos原理解析

你可能感兴趣的:(【分布式&微服务】,nacos,配置中心,java,中间件,分布式)