五、Nacos注册中心
官网
Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。相比Eureka功能更加丰富,在国内受欢迎程度较高。
5.1、安装
5.1.1、windows安装
1、下载
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、细节分析
- 服务提供者
- 服务提供者在注册中心分为临时实例和非临时实例。
- 临时实例在健康检测时(心跳检测)宕机就会直接从注册中心剔除。
- 非临时实例健康检测(主动询问)宕机不会剔除,等待恢复健康。
- 服务消费者
- 消费者在第一次拉取列表就会进行缓存。
- 缓存每隔30秒更新一次。
- 30秒内有服务器宕机,注册中心会主动推送更新列表。
- 注意
- 主动检测会增加服务器压力,推荐使用临时实例。
- 主动检测会增加服务器压力,推荐使用临时实例。
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方式。