Nacos注册中心

什么是Nacos

Nacos是Spring Cloud Alibaba提供的一个软件

这个软件具有微服务注册中心的功能

也就是当前微服务架构中的所有微服务项目都需要到Nacos注册才能成为这个微服务项目的一部分

Nacos是一个能够接收所有微服务项目信息的组件

只有将信息"注册"到Nacos,这个项目才会成为微服务架构中的一个组成部分

下面我们就来学习如何安装和启动Nacos

前提

需要当前计算机安装并配置java环境变量

因为Nacos是java开发的,所以要运行必须配置java环境变量

Nacos 下载路径

https://github.com/alibaba/nacos/releases/download/1.4.3/nacos-server-1.4.3.zip

安装启动Nacos

我们下载了Nacos软件

将压缩包解压(注意不要有中文路径或空格)

打开解压得到的文件夹后打卡bin目录会有如下内容

 

startup.cmd是windows系统启动Nacos的命令

shutdown.cmd是windows系统停止Nacos的命令

.sh结尾的文件是linux和mac系统的启动和停止文件

启动Nacos不能直接双击startup.cmd

而需要打开dos窗口来执行

Win+R输入cmd

 

 

启动命令中 standalone是表示本次启动以单机模式运行

如果不指定会默认以集群模式运行,无法完成功能

startup.cmd -m standalone

如果运行成功会显示8848端口

打开浏览器输入地址

http://localhost:8848/nacos

如果首次访问没有响应,可以尝试从新解压和运行,再访问

登录系统

用户名密码都是nacos

进入后会看到列表后台

注意不要关闭doc窗口,一旦关闭,nacos就停止了

将项目注册到Nacos的配置

要注册到Nacos的项目添加如下配置即可

添加pom.xml文件依赖

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

application-dev.yml文件添加配置

spring:
  application:
    name: nacos-business # 定义当前服务名称
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # 指定正在运行的Nacos服务器的位置

上面配置中nacos-business是当前服务名称,每个不同功能模块名称要不同

nacosip地址和端口号根据实际情况编写

我们启动business,在nacos的服务列表中观察

出现信息表示一切正常

可以复制项目然后修改端口号,启动同名服务的项目,这样服务列表中就会出现多个实例

实际开发中,一般情况都会有多个实例去分担同一个服务

使用Idea启动Nacos

每次开机都需要启动Nacos

启动Nacos使用dos窗口太麻烦了

我们可以使用Idea简化这个过程

 

 

 

点击ok确定之后

项目的启动项中就会出现Nacos的启动项了

Nacos心跳机制

常见面试题

Nacos系统内置周期性的检查和报告工作,称之为"心跳"

客户端或服务器会周期的检查状态,运行固定代码,保证能够检测模块的运行

Nacos实例的心跳又分类两种

  • 临时实例心跳

  • 永久实例心跳

在后面的配置中,如果采用默认配置,当前实例就是永久实例

spring:
  application:
    name: xxxx
  cloud:
    nacos:
      discovery:
        ephemeral: false # 默认false实例为永久实例。true:临时; false:永久
        server-addr: localhost:8848

临时实例基于心跳方式做健康检测

永久实例是Nacos主动探测健康状态

临时实例

客户端(各个模块)每隔5秒自动向Nacos发送心跳包

包中包含微服务名称,ip地址,port(端口号),集群名称等信息

Nacos接收到信息后,判断当前Nacos中是否包含这个包中的信息

  • 如果不包含,证明这是一个新的实例,进行注册操作

  • 如果存在,记录本次心跳时间,设置为健康状态

整体流程有个别名:"心跳续约"

永久实例

永久实例是Nacos周期性向客户端进行检测

Nacos每隔15秒向客户端发送一个检测请求,如果第一个15秒客户端没有给出响应,就会被标记为"非健康状态"

如果两个连续的15秒(一共30秒)都没有响应,就会从注册列表中剔除这个服务

整体流程有个别名:"心跳检测"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值