【Spring Cloud】Eureka详细介绍及底层原理解析
目录
底层原理详解
1. 服务注册与发现
2. 心跳机制
3. 服务剔除与自我保护机制
Eureka Server 核心组件
Eureka Client 核心组件
使用场景
结语
Eureka 是 Netflix 开源的一款服务发现框架,用于构建分布式系统中的服务注册与发现。
它包含两个核心组件:Eureka Server 和 Eureka Client。Eureka Server 用于服务注册中心,维护服务实例的注册信息;Eureka Client 用于服务注册,在服务启动时将自己注册到 Eureka Server。
底层原理详解
1. 服务注册与发现
- 服务注册:服务启动时,Eureka Client 将自身信息(如服务名、IP 地址、端口号)注册到 Eureka Server。
- 服务发现:其他服务消费者通过 Eureka Client 从 Eureka Server 获取可用服务列表,从而发现可用的服务。
2. 心跳机制
- 注册的服务实例会定期向 Eureka Server 发送心跳请求,以维持注册信息的实时性和可用性。
3. 服务剔除与自我保护机制
- Eureka Server 会监控服务实例的健康状态,如果一个服务实例长时间没有发送心跳,Eureka Server 将剔除该实例。
- Eureka Server 还具有自我保护机制,当服务实例注册量骤减时,自动进入自我保护模式,不剔除任何健康实例,以防止服务瘫痪。
Eureka Server 核心组件
-
ServerRegistry:用于保存注册的服务实例信息。
// 用于保存注册的服务实例信息 public interface ServerRegistry {// 注册服务实例boolean register(InstanceInfo info, int leaseDuration, boolean isReplication);// 取消注册服务实例boolean cancel(String appName, String id, boolean isReplication);// ... } -
PeerAwareInstanceRegistry:负责处理注册和剔除服务实例。
// 负责处理注册和剔除服务实例 public class PeerAwareInstanceRegistry implements ServerRegistry {// 注册服务实例@Overridepublic boolean register(InstanceInfo info, int leaseDuration, boolean isReplication) {// 根据服务名获取或创建服务信息Applications applications = getApplications();Application app = applications.getRegisteredApplications(info.getAppName());if (app == null) {app = new Application(info.getAppName());applications.addApplication(app);}// 添加服务实例到应用中app.addInstance(info);// ...}// ... } -
HealthCheckHandler:负责检查服务实例的健康状态。
// 负责检查服务实例的健康状态 public class HealthCheckHandler {// 检查服务实例的健康状态public boolean isInstanceHealthy(InstanceInfo instanceInfo) {// 检查实例的健康状态,例如发送心跳检查实例是否存活// 返回 true 或 false 表示实例是否健康}// ... }
Eureka Client 核心组件
-
DiscoveryClient:用于从 Eureka Server 获取可用服务列表,并进行缓存。
// 用于从 Eureka Server 获取可用服务列表,并进行缓存 public class DiscoveryClient {// 从 Eureka Server 获取服务列表public List<ServiceInstance> getInstances(String serviceId) {// 通过 REST API 从 Eureka Server 获取服务列表// 返回可用的服务实例列表}// ... } -
InstanceInfo:保存服务实例的基本信息,如服务名、IP 地址、端口等。
// 保存服务实例的基本信息,如服务名、IP 地址、端口等 public class InstanceInfo {// 服务名private String appName;// IP 地址private String ipAddr;// 端口号private int port;// ... } -
ApplicationInfoManager:管理当前服务的实例信息,负责向 Eureka Server 注册和发送心跳。
// 管理当前服务的实例信息,负责向 Eureka Server 注册和发送心跳 public class ApplicationInfoManager {// 向 Eureka Server 注册服务实例public InstanceInfo register(InstanceInfo info, int leaseDuration, boolean isReplication) {// 发送注册请求到 Eureka Server// 返回注册成功的服务实例信息}// ... }
使用场景
-
微服务架构:Eureka 适用于构建微服务架构中的服务注册与发现,实现服务之间的动态调用和扩展。
-
弹性和高可用:Eureka Server 支持集群部署,通过自我保护机制确保系统的弹性和高可用性。
-
复杂网络环境:适用于多个数据中心、跨区域服务调用等复杂网络环境下的服务注册与发现。
-
与 Spring Cloud 集成:Eureka 与 Spring Cloud 深度整合,可以轻松搭建微服务架构,并实现服务注册与发现。
结语
Eureka 作为服务发现领域的重要组件之一,为构建分布式系统提供了方便、稳定的服务注册与发现解决方案。通过深入了解其原理和使用场景,我们可以更好地应用 Eureka,构建出更强大、更稳定的微服务架构。
相关文章:
【Spring Cloud】Eureka详细介绍及底层原理解析
目录 底层原理详解 1. 服务注册与发现 2. 心跳机制 3. 服务剔除与自我保护机制 Eureka Server 核心组件 Eureka Client 核心组件 使用场景 结语 Eureka 是 Netflix 开源的一款服务发现框架,用于构建分布式系统中的服务注册与发现。 它包含两个核心组件&…...
【清华大学】《自然语言处理》(刘知远)课程笔记 ——NLP Basics
自然语言处理基础(Natural Language Processing Basics, NLP Basics) 自然语言处理( Natural Language Processing, NLP)是计算机科学领域与人工智能领域中的一个重要方向。它研究能实现人与计算机之间用自然语言进行有效通信的各种理论和方法。自然语言…...
代码随想录 | Day17 | 二叉树:二叉树的最大深度最小深度
代码随想录 | Day17 | 二叉树:二叉树的最大深度&&最小深度 主要学习内容: 利用前序后序层序求解二叉树深度问题 其中穿插回溯法 104.二叉树的最大深度 104. 二叉树的最大深度 - 力扣(LeetCode) 递归遍历 后序遍历 …...
【Linux】Socket编程基础
文章目录 字节序字节序转化函数 套接字socket通用结构体通信类型名空间套接字函数socket():创建套接字bind()函数:绑定服务器套接字与其地址、端口listen()函数:侦听客户连接connect():连接服务器套接字accept()函数:服…...
关于stm32的软件复位
使用软件复位的目的: 软件复位并不会擦除存储器中的数据,它只是将处理器恢复到复位状态,即中断使能位被清除,系统寄存器被重置,但RAM和Flash存储器中的数据保持不变。 STM32软件复位(基于库文件V3.5) ,对…...
规范系统运维:系统性能监控与优化的重要性与实践
在当今这个高度信息化的时代,企业的IT系统运维工作显得尤为关键。其中,系统性能监控和优化是运维工作中不可或缺的一环。本文旨在探讨规范系统运维中系统性能监控与优化的重要性,并分享一些实践经验和策略。 一、系统性能监控与优化的重要性…...
用python编撰一个电脑清理程序
自制一个电脑清理程序,有啥用呢?在电脑不装有清理软件的时候,可以解决自己电脑内存不足的情况。 1、设想需要删除指定文件夹中的临时文件和缓存文件。以下是代码。 import os import shutil def clean_folder(folder_path): for root,…...
2024年【天津市安全员C证】免费试题及天津市安全员C证试题及解析
题库来源:安全生产模拟考试一点通公众号小程序 天津市安全员C证免费试题是安全生产模拟考试一点通生成的,天津市安全员C证证模拟考试题库是根据天津市安全员C证最新版教材汇编出天津市安全员C证仿真模拟考试。2024年【天津市安全员C证】免费试题及天津市…...
【Python数据挖掘实战案例】机器学习LightGBM算法原理、特点、应用---基于鸢尾花iris数据集分类实战
一、引言 1、简要介绍数据挖掘的重要性和应用 在数字化时代,数据已经成为企业和社会决策的重要依据。数据挖掘作为一门交叉学科,结合了统计学、机器学习、数据库技术和可视化等多个领域的知识,旨在从海量数据中提取有价值的信息,…...
使用LabVIEW进行大数据数组操作的优化方法
针对大数据量数组操作,传统的内存处理方法可能导致内存不足。通过LabVIEW的图像批处理技术,可以有效地进行大数据数组操作,包括分块处理、并行处理和内存优化等。这种方法能显著提高处理效率和系统稳定性。 图像批处理的优势 内存优化&#…...
【Linux】(五)—— SSH远程登录和XShell使用
SSH Linux中的SSH(Secure Shell)是一个强大的网络协议,用于在不安全的网络环境中提供安全的远程登录和资料拷贝等其他网络服务。以下是有关Linux中SSH的关键点和操作指南: SSH的基础概念 安全性:SSH通过对所有传输的…...
前端怎么实现跨域请求?
前端实现跨域请求(Cross-Origin Resource Sharing, CORS)通常涉及到后端服务器的配置,因为浏览器的同源策略(Same-Origin Policy)会阻止前端代码直接发起跨域请求。然而,有几种方法可以在前端和后端的配合下…...
sqlmap直接嗦 dnslog注入 sqllibs第8关
dnslog注入是解决注入的时候没有回显的情况,通过dns外带来进行得到我们想要的数据。 我们是用了dns解析的时候会留下记录,这时候就可以看见我们想要的内容。 这个时候我们还要了解unc路径以及一个函数load_file()以及concat来进行注入。看看我的笔记 unc…...
数据结构笔记 3 串 数组 广义表
以下了解即可,暂时没发现有什么考点 参考: 【数据结构】——多维数组和广义表_数据结构loc-CSDN博客 相对应的题目: 他这个数组不是从0开始的,是从1开始的,所以为了配合公式要减1 下面这道题又不一样,它是…...
SpringCloud微服务GateWay网关使用与配置
一、概念 1、什么是GateWay网关 在微服务架构中,Gateway(网关)是一个重要的组件,负责处理外部请求并将它们路由到适当的微服务。以下是Gateway在微服务中的一些主要功能: 路由: Gateway负责将来自客户端的…...
win7补丁下载
目的 一般来说,安装上windows系统就带着补丁了,但有时,安装的是原始版的操作系统是不带补丁的,一般直接更新就可以了,但有时,电脑不能联网,只能通过安装包进行升级,所以下面介绍如何…...
在Cisco Packet Tracer上配置NAT
目录 前言一、搭建网络拓扑1.1 配置PC机1.2 配置客户路由器1.3 配置ISP路由器 二、配置NAT2.1 在客户路由器中配置NAT2.2 测试是否配置成功 总结 前言 本篇文章是在了解NAT的原理基础上,通过使用Cisco Packet Tracer 网络模拟器实现模拟对NAT的配置,以加…...
Web前端工程师的前景:挑战与机遇并存
Web前端工程师的前景:挑战与机遇并存 随着互联网的飞速发展和数字化转型的深入推进,Web前端工程师的前景日益广阔且充满挑战。作为互联网技术的核心力量之一,前端工程师的角色越来越重要,但同时也面临着技术更新迅速、市场需求多…...
MySQL—多表查询—联合查询
一、引言 之前学习了连接查询。现在学习联合查询。 union:联合、联盟 对于union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集 涉及到两个关键字:union 和 union all 注意: union 会把上面两个SQL查询…...
2024 Jiangsu Collegiate Programming Contest E. Divide 题解 主席树
Divide 题目描述 Given an integer sequence a 1 , a 2 , … , a n a_1,a_2,\ldots,a_n a1,a2,…,an of length n n n. For an interval a l , … , a r a_l,\ldots,a_r al,…,ar in this sequence, a Reduce operation divides the maximum value of the inter…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...
如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...
HBuilderX安装(uni-app和小程序开发)
下载HBuilderX 访问官方网站:https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本: Windows版(推荐下载标准版) Windows系统安装步骤 运行安装程序: 双击下载的.exe安装文件 如果出现安全提示&…...
【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具
第2章 虚拟机性能监控,故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令:jps [options] [hostid] 功能:本地虚拟机进程显示进程ID(与ps相同),可同时显示主类&#x…...
C++八股 —— 单例模式
文章目录 1. 基本概念2. 设计要点3. 实现方式4. 详解懒汉模式 1. 基本概念 线程安全(Thread Safety) 线程安全是指在多线程环境下,某个函数、类或代码片段能够被多个线程同时调用时,仍能保证数据的一致性和逻辑的正确性…...
Maven 概述、安装、配置、仓库、私服详解
目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...
云原生玩法三问:构建自定义开发环境
云原生玩法三问:构建自定义开发环境 引言 临时运维一个古董项目,无文档,无环境,无交接人,俗称三无。 运行设备的环境老,本地环境版本高,ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…...
中医有效性探讨
文章目录 西医是如何发展到以生物化学为药理基础的现代医学?传统医学奠基期(远古 - 17 世纪)近代医学转型期(17 世纪 - 19 世纪末)现代医学成熟期(20世纪至今) 中医的源远流长和一脉相承远古至…...
