【SpringCloud】Nacos健康检查
5.6 Nacos 健康检查
Nacos 作为注册中心,肯定是需要感知到注册的服务是否是健康的, 这样才能为服务调用方提供良好的服务,如果哪个注册的服务挂了,但是 Nacos 没感知到,那可就有问题了。
5.6.1 健康检查机制
Nacos 中提供了两种健康检查机制:
- 客户端主动上报
- 客户端通过心跳的方式告知 Nacos注册中心它的健康状态,默认心跳间隔五秒。
- Nacos 会在超过 15 秒未收到心跳后,将实例设置成不健康状态,超过 30 秒会将改实例删除。
- 反向探测
- Nacos 主动探知客户端的健康状态,默认间隔 20 秒探知一次。
- Naocs 探知发现该实例不健康后,会将改实例标记成为不健康状态,但不会被删除。
但是 Nacos 这两种健康检查机制,咱们是不能自定义的,它由服务实例的类型决定的。
5.6.2 服务实例类型
Nacos 服务在注册的时候,会将注册的服务节点分为两种类型:
临时实例: 如果实例宕机超过一定时间,会从服务列表中删除,默认的类型。
非临时实例: 如果实例宕机了,不会从服务列表中删除,也叫永久实例。
如果注册的服务是临时实例,则 Nacos 采用的是客户端主动上报的机制。
如果注册的服务是永久实例,则 Nacos 采用的是注册中心反向探测的机制。‘

所以其实 Nacos 有了这两种实例类型,咱们看看前面讲的 CAP 理论:
- 一致性(C):所有的节点提供的服务必须都是保持一致的。
- 可用性(A):就算某台节服务没同步,无法提供这个服务,也要允许返回错误信息。
- 分区容错性(P):某台服务器宕机,也能有其他的服务顶上。
C A 两个是互斥,所以只能在 CP 和 AP 中做选择。
在来看临时实例,如果宕机,则从服务列表中删除,这个保持了每个节点的一致性,确保每个节点提供的服务都是一致的,所以 Nacos 中,如果是临时实例,保证的是 CP。
再来看永久实例,如果宕机,也不从服务列表中删除,就算某个节点提供不了服务,也要允许返回错误的信息,所以 Nacos 中,如果是非临时实例(永久实例),保证的是 AP。
所以在 Nacos 中,AP 和 CP 可以混合存在。
如何为 Nacos 配置一个永久实例呢?
直接在 .yml 进行配置就行:
server:port: 9090
spring:application:name: waiter-servicecloud:nacos:discovery:server-addr: 127.0.0.1:8848 # 配置 nacos 地址cluster-name: SH # 配置集群名称ephemeral: false # 设置实例为非临时实例
这个 ephemeral 配置项,默认是 true,也是就临时实例,改成 false 就将这个实例设置成 非临时实例了。
这样一来,就算咱们的 waiter-service 9090 宕机了,Nacos 注册中心 也不会删除它,咱们 cook-service 也能在服务列表中发现他,虽然调用 waiter-service 9090 可能会返回错误信息,但至少也是保证了有节点可以用。
设置成非临时实例咱们就不演示了,配置完后,重新启动项目,去 Nacos 管理面板中查看,在临时实例那一栏,就会显示成 false,然后终止项目,会发现实例还在上面,接着进行测试就够了。
但是这里有个注意点!
Nacos 服务实例类型不允许改变!!!
当服务注册后,Nacos 会记录每个服务实例的IP和端口号,当发现IP和端口号都没有发生变化时,Nacos不允许⼀个服务实例类型发生变化,比如从临时实例变为非临时实例,或者从非临时实例,变成临时实例。
如果发现修改实例类型重新启动项目后报错,可以参考下面两个步骤:
① 停掉 Nacos 服务。
② 删除 Nacos 目录下/data/protocol/raft 目录。
相关文章:
【SpringCloud】Nacos健康检查
5.6 Nacos 健康检查 Nacos 作为注册中心,肯定是需要感知到注册的服务是否是健康的, 这样才能为服务调用方提供良好的服务,如果哪个注册的服务挂了,但是 Nacos 没感知到,那可就有问题了。 5.6.1 健康检查机制 Nacos …...
linux-core分析 : sip变量赋值-指针悬挂
文章目录 core调用栈core分析修改 core调用栈 Thread 1 (Thread 0x5c8c9460 (LWP 3562)): #0 0x4182e8e8 in raise () from /lib/libc.so.6 #1 0x4183271c in abort () from /lib/libc.so.6 #2 0x4186573c in __libc_message () from /lib/libc.so.6 #3 0x4186ff04 in mal…...
随机产生4位随机码(java)
Random类: 用于生成随机数 import java.util.Random; 导入必要的类 generateVerificationCode()方法: 这是一个静态方法,可以直接通过类名调用 返回一个6位数字的字符串,首位不为0 生成首位数字: random.nextInt…...
电源测试系统自动化转型:Chroma 8000 与 NSAT-8000 核心功能对比解析
在全球制造业加速智能化升级的背景下,电源模块测试正从传统手动模式向自动化、智能化深度转型。作为企业降本增效与提升竞争力的关键,如何选择适配的测试系统成为行业焦点。本文聚焦市场主流的 Chroma 8000 与 NSAT-8000 两款系统,从功能设计…...
一个极简的反向传播实现
代码: GitCode - 全球开发者的开源社区,开源代码托管平台 这是2022年,北方交通大学的同志实现的。 包含机器学习的所有过程。前向,反向,损失函数,detect,然后数据集使用了sklearn.datasets的make_moons()…...
【小沐学Web3D】three.js 加载三维模型(React Three Fiber)
文章目录 1、简介1.1 Three.js1.2 React Three Fiber 2、测试2.1 初始化环境2.2 app.js修改(显示内置立方体)2.3 app.js修改(显示内置球体)2.4 app.js修改(显示自定义立方体)2.5 app.js修改(显示…...
sqlalchemy查询json
第一种:字段op是json格式: {"uid": "cxb123456789","role": 2,"op_start_time": 1743513707504,"op_end_time": 1743513707504,"op_start_id": "op_001","op_end_id"…...
物联网外设管理服务平台
1 开发目标 1.1 架构图 操作系统:基于Linux5.10.10源码和STM32MP157开发板,完成tf-a(FSBL)、u-boot(SSBL)、uImage、dtbs的裁剪; 驱动层:为每个外设配置DTS并且单独封装外设驱动模块。其中电压ADC测试,采用linux内核…...
1.ElasticSearch-入门基础操作
一、介绍 The Elastic Stack 包含ElasticSearch、Kibana、Beats、LogStash 这就是所说的ELK 能够安全可靠地获取任何来源、任何格式的数据,然后实时地对数据进行搜索、分析和可视化。Elaticsearch,简称为ES,ES是一个开源的高扩展的分布式全文搜索引擎,是…...
uniapp加载json动画
一、添加canvas画布 <canvas id"lottie_demo" type"2d" style"display: inline-block;width: 148rpx; height: 148rpx;" /> 二、引入依赖和JSON文件 安装依赖 npm install lottie-miniprogram --save import lottie from lottie-mini…...
图论:最小生成树
最小生成树 (无向无环图) 概念 1.Prim算法 P3366 【模板】最小生成树 - 洛谷 邻接矩阵实现 #include<iostream> #include<cstring> using namespace std; const int INF 0x3f3f3f3f; const int N 5e3 10; int dis[N]; //记录每个结点到…...
智能多媒体处理流水线——基于虎跃办公API的自动化解决方案
在内容爆炸的时代,多媒体文件处理(图片压缩、视频转码、音频降噪)已成为内容生产者的日常挑战。本文将演示如何基于虎跃办公的多媒体处理API,构建自动化处理流水线,实现: 批量文件智能分类格式自动转换质量…...
虚拟表、TDgpt、JDBC 异步写入…TDengine 3.3.6.0 版本 8 大升级亮点
近日,TDengine 3.3.6.0 版本正式发布。除了此前已亮相的时序数据分析 AI 智能体 TDgpt,本次更新还带来了多个针对性能与易用性的重要增强:虚拟表全面上线,支持更灵活的一设备一表建模;JDBC 写入机制全新升级࿰…...
virt-manager配置NAT
在 virt-manager 中配置 NAT 模式,可以通过以下步骤完成。NAT(Network Address Translation)模式允许虚拟机通过宿主机的网络连接访问外部网络,同时对外隐藏虚拟机的真实 IP 地址。以下是具体操作步骤: 步骤 1&a…...
rqlite:一个基于SQLite构建的分布式数据库
今天给大家介绍一个基于 SQLite 构建的轻量级分布式关系型数据库:rqlite。 rqlite 基于 Raft 协议,结合了 SQLite 的简洁性以及高可用分布式系统的稳健性,对开发者友好,操作极其简便,其核心设计理念是以最低的复杂度实…...
Dynamics 365 Business Central Recurring Sales Lines 经常购买销售行 来作 订阅
#D365 BC ERP# #Navision# 前面有节文章专门介绍了BC 2024 Wave 2 支持的更好的Substription & Recurring Billing。 其实在D365 BC ERP中一直有一个比较简单的订阅模块Recrring Sales Lines。本文将介绍一下如何用Recurring Sales Lines来 实施简易的订阅Substription。具…...
【WebRTC】开源项目Webrtc-streamer介绍
WebRTC-Streamer 这是一个用于通过简单的信令机制(参见 api)流式传输 WebRTC 媒体源的实验项目,支持以下媒体源: 捕获设备 屏幕捕获 mkv 文件 RMTP/RTSP 源 同时该项目也兼容 WHEP 接口。 注意 * 在线演示已停止,…...
探索生成式AI在游戏开发中的应用——3D角色生成式 AI 实现
概述 自从开创性论文 Denoising Diffusion Probabilistic Models 发布以来,此类图像生成器一直在改进,生成的图像质量在多个指标上都击败了 GAN,并且与真实图像无法区分。 NeRF: Representing Scenes as Neural Radiance Fields for View S…...
androd的XML页面 跳转 Compose Activity 卡顿问题
解决 XML 点击跳转到 Compose Activity 卡顿问题 当从 XML 布局的 Activity 跳转到 Compose Activity 时出现卡顿现象,这通常是由以下几个原因导致的: 可能的原因及解决方案 1. Compose 首次初始化开销 问题:Compose 框架首次初始化需要时…...
神经网络能不能完全拟合y=x² ???
先说结论:关键看激活函数的选择 ReLU神经网络对非线性函数的拟合分析 ReLU神经网络对非线性函数(如 y x 2 y x^2 yx2)的拟合只能是逼近,而无法实现数学意义上的完全重合。这一结论源于ReLU的分段线性本质与目标函数的非线性结…...
Spring MVC 逻辑视图(JSP、Thymeleaf、FreeMarker)与非逻辑视图(JSON、Excel、PDF、XML)详解及示例
Spring MVC 逻辑视图与非逻辑视图详解及示例 一、逻辑视图与非逻辑视图的定义 类型定义逻辑视图通过视图解析器(ViewResolver)将逻辑名称(如 success)映射到具体视图实现。非逻辑视图直接返回具体视图对象(如 JsonVie…...
K8s 老鸟的配置管理避雷手册
Yining, China 引言 对于这种案例,你们的处理思路是怎么样的呢,是否真正的处理过,如果遇到,你们应该怎么处理。 最后有相关的学习群,有兴趣可以加入。 开始 一、血泪教训:环境变量引发的真实灾难 1.1 …...
云原生周刊:深入探索 kube-scheduler-simulator
开源项目推荐 mcp-server-kubernetes mcp-server-kubernetes 是一个实现了模型上下文协议(MCP)的服务器,旨在通过自然语言与 K8s 集群进行交互。它支持连接到 K8s 集群,列出所有 Pod、服务、部署和节点,创建、描述、…...
3-Visual Studio 2022打包NET开发项目为安装包
引言 本文将上一期博文>>>门店管理系统开发<<<开发的项目打包为Windows安装包 一,安装扩展 安装此扩展:installer Projects 二,创建安装程序项目 创建项目 右键解决方案-添加-新建项目 选择setup Project项目 填写项目名…...
国内外网络安全政策动态(2025年3月)
▶︎ 1.《关于进一步加强智能网联汽车产品准入、召回及软件在线升级管理的通知》发布 3月1日,工业和信息化部、市场监管总局联合发布《关于进一步加强智能网联汽车产品准入、召回及软件在线升级管理的通知》(以下简称《通知》)。 该通知旨在…...
Kafka 和 Flink的讲解
一、Kafka:分布式消息队列 1. 核心概念 角色:Kafka 是一个分布式、高吞吐量的消息队列(Pub-Sub 模型),用于实时传输数据流。关键术语: Producer(生产者):发送数据的客户端(如传感器、应用日志)。Consumer(消费者):接收…...
已知Word内容格式固定,通过宏实现Word转Excel
文章目录 需求描述一、宏是什么?二、使用步骤1.启用开发工具2.VBA基础知识3.单个Word文件转为Excel4.批量将Word文件转为Excel文件 总结 需求描述 现在有多个Word文档,Word文档格式固定,假如Word内容分为单选题和多选题,每个题目…...
一文详解OpenGL环境搭建:Ubuntu20.4使用CLion配置OpenGL开发环境
在计算机图形学的广阔领域中,OpenGL作为行业标准的图形库,为开发者提供了强大的工具集来创建从简单的2D图形到复杂的3D世界。然而,对于初学者而言,配置一个合适的开发环境是迈向成功的第一步。本文将详细介绍如何在Ubuntu 20.04.3 LTS操作系统上搭建基于CLion的OpenGL开发环…...
Java面试黄金宝典41
1. IO 种类 定义 在 Java 里,IO(输入 / 输出)主要分为字节流和字符流这两种类型。字节流以字节为单位处理数据,适合处理二进制数据,像图片、音频、视频等;字符流以字符为单位处理数据,适用于处理文本数据。 要点 字节流处理二进制数据,字符流处理文本数据。字节流的基类…...
边缘计算革命:低功耗GPU在自动驾驶实时决策中的应用
边缘计算革命:低功耗GPU在自动驾驶实时决策中的应用 ——分析NVIDIA Jetson与华为昇腾的嵌入式方案差异 一、自动驾驶的实时决策挑战与边缘计算需求 自动驾驶系统需在30ms内完成环境感知、路径规划与车辆控制的全流程闭环。传统云端计算受限于网络延迟…...
