当前位置: 首页 > article >正文

Eureka 高可用集群搭建实战:服务注册与发现的底层原理与避坑指南

引言:为什么 Eureka 依然是存量系统的核心?

       尽管 Nacos 等新注册中心崛起,但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制,是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eureka 集群,揭秘服务注册的核心逻辑。


一、服务注册与发现架构解析

sequenceDiagram服务提供者->>Eureka Server: 1. 发送注册请求(IP+端口+服务名)Eureka Server-->>服务提供者: 2. 返回注册成功服务消费者->>Eureka Server: 3. 拉取服务列表(每30秒)Eureka Server-->>服务消费者: 4. 返回可用实例列表服务消费者->>服务提供者: 5. 发起RPC调用

核心角色职责:

  • Eureka Server:注册中心集群(接收/维护服务状态)
  • Service Provider:服务提供者(注册自身信息,发送心跳)
  • Service Consumer:服务消费者(获取服务列表,负载均衡调用)

二、搭建生产级 Eureka 高可用集群

步骤 1:单节点 Eureka Server 搭建(Spring Boot 2.x)

// Maven 依赖
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>// 启动类注解
@EnableEurekaServer  
@SpringBootApplication  
public class EurekaServerApp { }// application.yml 配置
server:port: 8761
eureka:instance:hostname: eureka1client:registerWithEureka: false # 不向自己注册fetchRegistry: false      # 不从自己拉取列表serviceUrl:defaultZone: http://eureka2:8762/eureka/ # 指向其他节点

步骤 2:双节点互注册实现高可用

# 节点1配置(eureka-server-1.yml)
eureka:instance:hostname: eureka1client:serviceUrl:defaultZone: http://eureka2:8762/eureka/ # 指向节点2# 节点2配置(eureka-server-2.yml)
eureka:instance:hostname: eureka2client:serviceUrl:defaultZone: http://eureka1:8761/eureka/ # 指向节点1

关键配置项说明:

配置项默认值生产建议值作用
eureka.server.enableSelfPreservationtrue根据网络稳定性调整开启/关闭自我保护机制
eureka.instance.leaseRenewalIntervalInSeconds3010~15心跳间隔(直接影响实时性)
eureka.instance.leaseExpirationDurationInSeconds9025~30服务失效阈值

三、服务注册与发现的底层流程

服务提供者注册核心代码:

// 服务提供者配置
eureka:client:serviceUrl:defaultZone: http://eureka1:8761/eureka,http://eureka2:8762/eureka// 启动时自动注册(Spring Cloud 自动完成)

服务消费者发现流程:

  1. 缓存机制:拉取的服务列表在本地缓存(可配置更新周期)
  2. 负载均衡策略:默认轮询,支持自定义(如基于响应时间加权)
@Bean
public IRule ribbonRule() {return new WeightedResponseTimeRule(); // 启用响应时间权重策略
}

四、自我保护机制与心跳配置的工业级调优

1. 自我保护机制(Self-Preservation)

85% 以上服务节点心跳丢失 时触发,Eureka 会保留失效节点(防止因网络抖动导致服务全量下线)

生产环境调优策略

网络稳定环境

:关闭自我保护(避免累积失效节点)

eureka:server:enable-self-preservation: false 

跨机房部署环境

:调高失效阈值比例

eureka:server:renewal-percent-threshold: 0.75  # 75%节点失联才触发

2. 心跳检测参数黄金法则

# 服务提供者配置(必须小于Server的失效阈值)
eureka:instance:lease-renewal-interval-in-seconds: 10    # 每10秒发送心跳lease-expiration-duration-in-seconds: 25 # 25秒内未收到心跳则标记失效# Eureka Server配置(需协调所有客户端)
eureka:server:eviction-interval-timer-in-ms: 30000     # 每30秒清理失效节点

五、常见故障排查清单

  1. 服务列表不同步
    • 检查 defaultZone 地址(集群节点需互指)
    • 确认防火墙开放 8761/8762 端口
  2. 自我保护导致无效节点残留
    • 访问 http://eureka-server:port/status 查看阈值
    • 手动剔除节点:调用 DELETE /eureka/apps/{serviceId}/{instanceId}
  3. 注册延迟超过 30 秒
    • 调整客户端:eureka.client.registryFetchIntervalSeconds=15

结语:Eureka 的不可替代性

在迁移到新注册中心前,请记住:

“稳定运行的系统,永远不要为追新而重构”

对于需要强一致性的场景(如金融交易系统),Eureka 的 AP 设计(高可用)仍是更安全的选择。保留这套技术储备,将是你的架构护城河


新时代农民工

相关文章:

Eureka 高可用集群搭建实战:服务注册与发现的底层原理与避坑指南

引言&#xff1a;为什么 Eureka 依然是存量系统的核心&#xff1f; 尽管 Nacos 等新注册中心崛起&#xff0c;但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制&#xff0c;是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...

PyTorch--池化层(4)

池化层&#xff08;Pooling Layer&#xff09; 用于降低特征图的空间维度&#xff0c;减少计算量和参数数量&#xff0c;同时保留最重要的特征信息。 池化作用&#xff1a;比如1080p视频——720p 池化层的步长默认是卷积核的大小 ceil 允许有出界部分&#xff1b;floor 不允许…...

GPU加速与非加速的深度学习张量计算对比Demo,使用PyTorch展示关键差异

import torch import time # 创建大型随机张量 (10000x10000) tensor_size 10000 x_cpu torch.randn(tensor_size, tensor_size) x_gpu x_cpu.cuda() # 转移到GPU # CPU矩阵乘法 start time.time() result_cpu torch.mm(x_cpu, x_cpu.t()) cpu_time time.time() - sta…...

Vue中的自定义事件

一、前言 在 Vue 的组件化开发中&#xff0c;组件之间的数据通信是构建复杂应用的关键。而其中最常见、最推荐的方式之一就是通过 自定义事件&#xff08;Custom Events&#xff09; 来实现父子组件之间的交互。 本文将带你深入了解&#xff1a; Vue 中事件的基本概念如何在…...

2025年大模型平台落地实践研究报告|附75页PDF文件下载

本报告旨在为各行业企业在建设落地大模型平台的过程中&#xff0c;提供有效的参考和指引&#xff0c;助力大模型更高效更有价值地规模化落地。本报告系统性梳理了大模型平台的发展背景、历程和现状&#xff0c;结合大模型平台的特点提出了具体的落地策略与路径&#xff0c;同时…...

PPTAGENT:让PPT生成更智能

想要掌握如何将大模型的力量发挥到极致吗&#xff1f;叶梓老师带您深入了解 Llama Factory —— 一款革命性的大模型微调工具。 1小时实战课程&#xff0c;您将学习到如何轻松上手并有效利用 Llama Factory 来微调您的模型&#xff0c;以发挥其最大潜力。 CSDN教学平台录播地址…...

Kotlin 中 companion object 扩展函数和普通函数区别

在 Kotlin 中&#xff0c;companion object 的扩展函数与普通函数&#xff08;包括普通成员函数和普通扩展函数&#xff09;有显著区别。以下是它们的核心差异和适用场景&#xff1a; 1. 定义位置与归属 特性companion object 扩展函数普通函数定义位置在类外部为伴生对象添加…...

《汇编语言》第13章 int指令

中断信息可以来自 CPU 的内部和外部&#xff0c;当 CPU 的内部有需要处理的事情发生的时候&#xff0c;将产生需要马上处理的中断信息&#xff0c;引发中断过程。在第12章中&#xff0c;我们讲解了中断过程和两种内中断的处理。 这一章中&#xff0c;我们讲解另一种重要的内中断…...

Redis实战-基于redis和lua脚本实现分布式锁以及Redission源码解析【万字长文】

前言&#xff1a; 在上篇博客中&#xff0c;我们探讨了单机模式下如何通过悲观锁&#xff08;synchronized&#xff09;实现"一人一单"功能。然而&#xff0c;在分布式系统或集群环境下&#xff0c;单纯依赖JVM级别的锁机制会出现线程并发安全问题&#xff0c;因为这…...

Ubuntu崩溃修复方案

当Ubuntu系统崩溃时,可依据崩溃类型(启动失败、运行时崩溃、完全无响应)选择以下修复方案。以下方法综合了官方推荐和社区实践,按操作风险由低到高排序: 一、恢复模式(Recovery Mode) 适用场景​​:系统启动卡顿、登录后黑屏、软件包损坏等。 ​​操作步骤​​: ​…...

计算机网络 : 应用层自定义协议与序列化

计算机网络 &#xff1a; 应用层自定义协议与序列化 目录 计算机网络 &#xff1a; 应用层自定义协议与序列化引言1. 应用层协议1.1 再谈协议1.2 网络版计算器1.3 序列化与反序列化 2. 重新理解全双工3. socket和协议的封装4. 关于流失数据的处理5. Jsoncpp5.1 特性5.2 安装5.3…...

Python Day42 学习(日志Day9复习)

补充&#xff1a;关于“箱线图”的阅读 以下图为例 浙大疏锦行 箱线图的基本组成 箱体&#xff08;Box&#xff09;&#xff1a;中间的矩形&#xff0c;表示数据的中间50%&#xff08;从下四分位数Q1到上四分位数Q3&#xff09;。中位线&#xff08;Median&#xff09;&#…...

CMake在VS中使用远程调试

选中CMakeLists.txt, 右键-添加调试配置-选中"C\C远程windows调试" 之后将 aunch.vs.json文件改为如下所示: CMake在VS中使用远程调试时,Launch.vs.json中远程调试设置 ,远程电脑开启VS专用的RemoteDebugger {"version": "0.2.1","defaul…...

《图解技术体系》How Redis Architecture Evolves?

Redis架构的演进经历了多个关键阶段&#xff0c;从最初的内存数据库发展为支持分布式、多模型和持久化的高性能系统。以下为具体演进路径&#xff1a; 单线程模型与基础数据结构 Redis最初采用单线程架构&#xff0c;利用高效的I/O多路复用&#xff08;如epoll&#xff09;处…...

从零搭建到 App Store 上架:跨平台开发者使用 Appuploader与其他工具的实战经验

对于很多独立开发者或小型团队来说&#xff0c;开发一个 iOS 应用并不难&#xff0c;真正的挑战在于最后一步&#xff1a;将应用成功上架到 App Store。尤其是当你主要在 Windows 或 Linux 系统上开发&#xff0c;缺乏苹果设备和 macOS 环境时&#xff0c;上架流程往往变得繁琐…...

Spring Cloud 2025 正式发布啦

文章目录 一、版本兼容性二、Spring Cloud Gateway 重大更新1、新增功能1.1 Function & Stream 处理器集成1.2 Bucket4j 限流器支持 2、重要弃用2.1. WebClientRouting 基础设施2.2. 模块和启动器重命名 3、破坏性变更3.1 X-Forwarded-* 头部默认禁用3.2 配置受信任代理:3.…...

一文速通Python并行计算:12 Python多进程编程-进程池Pool

一文速通 Python 并行计算&#xff1a;12 Python 多进程编程-进程池 Pool 摘要&#xff1a; 在Python多进程编程中&#xff0c;Pool类用于创建进程池&#xff0c;可并行执行多个任务。通过map、apply等方法&#xff0c;将函数和参数分发到子进程&#xff0c;提高CPU利用率&…...

相机Camera日志分析之二十五:高通相机Camx 基于预览1帧的process_capture_request四级日志分析详解

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:相机Camera日志分析之二十四:高通相机Camx 基于预览1帧的process_capture_request三级日志分析详解 ok 这一篇我们开始讲: 相机Camera日志分析之二十五:高通相机Camx 基于预览1帧的process_capture_…...

React从基础入门到高级实战:React 实战项目 - 项目一:在线待办事项应用

React 实战项目&#xff1a;在线待办事项应用 欢迎来到本 React 开发教程专栏的第 26 篇&#xff01;在之前的 25 篇文章中&#xff0c;我们从 React 的基础概念逐步深入到高级技巧&#xff0c;涵盖了组件、状态、路由和性能优化等核心知识。这一次&#xff0c;我们将通过一个…...

云部署实战:基于AWS EC2/Aliyun ECS与GitHub Actions的CI/CD全流程指南

在当今快速迭代的软件开发环境中&#xff0c;云部署与持续集成/持续交付(CI/CD)已成为现代开发团队的标配。本文将详细介绍如何利用AWS EC2或阿里云ECS结合GitHub Actions构建高效的CI/CD流水线&#xff0c;从零开始实现自动化部署的全过程。 最近挖到一个宝藏级人工智能学习网…...

golang 如何定义一种能够与自身类型值进行比较的Interface

定义一种具有比较能力的类型是一种常见需求&#xff0c;比如对一组相同类型的值进行排序&#xff0c;就需要进行两两比较&#xff0c;那么在Go语言中有没有办法定义一种具有比较能力的Interface&#xff0c;实现该接口的类型都具备比较能力呢&#xff0c;最常见最容易的办法是定…...

Web前端之原生表格动态复杂合并行、Vue

MENU 效果公共数据纯原生StyleJavaScript vue原生table 效果 原生的JavaScript原生table null 公共数据 const list [{id: "a1",title: "第一列",list: [{id: "a11",parentId: "a1",title: "第二列",list: [{ id: "…...

『uniapp』把接口的内容下载为txt本地保存 / 读取本地保存的txt文件内容(详细图文注释)

目录 预览效果思路分析downloadTxt 方法readTxt 方法 完整代码总结 欢迎关注 『uniapp』 专栏&#xff0c;持续更新中 欢迎关注 『uniapp』 专栏&#xff0c;持续更新中 预览效果 思路分析 downloadTxt 方法 该方法主要完成两个任务&#xff1a; 下载 txt 文件&#xff1a;通…...

C/C++ 面试复习笔记(2)

C语言如何实现快速排序算法&#xff1f; 答案&#xff1a;快排是一种分治算法&#xff0c;选择一个基准元素&#xff0c;将数据划分成两部分&#xff0c;然后递归排序 补充&#xff1a; void quick_sort(int arr[], int start, int end) {//判断是否需要排序if (start > …...

宝马集团推进数字化转型:强化生产物流与财务流程,全面引入SAP现代架构

2025年6月&#xff0c;宝马集团宣布在生产物流与财务流程领域取得重大数字化成果。这些进展标志着集团全球范围内采用基于云的新型SAP架构进入关键阶段&#xff0c;旨在提升运营效率、透明度和AI能力&#xff0c;为未来工业发展奠定技术基础。 一、生产物流全球数字化部署 宝…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 时间事件处理部分)

揭秘高效存储模型与数据结构底层实现 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 时间事件&#xff1a;serverCron函数更新服务器时间缓存更新LRU时钟-lruclock更新服务器每秒执行命令次…...

【DAY40】训练和测试的规范写法

内容来自浙大疏锦行python打卡训练营 浙大疏锦行 知识点&#xff1a; 彩色和灰度图片测试和训练的规范写法&#xff1a;封装在函数中展平操作&#xff1a;除第一个维度batchsize外全部展平dropout操作&#xff1a;训练阶段随机丢弃神经元&#xff0c;测试阶段eval模式关闭drop…...

C语言 标准I/O函数全面指南

C标准I/O函数全面指南 本指南详细介绍了C语言中用于文件操作的标准输入/输出函数&#xff0c;包括单字符I/O、字符串I/O、格式化I/O、块I/O以及文件光标操作。每个部分包含函数定义、使用说明和实用示例&#xff0c;适合学习、复习以及博客发布。内容采用清晰的Markdown格式&a…...

el-select 实现分页加载,切换也数滚回到顶部,自定义高度

el-select 实现分页加载&#xff0c;切换也数滚回到顶部&#xff0c;自定义高度 1.html <el-form-item label"俱乐部&#xff1a;" prop"club_id" label-width"120px"><el-select :disabled"Boolean(match_id)" style"w…...

Langchaine4j 流式输出 (6)

Langchaine4j 流式输出 大模型的流式输出是指大模型在生成文本或其他类型的数据时&#xff0c;不是等到整个生成过程完成后再一次性 返回所有内容&#xff0c;而是生成一部分就立即发送一部分给用户或下游系统&#xff0c;以逐步、逐块的方式返回结果。 这样&#xff0c;用户…...