前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >微服务:Nacos注册中心

微服务:Nacos注册中心

作者头像
.29.
发布2024-04-25 20:22:07
1030
发布2024-04-25 20:22:07
举报
文章被收录于专栏:个人技术博客个人技术博客
Nacos注册中心
  • 一、服务注册与发现
    • 1.启动Nacos
    • 2.引入依赖
      • ①父工程依赖
      • ②客户端依赖
    • 3.添加配置
    • 二、Nacos服务分级存储模型
    • 1.概念
    • 2.配置集群属性
  • 三、NacosRule负载均衡
    • 1.实现NacosRule
    • 2.根据权重负载均衡
  • 四、环境隔离 - namespace
  • 五、Nacos注册中心原理
    • 1.流程原理分析
    • 2.临时实例和非临时实例
    • 3.总结

一、服务注册与发现

1.启动Nacos

首先,启动Nacos并访问Web端控制台

进入nacos/bin目录下,启动nacos服务: Windows版启动命令:startup.cmd -m standalone Linux版启动命令:sh startup.sh -m standalone Nacos页面的账户与密码均为nacos

在这里插入图片描述
在这里插入图片描述
2.引入依赖
①父工程依赖

父工程中导入阿里巴巴相关依赖,用于对Nacos依赖进行版本控制。

代码语言:javascript
复制
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-alibaba-dependencies</artifactId>
    <version>2.2.5.RELEASE</version>
    <type>pom</type>
    <scope>import</scope>
</dependency>
②客户端依赖
代码语言:javascript
复制
<!-- nacos客户端依赖包 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
3.添加配置

在微服务的application.yml配置文件中添加nacos的服务地址,当微服务启动时,就会完成服务信息的注册,信息列表可在Nacos控制台查看详情。

代码语言:javascript
复制
spring:
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
  • 到这里,就完成了nacos的基本配置,可以让微服务借助Nacos进行服务注册与服务发现。

二、Nacos服务分级存储模型
1.概念
  • 一级是服务
  • 二级是集群
  • 三级是实例

在这里插入图片描述
在这里插入图片描述
  • 服务跨集群调用问题:
    • 服务调用尽可能选择本地集群的服务,跨集群调用延迟较高,当本地集群不可访问时,再去访问其他集群。
2.配置集群属性

修改application.yml配置文件,添加cluster-name配置属性,以配置集群信息,具体内容如下:

代码语言:javascript
复制
spring:
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
      discovery:
        cluster-name: HZ #集群名称,可自定义
  • 配置完成后,可重启微服务,在nacos的Web端控制台页面上查看集群变化。

三、NacosRule负载均衡

1.实现NacosRule

在上述Nacos服务分级存储模型的集群属性配置完成的基础上,在application.xml配置文件中添加以下配置,来指定对应服务负载均衡规则:

代码语言:javascript
复制
userservice: # 要做配置的微服务名称,即配置会作用到的微服务。
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule  # 使用Nacos负载均衡规则
  • NacosRule负载均衡策略
    • ①优先选择本地集群(同一集群)服务实例列表。
    • ②本地集群找不到服务提供者,才去其他集群寻找,并且会报警告。
    • ③确定了可用实例列表后,再采用随机负载均衡挑选实例。
2.根据权重负载均衡

实际部署时会吃出现这样的场景:

  • 服务设备性能有差异,部分实例所在的机器性能较好,另一些较差,我们希望性能好的机器承担更多的用户请求。
  • Nacos中,就提供了权重配置来控制访问频率的功能,权重越大则访问频率越高。

Nacos控制台

  1. 在Nacos控制台可以设置实例的权重值,首先选中实例后面的编辑按钮

在这里插入图片描述
在这里插入图片描述
  1. 自定义权重后,保存设置即可

在这里插入图片描述
在这里插入图片描述
  • 实例的权重控制:
      1. Nacos控制台可以控制实例的权重值,0~1之间。
      2. 同集群内的多个实例,权重越高被访问的频率越高。
      3. 权重设置为0则完全不会被访问。

四、环境隔离 - namespace

Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层的隔离。

Nacos控制台

  1. 新建命名空间

在这里插入图片描述
在这里插入图片描述
  1. 自定义命名空间信息

在这里插入图片描述
在这里插入图片描述
  1. 创建成功

在这里插入图片描述
在这里插入图片描述

可在微服务的application.yml配置文件中指定微服务的Nacos命名空间,下述配置完并重启微服务,微服务的namespace就会改变。

代码语言:javascript
复制
spring:
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
      discovery:
        cluster-name: GD #集群名称
        namespace: ec10a576-86b6-45eb-ba7c-c0647b6ef69a #命名空间ID,这里是dev环境
  • Nacos环境隔离
      1. namespace用来做环境隔离;
      2. 每个namespace都有唯一id;
      3. 不同namespace下的服务不可见(无法跨namespace远程调用);

五、Nacos注册中心原理

1.流程原理分析
  • 服务提供者启动时注册信息。
  • 服务提供者为临时实例:采用心跳监控,向每30秒发送心跳请求向nacos汇报状态。
  • 服务提供者非临时实例:nacos会主动询问其状态。
  • 服务消费者远程调用服务提供者时,会定时从nacos拉取服务列表,更新服务列表缓存。
  • 当nacos注册中心的服务列表更新时,nacos还会主动推送消息给服务消费者,以更新服务列表缓存。

在这里插入图片描述
在这里插入图片描述
2.临时实例和非临时实例
  • 服务注册到Nacos时,可以选择注册为临时实例或非临时实例,通过application.yml中添加配置消息来设置:
代码语言:javascript
复制
spring:
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos服务地址
      discovery:
        ephemeral: false # 是否是临时实例
3.总结
  • Nacos与Eureka的共同点:
      1. 都支持服务注册和服务拉取。
      2. 都支持服务提供者心跳方式做健康检测。
  • Nacos和Eureka区别:
      1. Nacos支持服务端主动检测提供者状态:临时实例采取心跳模式,非临时实例采取主动检测模式。
      2. 临时实例心跳不正常会被剔除,非临时实例则不会被剔除。
      3. Nacos支持服务列表变更的消息推送模式,服务列表更新更及时。
      4. Nacos集群默认采用AP方式(强调数据可用性),当集群中存在非临时实例时,采用CP模式(强调数据可靠性、一致性);Eureka集群采用AP方式。

本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-04-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Nacos注册中心
  • 一、服务注册与发现
    • 1.启动Nacos
      • 2.引入依赖
        • ①父工程依赖
        • ②客户端依赖
      • 3.添加配置
        • 二、Nacos服务分级存储模型
          • 1.概念
            • 2.配置集群属性
            • 三、NacosRule负载均衡
              • 1.实现NacosRule
                • 2.根据权重负载均衡
                • 四、环境隔离 - namespace
                • 五、Nacos注册中心原理
                  • 1.流程原理分析
                    • 2.临时实例和非临时实例
                      • 3.总结
                      相关产品与服务
                      负载均衡
                      负载均衡(Cloud Load Balancer,CLB)提供安全快捷的流量分发服务,访问流量经由 CLB 可以自动分配到云中的多台后端服务器上,扩展系统的服务能力并消除单点故障。负载均衡支持亿级连接和千万级并发,可轻松应对大流量访问,满足业务需求。
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
                      http://www.vxiaotou.com