Eureka缓存机制

一、Eureka的CAP特性

Eureka是一个AP系统,它优先保证可用性(A)和分区容错性(P),而不保证强一致性(C)。这种设计使得Eureka在分布式系统中能够应对各种故障和分区情况,保证服务的基本可用性。为了实现这一目标,Eureka在架构中设计了多级缓存,以降低读写并发,避免读写争抢资源所带来的压力。

二、Eureka的三级缓存架构

Eureka的三级缓存架构包括一级缓存、二级缓存和三级缓存,它们分别对应Eureka Server中的不同变量:

  1. ‌**一级缓存(registry)**‌:这是Eureka Server中的注册表,保存了实时最新的服务注册信息。它是Eureka Server的核心数据结构,用于存储所有注册到Eureka Server上的服务实例信息。
  2. ‌**二级缓存(readWriteCacheMap)**‌:这是Eureka Server中的读写缓存,用于缓存从一级缓存中读取的服务注册信息。二级缓存的引入是为了降低对一级缓存的读写压力,提高服务查询的效率。当服务实例信息发生变化时,二级缓存会相应地进行更新。
  3. ‌**三级缓存(readOnlyCacheMap)**‌:这是Eureka Server中的只读缓存,用于进一步缓存从二级缓存中读取的服务注册信息。三级缓存的引入是为了实现读写分离,使得读操作不会阻塞写操作。默认情况下,Eureka Server会每30秒将二级缓存中的数据同步到三级缓存中。

三、Eureka缓存的工作机制

Eureka缓存的工作机制涉及服务注册、服务发现以及缓存的同步和失效等方面:

  1. 服务注册‌:当Eureka Client向Eureka Server注册服务时,Eureka Server会将服务实例信息写入到一级缓存(registry)中,并使得二级缓存(readWriteCacheMap)失效。这样,当其他Eureka Client查询该服务时,会首先从二级缓存中读取数据(如果二级缓存中有数据且未过期),否则会从一级缓存中读取数据并更新到二级缓存中。
  2. 服务发现‌:Eureka Client在查询服务时,会首先从三级缓存(readOnlyCacheMap)中读取数据。如果三级缓存中有数据且未过期,则直接返回数据;否则,会从二级缓存中读取数据并更新到三级缓存中。如果二级缓存中也没有数据或者数据已过期,则会触发回调函数从一级缓存中同步数据。
  3. 缓存同步‌:Eureka Server会定期将二级缓存中的数据同步到三级缓存中,以确保三级缓存中的数据是最新的。默认情况下,这个同步周期是30秒。
  4. 缓存失效‌:Eureka引入了缓存失效与剔除机制来确保缓存中的数据是活跃的。当一个服务实例长时间没有发送心跳请求时,Eureka Server会将其标记为失效。如果在一定时间内仍然没有收到心跳请求,则会从缓存中剔除该服务实例的信息。

四、Eureka缓存机制的优势

Eureka的缓存机制带来了以下优势:

  1. 提高性能‌:通过引入多级缓存,Eureka能够降低对注册表的读写压力,提高服务查询的效率。
  2. 读写分离‌:通过实现读写分离,Eureka能够使得读操作不会阻塞写操作,从而提高了系统的并发处理能力。
  3. 保证最终一致性‌:虽然Eureka不保证强一致性,但通过缓存机制和定期同步,它能够确保在一定时间内达到最终一致性。

综上所述,Eureka的缓存机制是其实现高效服务发现和注册功能的重要基础。通过引入多级缓存和相应的同步、失效机制,Eureka能够在分布式系统中提供稳定、可靠的服务发现和注册服务。

相关推荐
潮流coder1 分钟前
IntelliJ IDEA给Controller、Service、Mapper不同文件设置不同的文件头注释模板、Velocity模板引擎
java·ide·intellij-idea
lichuangcsdn4 分钟前
【springcloud学习(dalston.sr1)】项目整体介绍(含源代码)(一)
学习·spring·spring cloud
码农飞哥8 分钟前
互联网大厂Java求职面试实战:Spring Boot与微服务场景深度解析
java·数据库·spring boot·安全·微服务·消息队列·互联网医疗
Akiiiira24 分钟前
【日撸 Java 300行】Day 14(栈)
java·开发语言
猴子请来的逗比48931 分钟前
tomcat与nginx之间实现多级代理
java·nginx·tomcat
一丝晨光34 分钟前
数值溢出保护?数值溢出应该是多少?Swift如何让整数计算溢出不抛出异常?类型最大值和最小值?
java·javascript·c++·rust·go·c·swift
意倾城38 分钟前
浅说MyBatis-Plus 的 saveBatch 方法
java·mybatis
JANYI201844 分钟前
C语言易混淆知识点详解
java·c语言·算法
kyy_studydiary1 小时前
集合-进阶
java·开发语言
?abc!2 小时前
缓存(4):常见缓存 概念、问题、现象 及 预防问题
缓存