改了 Nacos 一行配置,搞崩线上支付系统!

news/2025/10/11 10:56:23/文章来源:https://www.cnblogs.com/chengxy-nds/p/19134558

节前上线出问题,线上灰度发布后部分用户反馈付款后订单状态不更新,支付服务的失败率飙升。一顿排查后发现致命配置错误。小可爱上线时,将payment-service服务的 Nacos 注册类型改成了ephemeral=false(持久化实例)。

当时其中一台服务节点因内存泄漏频繁 GC,心跳线程被阻塞超过 30 秒,但是由于持久化实例没被 Nacos 剔除,导致调用方持续往这台异常节点发请求,最终拖垮整个支付链路。

这个面试场景题总问,不过很多同学对 Nacos 临时、持久实例的认知,只停留在服务会不会消失的表面,什么时候该用临时,什么时候该用持久,适用场景是什么,没太明白。

注册中心和配置中心本质区别

我们用 Nacos 主要使用到它的服务注册中心和配置中心,它们的设计初衷不同,服务注册中心要求符合 CAP 中的高可用(AP)服务发现不能中断,允许短暂数据不一致;注册中心要求是一致性(CP),配置不能错、不能丢,更新需同步到所有节点。

简单说,注册中心的实例是活的服务节点,配置中心的实例是死的配置文件

它们之间的实例的概念也不太一样:

对比维度 服务注册中心的实例 配置中心的实例
本质 运行中的服务节点(如user-service的某台服务器) 静态配置数据单元(如redis-dev.yml配置文件)
核心作用 提供服务发现,让调用方找到可用节点 集中管理配置,支持动态更新
创建方式 客户端自动注册(如 Spring Cloud 服务启动时) 手动创建(控制台 / API)或代码推送
生命周期依赖 依赖服务节点的运行状态(节点宕机则实例失效) 依赖手动维护(不删就一直存在)

注册中心:默认临时实例

要知道服务注册中心的核心需求是实时感知服务可用性

它设计了临时实例持久化实例两种模式,分别对应动态服务和静态服务场景。

临时实例

临时实例是 Nacos 服务注册的默认模式

Spring Cloud、Dubbo 等业务服务启动时,若不额外配置,都会以临时实例注册。核心逻辑是心跳保活,来检测服务的可用性。

  • 心跳机制:客户端每 5 秒向 Nacos 服务端发送一次心跳;服务端 15 秒没收到心跳,就把实例标记为不健康;30 秒没收到,直接从注册表中剔除实例;

  • 存储方式:实例信息只存在服务端内存中,不写磁盘。Nacos 重启后,所有临时实例都会消失,需客户端重新注册;

  • 故障表现:服务节点宕机、网络中断,或像我们支付服务那样因 GC 阻塞心跳,实例会被自动摘除,调用方不会再路由到无效节点。

持久化实例

持久化实例则完全相反,它针对长期稳定运行、很少变化的基础服务(如 MySQL、Redis、Elasticsearch)设计,核心逻辑是服务端主动探活 + 数据持久化,不适合支付、订单这类动态业务服务。

  • 保活机制:不需要客户端发心跳,而是 Nacos 服务端主动探活。支持 TCP 端口探测(如 MySQL 的 3306 端口)、HTTP 接口探测(如 Redis 的 /health 接口)、自定义协议探测;

  • 存储方式:实例信息会持久化到 Nacos 的数据库(默认 Derby,生产用 MySQL),即使 Nacos 重启,实例信息也不会丢失;

  • 故障表现:实例宕机后,Nacos 只会把它标记为不健康,不会删除。运维能在控制台实时看到故障节点,方便排查,恢复后实例自动变回健康。

在 SpringCloud 项目中,只需在application.yml中添加一行配置,就能切换实例类型,就是这行配置,被新人改错导致了故障:

spring:cloud:nacos:discovery:server-addr: 192.168.1.100:8848ephemeral: false # 新人误改为此值,正确应为true(默认)service: payment-service # 注册的服务名

配置中心:默认持久化

Nacos 配置中心的所有配置实例(即配置文件)默认都是持久化的,根本不存在临时配置的概念,所谓的动态更新也和临时无关。

Nacos 配置中心的设计初衷是集中管理配置,避免配置丢失,因此所有配置都满足以下特性:

  • 存储层面:无论在控制台创建、还是用 API 推送的配置,都会持久化到数据库(如 MySQL),即使 Nacos 服务端重启、甚至服务器宕机,配置也不会丢失;

  • 生命周期:配置只会被手动删除或覆盖更新,不会因为客户端断开连接、或服务重启而自动消失;

  • 动态更新:客户端通过长轮询机制监听配置变化(默认每 30 秒轮询一次,可调整),配置更新后 1 秒内推送到客户端。但动态更新是 内容实时变化,不是配置临时存在。

写在最后

说了一大堆其实总结起来就两句话:

  • 服务注册中心:动态业务服务(支付、订单)用临时实例(默认),静态基础组件(MySQL、Redis)用持久化实例;

  • 配置中心:没有临时配置,所有配置默认持久化,动态更新 ≠ 临时存在。

读到这就等于学会!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/934652.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Gitee Insight领跑DevSecOps赛道:2025研发效能工具全景评测

Gitee Insight领跑DevSecOps赛道:2025研发效能工具全景评测 在数字化转型浪潮席卷全球的当下,研发效能工具已成为企业技术团队不可或缺的核心基础设施。随着DevSecOps理念的深入普及,企业对研发效能工具的需求正从单…

最小二乘法的直线拟合

由于网上没有找到直接的代码,就来写一下。 原理部分可以回去看高数,核心就是以直线的斜率和截距为变量,让误差最小化。以下是代码部分 import numpy as np import matplotlib.pyplot as pltdef linear_least_square…

Vue3 集成 VueRouter

Vue Router 是 Vue.js 的官方路由管理器,用于构建单页面应用程序(SPA)。它与 Vue.js 核心深度集成,使得构建单页应用变得简单高效。Vue Router 是 Vue.js 的官方路由管理器,用于构建单页面应用程序(SPA)。它与 …

2025 年车床生产厂家最新推荐排行榜:涵盖数控 / 卧式 / 斜床身 / 重型等多类型设备,助力企业精准选购优质车床品牌

随着制造业转型升级加速,汽车摩托车、工程机械、军工等关键行业对车床设备的精度、效率及个性化定制需求日益严苛,市场对高品质车床的采购需求持续攀升。然而,当前车床行业品牌众多,部分厂家存在技术研发薄弱、产品…

2025 最新球墨铸铁管件厂商推荐排行榜权威发布,市政 / 给排水 / 消防用管件优选品牌深度解析

在市政水利、建筑给排水、消防工程等核心领域,球墨铸铁管件的质量直接决定管网系统的安全与寿命。当前市场中,部分企业因工艺落后、检测缺失导致产品抗腐性差、寿命缩水,不仅推高工程维护成本,更埋下安全隐患。同时…

2025 年加工中心厂商最新推荐排行榜权威发布,涵盖立式 / 卧式 / 龙门 / 四轴 / 五轴等机型,助力采购方精准筛选实力厂商

当前加工中心市场竞争激烈,制造商数量繁杂且产品质量、技术水平差异显著,采购方在选择时常常陷入困境。汽车摩托车、工程机械、军工等行业对加工设备的个性化、高精度、高可靠性需求日益提升,但部分厂商存在技术研发…

CH585在MACOS系统中协商BLE连接间隔至7.5ms

首先,部分MAC OS其实是支持分配连接间隔到7.5ms的,并不是所有都支持,不支持的基本都是最低15ms; 例程改写: 1、广播包设备类型修改,必须为鼠标类型 2、BLE初始化中加入声明,// 强制连接参数更新的允许范围,如…

2025 年磨床厂家最新推荐排行榜:平面磨床 / 外圆磨床 / 数控磨床等优质设备品牌深度解析与核心竞争力测评

当前磨床市场呈现出产品种类繁杂、质量差距悬殊的态势,众多企业在选购磨床时屡屡陷入困境。一方面,部分厂家缺乏规范的生产标准与质量管控机制,产出的磨床在精度稳定性、耐用性上难以达标,无法满足汽车制造、军工生…

基于MATLAB的粒子群算法(PSO)优化libsvm参数完整实现

一、优化原理与流程 1. 优化目标参数空间:SVM关键参数为惩罚系数C和RBF核参数gamma 目标函数:最大化交叉验证准确率(分类)或最小化均方误差(回归)2. PSO算法流程 graph TD A[初始化粒子群] --> B{适应度评估}…

FastCopy复制软件绿色版下载!一款快速复制软件!方便实用

软件介绍 小伙伴要拷贝数据,说要把整个硬盘的数据拷贝到另外的一个硬盘,数据有120G左右。用直接系统复制粘贴的方法进行拷贝,那120G的硬盘,要拷到猴年马月了,所以我推荐给他使用今天的这款软件。 这款软件叫FastC…

python实现提取iso中的文件(支持多平台)

#! /bin/python3 import os import shutil from glob import glob from tempfile import TemporaryDirectory import subprocess as spdef cp_with_level(list_src, folder_target, folder_src_parent):""&q…

2025 年最新推荐球墨铸铁管厂家排行榜:涵盖自来水 / 污水 / 消防等多场景适用优质品牌权威推荐

在市政水利、供水排污、消防输水等工程领域,球墨铸铁管的质量直接决定项目稳定性与使用寿命。当前市场上,部分产品存在强度不足、防腐性能差等问题,导致后期维护成本激增,还可能威胁用水安全与工程安全。同时,品牌…

CopyOnWriteArrayList 的故事--一起看看java原生的读写分离

CopyOnWriteArrayList 是JUC中提供的,为了实现高并发的而提供的list容器之一。对于大部分的业务场景,都是读多写少,并发度也基本卡在了读的位置。通常支持并发的容器在解决并发时,采用是:(1)数据分割,每个线程…

OSI模型-笔记

OSI模型 网络工程师必背 OSI(Open System Interconnection Reference Model) 基本概念 用范围形容网络局域网:LAN 广域网:WAN以太网:一个网络的封装协议,不是一种类型或范围 局域网当中使用的是以太网协议(IEEE…

痞子衡嵌入式:如果i.MXRT1xxx在Hab关闭时出现偶发性启动失败,请先检查JTAG电路

大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是i.MXRT1xxx在Hab关闭时出现偶发性启动失败原因分析。最近有一个 RT1064 客户(无人机产品)遇到了一个奇怪的启动失败问题,客户应用程序设计里需要…

如何使用notepad++查看二进制bin文件

如何使用notepad++查看二进制bin文件 菜单栏——插件——插件管理——找到HEX-Editor——安装,等待重启——用notepad++打开二进制bin文件(显示乱码)——插件——HEX-Editor——View in HEX——成功另外,下图红色圈内…

2025 电缆绝缘材料生产厂家最新推荐榜单:品牌技术实力解析,爱普等企业领跑行业

随着电力、风电、轨道交通等领域的高速发展,电缆绝缘材料作为保障系统安全的核心部件,其性能与质量直接决定设备运行稳定性。当前市场品牌繁杂,部分产品在耐温性、绝缘强度等关键指标上不达标,且风电、矿用等特殊场…

SAP BP主数据维护BAPI CVI_EI_INBOUND_MAIN(转)

SAP BP主数据维护BAPI CVI_EI_INBOUND_MAIN_sap bp bapi-CSDN博客近期有创建BP供应商主数据的需求,想起上次写这个批导还是2018年,当时的我面对这个BAPI还是抗拒的,因为算是相对来说比较复杂的一类BAPI了,当时网上…

2025 年最新外呼系统机构最新推荐排行榜:深度解析技术实力、服务体系及行业适配方案电话营销外呼系统/智能外呼系统/外呼系统电销卡/外呼系统平台搭建推荐

在数字化转型全面深化的 2025 年,外呼系统已成为企业打通客户沟通链路、提升业务拓展效率的核心工具。然而当前市场中,外呼系统厂商资质良莠不齐,部分厂商缺乏合规资质、技术架构落后导致通话中断率高,或售后服务响…

运放速度揭秘:带宽与压摆率的关键对决

运放速度揭秘:带宽与压摆率的关键对决本文探讨了放大器带宽与速度的概念区别,分析了小信号和大信号带宽的特性及其影响因素。小信号带宽由RC时间常数决定,反映电路的线性响应;大信号带宽则受限于压摆率,影响输出波…