多级透明分流系统(服务端缓存)

2024-03-06 14:04

本文主要是介绍多级透明分流系统(服务端缓存),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一件事情是确认是否需要引入缓存:缓存的核心是缓解压力,而非提高响应速度

引入缓存的原因无非两点:

  • 缓解CPU压力而引入缓存(比如将运行结果存起来,要求实时计算的结果存起来,公用数据复用)
  • 缓解IO压力引入缓存(将单点部件的读写访问变为可扩缩部件的访问)

缓存属性

  • 吞吐量
  • 命中率和淘汰规则
  • 扩展功能
  • 分布式缓存(缓存可分为进程内缓存和分布式缓存两种)

缓存淘汰规则

  • FIFO
  • LRU(Least Recent Used),淘汰最久未被使用的数据
    通常可以通过LinkedList双向队列来实现,使用过的放开头,淘汰末尾。
  • LFU(Least Frequently Used),淘汰最不经常使用的数据。给每个数据都加一个访问记录器,每访问一次就加1,需要淘汰时候淘汰访问数最少的数据。
    TinyLFU:添加了滑动窗口的概念,一段时间后所有计数器值减半,热度衰退。

分布式缓存

相比于在进程内存中读写速度,一旦涉及网络访问,由网络传输,数据复制,序列化,反序列化等操作所导致的延迟要比内存访问高很多。

复制式分布式缓存

更新很少但是频繁读取的数据,可以将数据分布到不同线程的,这样读就不需要网络访问了。
当数据发生变化时,遵循复制协议,将变更同步到集群的每个节点中。
复制式随着节点的增加呈现性能的平方级别的下将,变更代价变得高昂。

集中式分布式缓存

读写都需要网络访问,不会随着集群节点的数量增加而产生额外的代价。
强一致性zookeeper,弱一致性Redis。

多级缓存

分布式缓存和进程内缓存各有所长,通常将两者搭配使用,可以将进程内缓存作为一级缓存,而分布式缓存作为二级缓存。没找到,回填数据。通过对接口的包装,实现对用户的透明。

缓存风险

缓存穿透

查询在数据库中不存在的数据,每次查询都会触及末端的数据库,这种现象就叫做缓存穿透。
缓存穿透可能是恶意攻击造成的。
有两种解决方案:

  1. 将查询为空的key也缓存,从而一段时间内一个空查询只会穿透一次。
  2. 在缓存之前设置一个布隆过滤器。

缓存击穿

热点数据失效,导致大量的请求击穿缓存到达数据库,导致数据库压力倍增,就叫做缓存击穿。
有两种解决方案:

  1. 加锁同步,以请求的key为锁,使得只有第一个请求可以流入真实的数据源,其他线程阻塞或者重试。
  2. 热点数据手动管理

缓存雪崩

缓存雪崩通常描述的是更广泛范围的缓存失效情况,而缓存击穿则更侧重于某个具体数据的失效引起的问题。
出现这种情况通常是因为冷启动,或者大量数据的过期时间设置相似导致的。
策略:

  1. 不要将大量数据的过期时间设置的相似。
  2. 热启动。
  3. 建立分布式集群,提高可用性。

缓存污染

缓存中的数据和数据源中的数据不一致(最终一致性)。

这篇关于多级透明分流系统(服务端缓存)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/780289

相关文章

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

Oracle数据库在windows系统上重启步骤

《Oracle数据库在windows系统上重启步骤》有时候在服务中重启了oracle之后,数据库并不能正常访问,下面:本文主要介绍Oracle数据库在windows系统上重启的相关资料,文中通过代... oracle数据库在Windows上重启的方法我这里是使用oracle自带的sqlplus工具实现的方

Redis高性能Key-Value存储与缓存利器常见解决方案

《Redis高性能Key-Value存储与缓存利器常见解决方案》Redis是高性能内存Key-Value存储系统,支持丰富数据类型与持久化方案(RDB/AOF),本文给大家介绍Redis高性能Key-... 目录Redis:高性能Key-Value存储与缓存利器什么是Redis?为什么选择Redis?Red

React 记忆缓存的三种方法实现

《React记忆缓存的三种方法实现》本文主要介绍了React记忆缓存的三种方法实现,包含React.memo、useMemo、useCallback,用于避免不必要的组件重渲染和计算,感兴趣的可以... 目录1. React.memo2. useMemo3. useCallback使用场景与注意事项在 Re

Docker多阶段镜像构建与缓存利用性能优化实践指南

《Docker多阶段镜像构建与缓存利用性能优化实践指南》这篇文章将从原理层面深入解析Docker多阶段构建与缓存机制,结合实际项目示例,说明如何有效利用构建缓存,组织镜像层次,最大化提升构建速度并减少... 目录一、技术背景与应用场景二、核心原理深入分析三、关键 dockerfile 解读3.1 Docke

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环