springboot -- 微服务 - 5.Nacos注册中心

34 篇文章 0 订阅
6 篇文章 0 订阅

五、Nacos注册中心

官网
Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。相比Eureka功能更加丰富,在国内受欢迎程度较高。

5.1、安装

5.1.1、windows安装

1、下载

GitHub主页
GitHub的Release下载页
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2、配置
3、启动

进入bin目录
在这里插入图片描述
然后命令行输入

startup.cmd -m standalone

解释:

-m #启动模式
standalone #单机启动

5.2、服务注册

5.2.1、在父工程中添加管理依赖

<!-- nacos的管理依赖 -->
<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>

5.2.2、添加nacos的客户端依赖

<!-- nacos客户端依赖 -->
<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-alibatlr-nacos-discovery</artifactId>
</dependency>
5.2.3、修改application文件

添加nacos地址

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

5.3、Nacos的服务分级存储模型

在这里插入图片描述

5.3.1、服务跨集群调用问题

服务调用尽可能选择本地集群的服务,跨集群调用延迟较高,本地集群不可访问时,再去访问其它集群。

5.3.2、服务集群属性

修改application.yml,添加如下内容:

spring:
  cloud: 
    nacos:
      server-addr: localhost:8848 # nacos 服务端地址
      discovery:
        cluster-name: HZ  # 配置集群名称(机房位置),如HZ--杭州

在这里插入图片描述

5.4、负载均衡

5.4.1、NacosRule (根据集群的负载均衡)

1、介绍

NacosRule优先访问同集群内的东西,本地集群找不到提供者,才去其它集群寻找,井且会
报警告,确定了可用实例列表后,再采用随机负载均衡挑选。

2、配置

先设置同一集群(看前面),然后在配置文件中修改

userservice: #名称
  ribbon:
    NFLoadBaLancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule #负载均衡规则

然后将userservice的权重设置成1

5.4.1 根据权重负载均衡

1、应用场景

服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,希望性能好的机器承担更多的用户请求。

2、介绍

Nacos提供了权重配置来控制访问频率,权重越大则访问频率越高

3、设置

在Nacos控制台可以设置实例的权重值,首先选中实例后面的编辑按钮。
在这里插入图片描述
将权重设置为0.1,测试可以发现8081被访问到的频率大大降低。
在这里插入图片描述
注意:权重为0的时候,服务器就不会被访问。

5.5、环境隔离(namespace)

Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西, 用来做最外层隔离。
在这里插入图片描述

5.5.1、新建命名空间

在Nacos控制台可以创建namespace,用来隔离不同环境。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
修改配置文件

spring:
  datasource:
    url: jdbc:mysqL://Localhost:3306/heima?useSsL=false
    username: root
    password: 123
    driver-class-name: com.mysql.jdbc.Driver
  cloud:
    nacos: 
      server-addr: localhost :8848
      discovery:
        cluster-name: SH #上海
        namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 #命名空间,填ID

5.6、nacos注册中心细节

5.6.1、细节分析

  • 服务提供者
    1. 服务提供者在注册中心分为临时实例非临时实例
    2. 临时实例在健康检测时(心跳检测)宕机就会直接从注册中心剔除。
    3. 非临时实例健康检测(主动询问)宕机不会剔除,等待恢复健康。
  • 服务消费者
    1. 消费者在第一次拉取列表就会进行缓存。
    2. 缓存每隔30秒更新一次。
    3. 30秒内有服务器宕机,注册中心会主动推送更新列表。
  • 注意
    1. 主动检测会增加服务器压力,推荐使用临时实例。
      在这里插入图片描述

5.6.2、临时实例和非临时实例

服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面的配置来设置:

spring:
  cloud:
    nacos:
      discovery:
        ephemeral: false # 设置为非临时实例

5.7、Nacos与eureka比较

5.7.1、Nacos与eureka的共同点

  • 都支持服务注册和服务拉取。
  • 都支持服务提供者心跳方式做健康检测。

5.7.2、Nacos与Eureka的区别

  • Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测模式。
  • Nacos临时实例心跳不正常会被剔除,非临时实例则不会被剔除。
  • Nacos支持服务列表变更的消息推送模式,服务列表更新更及时。
  • Nacos集群默认采用AP方式,当集群中存在非临时实例时,采用CP模式,Eureka采用AP方式。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值