Nacos注册中心

简介: 本文介绍Nacos的安装部署、服务注册中心整合、分级模型、负载均衡策略、权重控制、环境隔离及实例类型,详解其在微服务架构中的应用,帮助开发者掌握Nacos核心功能与最佳实践。

1.Nacos安装部署

1.1 下载安装

nacos官网提供了安装部署教程,其下载链接指向github官网,选择合适版本即可。如访问受阻可直接使用以下最新稳定版压缩包:📎nacos-server-2.1.0.zip,后续我们也可能会更改为其他版本做更多测试。

公司一般会采用最新版落后几个版本的稳定版当做生产版本,避免一些新特性引发的未知问题。

1.2 启动

  • window请直接进入路径:cd nacos/bin后双击startup.sh启动,或按照下述指令启动
cd nacos/bin 
startup.cmd -m standalone
  • linux或mac进入路径:nacos/bin/,cmd控制台执行
cd nacos/bin 
sh startup.sh -m standalone

注意:如存在端口冲突,可至路径:nacos/conf/application.properties 中修改后启动

注意nacos存储路径不可有中文。如遇启动异常,

  • mac可至路径:nacos/logs/start.out 查看具体错误信息
  • windows可至路径:nacos/logs/nacos.log 查看具体错误信息,正常启动日志如下

1.3 访问

成功启动后访问如下地址:http://localhost:8848/nacos/#/login,默认用户名/密码:nacos/nacos

2.整合Nacos注册中心

2.1 依赖导入

父工程新增spring-cloud-alibaba依赖

<!--nacos依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.2.6.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>

因为Spring-cloud-alibaba自身也是集成了多个组件,所以这里只需引入alibaba大管家即可

子工程去除eureka依赖

注意order-service、user-service均需删除

子工程新增spring-cloud-alibaba-nacos依赖

注意:不同于父工程,是nacos-discovery,order-service、user-service均需添加

<!--nacos依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

至此,三个工程pom如下(eureka相关工程无需操作):

2.2 配置文件修改注册中心

子工程均去除eureka注册配置,均新增nacos配置

spring:
  cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址

至此,两个业务工程application.yml如下(eureka相关工程无需操作):

2.3 启动工程并验证

启动应用后访问Nacos会发现服务已完成注册

如启动遇到工程仍存在Eureka依赖,可尝试重新编译整个工程,或手动删除target文件夹后再启动

3.Nacos服务分级模型

不同于Zookeeper没有针对服务发现设计数据模型,它的数据是以一种更抽象的树形K-V组织的,因此理论上可以存储任何语义的数据。而Eureka或Consule都做到了实例级别的数据扩展,这能满足大多数场景但无法满足大规模和多环境的服务数据存储。Nacos经过多年经验后提炼出上述模型,其特点在于:服务-集群-实例三层模型,可以满足所有场景下的数据存数和管理。

通过设置不同的集群所在参数,可以保证相同集群间优先调用,减少网络开销。当本地集群服务无法拉取时,再去跨集群调用。对于此工程我们只需要设置提付提供者集群参数:

cloud:
  nacos:
    server-addr: localhost:8848   # nacos服务地址
    discovery:
      cluster-name: HZ # 声明集群名称杭州

此时访问Nacos会发现其增加了集群属性发生变化,原为:Default

为模拟多集群场景,此时我们复制一个新的userApplicatio3启动类,具体操作步骤如下:

  • 复制一个新的userApplicatio3启动类,设置其启动端口:-Dserver.port=8083
  • 更改配置文件集群属性为GZ(注意不要停userApplication、userApplication2,否则原注册信息会失效)
  • 启动userApplication3并访问nacos

此时查看Nacos服务信息会发现,已经有了两个集群信息。

此时我们就完成Nacos分级模型的验证,在实际的工作、生产环境中,一般来说服务都是同集群部署,不需要开发人员声明式感知服务所在集群信息。

4.NacosRule负载均衡策略

修改oder-service集群属性、负载均衡策略,调整为如下:

注意:此时需要将OrderApplication中的代码声明式负载均衡策略注释或删除(约定大于配置),否则失效

cloud:
    nacos:
      server-addr: localhost:8848 #nacos服务地址
      discovery:
        cluster-name: HZ # 声明集群名称杭州
userservice: # 给某个微服务配置负载均衡规则,这里是userservice服务
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则

此时重启应用后会发现orderservice集群属性存在变化:

访问oder-service服务会发现其优先匹配HZ集群的userApplication、userApplication2。

上面我们提到优先调用本集群的服务,当本集群服务实例不存在时会考虑跨集群调用,故我们停掉userApplication、userApplication2,再做一次访问会发现访问正常,同时请求日志打到userApplication3。

5.Nacos权重控制

基于上一章节的负载均衡算法,我们可以了解到:存在部分机器性能更优,此时该机器理应得到更多的流量分配,nacos通过设置服务权重解决这一问题,权重越大访问评率越高,配置页面如下:

编辑后再次访问服务,会发现流量产生明细变化。如权重设置为0对于服务调用方等同于服务下线。

6.Nacos环境隔离

日常开发过程中,我们一般会有dev、test、poc、prod等多个环境,同一个服务不同环境之间因存在代码不一致问题肯定需要做隔离调度,Nacos通过namespace解决此问题,配置页面如下,我们新增一个dev:

增加完成后列表发生变化如下:

我们尝试在order-service中增加namespace,并重启服务再次访问,注意:namespace后字符串为上图ID

cloud:
  nacos:
    server-addr: localhost:8848 #nacos服务地址
    discovery:
      cluster-name: HZ # 声明集群名称杭州
      namespace: 06e5f1a5-9ecb-438a-aae0-b434073bb973 # 命名空间

此时会因不在同一命名空间导致无法访问(因userservice暴露服务时未声明namespace,默认public)

我们修改user-service的配置文件,增加namespace,并重启服务再次访问会发现服务恢复正常

7.Nacos临时实例与持久化实例

Nacos在定义上区分临时实例和持久化实例,其主要区分关键是健康检查的方式。

  • 临时实例:客户端上报模型,能够自动摘除不健康实例,无需持久化实例存储
  • 持久实例:服务端反省探测模式,客户端因不上报心跳故不会自动摘除下线实例

在大中型公司,两种类型一般都会使用,基础的组件如数据库、缓存等往往不能上报心跳,这种类型的服务在注册时就需要作为持计划实例注册。而上层的业务服务,如微服务或Dubbo服务,服务的Provider端支持添加心跳,此时就可以使用临时实例的注册方式。

其配置文件配置如下:

cloud:
  nacos:
    server-addr: localhost:8848   # nacos服务地址
    discovery:
      cluster-name: HZ # 声明集群名称杭州
      namespace: 06e5f1a5-9ecb-438a-aae0-b434073bb973 # 命名空间
      ephemeral: false # 设置为非临时实例

8.Nacos更多总结分析

📎Nacos.mm,如无法访问可链接至:https://kdocs.cn/l/ccGuOOfpPjFv,图片展示如下:

9.总结

本节从Nacos安装、运行到具体规则配置,带领读者们深度参与了Nacos日常使用场景,Nacos作为注册中心可以优雅替换Eureka也离不开SpringCloud Alibaba的开源贡献。作为国内主流的配置、注册中心,Nacos在国内多数微服务公司都有使用,感兴趣的可以阅读一下本节推荐资料,笔者整理归纳在本文第8章节。

Nacos除了能够实现服务注册发现(AP),此外还有个重要特性:配置管理(CP),我们将在下一章节展开学习。


思考问题

  • Nacos是什么?解决了什么问题?
  • Nacos是如何优雅替换Eureka的?
  • Nacos实现的是客户端,还是服务端负载均衡?
  • Nacos如何实现注册中心?

10.推荐阅读资料

相关文章
|
1天前
|
缓存 运维 监控
一场FullGC故障排查
本文记录了一次Java应用CPU使用率异常升高的排查过程。通过分析发现,问题根源为频繁Full GC导致CPU飙升,而Full GC是因用户上传的Excel数据被加载为大对象并长期驻留JVM内存所致。使用JProfiler分析堆内存,定位到List&lt;Map&lt;String, String&gt;&gt;结构造成内存膨胀,空间效率仅约13.4%。最终提出“治本”与“治标”两类解决方案:一是将大数据移出JVM内存,存入Redis;二是优化代码,及时清理无用字段以减小对象体积。文章总结了从监控识别、工具分析到根本解决的完整排查思路,对类似性能问题具有参考价值。(238字)
|
2天前
|
安全 JavaScript
JeecgBoot介绍
JeecgBoot是一款基于代码生成器的低代码开发平台,支持零代码快速开发。采用SpringBoot2.x、Ant Design&Vue、Mybatis-plus等主流技术,前后端分离架构,集成Shiro、JWT安全控制,助力高效构建企业级应用。
JeecgBoot介绍
|
1天前
|
负载均衡 算法 架构师
Ribbon负载均衡
本文深入讲解Spring Cloud中Ribbon实现客户端负载均衡的原理,包括@LoadBalanced注解的作用、负载均衡策略分类与算法,以及如何自定义配置和优化首次调用延迟的饥饿加载机制,帮助读者全面理解微服务间的流量分发技术。
Ribbon负载均衡
|
1天前
|
关系型数据库 MySQL Nacos
今日练习
本课程聚焦微服务实战,涵盖MySQL、MyBatis-Plus集成,RestTemplate跨服务调用及Nacos注册中心部署。通过重构与优化,提升学生对微服务架构的理解与编码能力。
 今日练习
|
1天前
|
SQL 容灾 Nacos
Seata的部署和集成
本文介绍Seata TC服务器的部署与微服务集成,包括下载、配置、数据库表初始化及高可用集群搭建,实现基于Nacos的分布式事务管理与异地容灾支持。
|
1天前
|
自然语言处理 数据可视化 Docker
安装ES、Kibana、IK
本文介绍如何通过Docker部署单节点Elasticsearch与Kibana,并安装IK分词器。内容涵盖创建网络、加载镜像、运行容器、配置扩展词典与停用词典,以及常见启动报错处理,帮助快速搭建ES开发环境。
安装ES、Kibana、IK
|
1天前
|
JSON 自然语言处理 算法
DSL语法、搜索结果处理
本文介绍了Elasticsearch的DSL查询语法及RestClient实现方式,涵盖全文检索、精确查询、地理坐标查询和复合查询,并结合黑马旅游案例实现了搜索、分页、过滤与高亮功能。
 DSL语法、搜索结果处理
|
1天前
|
自然语言处理 关系型数据库 MySQL
数据聚合、自动补全、数据同步
本文介绍了Elasticsearch中的核心功能:数据聚合、自动补全与数据同步。聚合支持对数据分组(Bucket)、统计计算(Metric)及管道聚合,可高效实现品牌、价格等分析;通过拼音分词器与Completion Suggester实现搜索自动补全;并利用MQ异步通知机制实现MySQL与ES之间的数据同步,确保数据一致性,提升搜索实时性与准确性。(238字)
数据聚合、自动补全、数据同步
|
1天前
|
存储 监控 Docker
ElasticSearch集群
Elasticsearch集群通过分片和副本解决海量数据存储与单点故障问题。分片实现数据水平拆分,副本保障高可用,结合节点角色划分与故障转移机制,提升系统稳定性与性能。
 ElasticSearch集群
|
1天前
|
Kubernetes Java 应用服务中间件
1.开发篇(脚手架下载)
本文介绍基于SpringCloud + Kubernetes的微服务开发实践,重点分享EDAS 3.0在项目初始化与本地启动环节的优化体验。通过阿里云start.aliyun.com脚手架快速生成项目,结合Cloud Toolkit插件一键拉起本地注册中心,实现应用快速部署与联调,提升开发者效率。后续将深入讲解云端部署及端云互联能力。