1898 字
9 分钟
Nacos

Nacos#

浅聊微服务配置和注册中心#

配置中心#

传统的静态配置方式要想修改某个配置只能修改之后重新发布应用,要实现动态性,可以选择使用数据库,通过定时轮询访问数据库来感知配置的变化。轮询频率低感知配置变化的延时就长,轮询频率高,感知配置变化的延时就短,但比较损耗性能,需要在实时性和性能之间做折中。配置中心专门针对这个业务场景,兼顾实时性和一致性来管理动态配置。配置中心兼往往顾了集中管理、动态更新和版本控制等优点。

注册中心#

注册中心用于管理和维护微服务的注册信息,包括微服务的网络位置(IP地址和端口)以及其他元数据。每个微服务在启动时向注册中心注册自己的信息,并定期发送心跳以保持活动状态。其他微服务可以通过查询注册中心获取所需服务的信息,从而实现服务的发现和调用。

微服务中的使用#

配置中心和注册中心通常会一起使用,配合实现微服务的配置管理、服务发现和通信。它们为微服务架构的可伸缩性、弹性和灵活性提供了重要的基础设施。

作为配置中心应该要求支持集中化管理、配置存储和分发、动态更新、版本控制、安全性和权限控制和监控和告警;作为注册中心要做到服务注册和注销、服务发现、心跳和健康检查、负载均衡、高可用性和容错性和监控和告警。目前市面上现在针对配置中心和注册中心分别都有很多产品,像百度的 Disconf、Spring的 Spring Cloud Config、携程的 Apollo、阿里的 Nacos、网飞的 Eureka等。

结合网络上的综合评价来看总,作为配置中心的话,Apollo 和 Nacos 相对于 Spring Cloud Config 的生态支持更广,在配置管理流程上做的更好。Apollo 相对于 Nacos 在配置管理做的更加全面,不过使用起来也要麻烦一些。Nacos 使用起来相对比较简洁,在对性能要求比较高的大规模场景更适合。在注册中心上来看,Eureka 在跨区域部署和大规模集群上可能面临一些性能和可扩展性方面的挑战,并且在广泛的生态上来看, Nacos 是更好的选择。结合双方的优点,Nacos 非常适合作为微服务学习的第一选择,想要更加详细了解 Nacos 请点击下方官网链接访问。

title: Nacos 中文官网
desc: 点击跳转官网查看详细内容
logo: /assets/images/study/backend/java/micro-services/nocas/nacos_colorful.png
link: https://nacos.io/zh-cn/index.html
color: rgba(173, 216, 590, 0.15)

快速开始#

Nacos服务端单机模式启动#

我们这里根据 Spring Cloud Alibaba 毕业版本推荐选择了 2.2.1 的版本,相比于 Eureka 来说,Nacos 同样也分为客户端和服务端,不过服务端不需要我们自行搭建,我们直接下载使用官方的即可,这里你可以选择下载二进制包直接使用或者 Docker 镜像的方式都可以,我们这里使用下载二进制包的方法,可以去下面网址找到你想要的版本进行下载。

title: Nacos 版本下载网址
desc: 点击跳转官网查看详细内容
logo: /assets/common-icon/spring-initializr.svg
link: https://github.com/alibaba/nacos/tags
color: rgba(173, 216, 590, 0.15)

下载完成后启动前,这里值得注意的是 Nacos 在2.2.0.12.2.1版本后,必须修改 conf 目录下的 application.properties 文件设置其中的 nacos.core.auth.plugin.nacos.token.secret.key 值,否则不能启动,该参数是鉴权用于生成用户登陆临时accessToken所使用的密钥,默认可以使用SecretKey012345678901234567890123456789012345678901234567890123456789,该值可用于临时测试,实际使用时请务必更换为自定义的其他有效值。如果你不想使用内置数据库想绑定数据库实现持持久化,需要把 Config Module Related Configurations 中的配置全部打开并配置正确的数据库参数,并且把 conf 目录中对应数据库的sql文件执行生成工作表。一切准备完毕后启动即可。

Terminal window
sh startup.sh -m standalone

执行命令后可以根据自己的配置访问下面网址进行访问。如果启动失败,可以在日志文件夹中寻找 start.out 文件查看启动失败的原因,这里面的日志会根据你每次启动而更换,如果是想查看历来所有的日志则需要去 nacos.log 文件查看。

http://{ip}:{port}/nacos/

  • 默认账号:nacos
  • 默认密码:nacos

启动成功后可以通过添加配置文件来测试各功能是否好用,如果是外置数据源的情况可以配置完后查看数据库表中数据是否存在来判断。

Nacos客户端启动后注册#

准备一个 Spring boot 项目,这里建议使用下面阿里云网站进行构建,如果你使用 Spring 官网的工具会发现在 IDEA 中添加依赖的时候找不到 Nacos ,还需要自己去添加。并且使用阿里云构建项目会在项目中给你添加 demo 示例,这里让我想到看过的一个视频里说:“这些生成的配置在我的代码里完全是画蛇添足!”哈哈哈哈,现在想到这句话我都觉得很逗。

下面是要添加的关键依赖:

<dependencies>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
</dependencies>

然后配置好配置文件并像 Eureka 一样在启动类或者配置类中添加@EnableDiscoveryClient客户端注解即可。

server:
port: 8080 # 应用服务 WEB 访问端口
spring:
application:
name: nacos-demo # 服务注册名称
cloud:
nacos:
config:
server-addr: localhost:8848 # 服务注册地址
username: nacos
password: nacos

Nacos 登录界面

Nacos服务端集群模式启动#

Nacos 集群

上图是从网络上找到的 Nacos 集群图,其实在官网也有集群部署的说明,但是没有展示出 Nacos 集群和数据交互的部分,但是在安全性方面,官网推荐域名 + SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),可读性好,而且换 ip 方便。不过我们先不讨论网关的部分,因为如果牵扯到网关到底是使用微服务网关(Netflix Zuul、Spring Cloud Gateway)还是 Nginx 还需要根据我们项目 API 管控治理能力的大小来决定。搭建 Nacos 集群我们需要使用先修改一下安装目录中 cong 下的 cluster.conf.exemple 文件,可以直接将该文件的 .exemple 后缀去掉后按照文件中例子添加自己创建的 Nacos 节点的 ip 和 port,至于数据源配置如果使用内置数据源则不需要修改,如果使用外置数据源则全部按照单机启动的部分配置成自己的数据库参数即可。这里如果使用的的单机多端口搭建集群的话注意,使用 nacos2.0 之后需要开放两个8848偏移后的端口

Nacos 集群节点

这个时候启动我们的注册服务会发现每个 Nacos 节点内都可以看到注册服务,Nacos 集群就搭建完成了。

Nacos
https://songbaicheng.cc.cd/posts/nacos/
作者
宋柏成
发布于
2026-06-05
许可协议
CC BY-NC-SA 4.0