[个人感悟] 缓存应该考察哪些问题?

2024-06-17 10:52

本文主要是介绍[个人感悟] 缓存应该考察哪些问题?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述


前言

缓存, 根据冯诺依曼计算机模型, 无非是为了更高效的交互, 使用内存IO替换本地磁盘IO. 又因为内存的稀缺性, 其必然存储的是热点数据, 且较小的数据. [虽然直至今日, 已有使用缓存作为数据库的使用, 但是与磁盘IO相比, 其价格仍是数倍之多.]

当涉及缓存问题时, 又分为本地缓存和分布式缓存, 此2个方向. 且对于缓存而言, 除了询问其基本使用外, 还会寻味其中相关的经典问题, 缓存击穿&缓存穿透&缓存雪崩, 以及如何保证缓存一致性. 这2个经典问题.


问题

问题 - 缓存

  • 为什么需要缓存, 缓存的意义和底层原理是什么?
  • 讲一讲你常用的缓存工具? [单机 & 分布式]

问题 - 本地缓存

  • 常用的本地缓存是什么? Spring 默认提供的缓存实现是什么?

问题 - Redis(1)

  • 为什么要使用Redis缓存? (Redis 缓存的优势)
  • Redis是单线程还是多线程? 如何理解?
  • Redis 常见的数据类型有哪些? 各有哪些运行场景?
  • Redis 高级数据类型? 各有哪些运行场景?

问题 - Redis(2)

  • 如何使用Redis实现分布式锁?
  • 是否使用过Redis事务?生产过程中是否使用? [为什么不使用]
  • Reids持久化方式有哪些? 其有什么区别和优势?
  • 讲一讲Redis的渐进式Rehash过程?
  • Redis的过期策略有哪些?
  • Redis bgsave的同步策略有了解么?
  • Redis 是否使用keys命令? 其会导致什么影响?
  • Redis 如何计算key的大小, 并实施监控?
  • Redis 主从, 哨兵, 集群问题. 介绍下这3种架构的区别和优势?

问题 - 缓存经典问题

  • 什么是缓存穿透? 如何解决?
  • 什么是缓存击穿? 如何解决?
  • 什么是缓存雪崩? 如何解决?
  • 什么是缓存热点数据预热? 通常解决什么问题?
  • 多级缓存架构问题?
  • 如何保证Mysql和Redis缓存的双写一致性?
  • 什么是BigKey? 如何解决?
  • 什么是热点Key? 如何解决?

解答

Redis相关的问题个人认为不再赘述. 其基本都有现成的解决策略. 这里捡主要的问题进行回答.

问题 - 本地缓存

Spring 3.x使用Guava作为本地缓存默认实现, 4.x使用CaffeineCache.

解答-Redis

  • 如何使用Redis实现分布式锁?

问题一般是: “你们开发过程种如何使用Redis的?” 其中回答可以引申至Redis锁. 关于Redis锁, 其Redission包内有非常成功的实现. 其要点如下:

  1. 设置单一锁. 锁仅第一个申请线程才可以获取.
  2. 设置锁自动失效时间. 考虑如果申请线程失效, 无法自动释放锁, 导致死锁.
  3. 设置守护线程, 对锁进行续约. watchdog策略, 可以使用时间轮进行优化定时任务.
  4. 设置获取锁线程. 必须由当前线程对锁进行释放.
  5. 设置获取锁线程. 当前线程可以重入锁.

解答-缓存经典问题

缓存穿透, 缓存击穿, 缓存雪崩. 基本是缓存常见的3个实战问题. 笔者之前常常分不清穿透和击穿, 这里给出一个小技巧.
穿透, 强调的是大量无效Key, 导致缓存似乎无用.
击穿. 强调是大量请求访问数据库. 导致突然的流量异常.

  • 什么是缓存穿透? 如何解决?

根据上述描述. 缓存穿透, 某些用户经常查询不存在的key, 导致多次访问数据库. 好似缓存不存在, 请求透过缓存, 直接访问数据库. 其解决方式主要有2种:

  1. 如果无用键较少. 可以使用 unknow_key=null.的策略进行预防.
  2. 使用布隆过滤器. 已存在键进行写入时, 需要更新布隆过滤器的bitmap.
  3. 如果是黑客攻击等. 需要设置相关黑白名单进行防御.
  • 什么是缓存击穿? 如何解决?

根据上述描述. 缓存击穿, 指某一常用的key失效, 导致多个请求, 同时对于数据库进行访问. 导致数据库压力过大.
其主要解决方式主要有2种:

  1. 热点key设置永不过期.
  2. 热点数据请求时, 设置锁. 仅使用一个线程进行获取并更新缓存, 其余线程唤醒后, 优先请求缓存数据.
  • 什么是缓存雪崩? 如何解决?

缓存雪崩. 多个热点数据同时失效, 导致大量缓存失效. 其主要解决方式2种:

  1. 热点key设置永不过期.
  2. 缓存时间设置 当前时间+[1-5分钟随机数] 可以使用框架完成.
  • 什么是缓存热点数据预热? 通常解决什么问题?

这个问题一般不这么问. 一般可以作为项目优化点和亮点进行. 热点数据预热, 即项目启动时, 或者秒杀活动等开启前, 将需要秒杀或者使用的数据提前放置缓存, 放置进行备动添加. 优点是提升效率. 缺点是可能导致部分非核心数据写入缓存.

  • 多级缓存架构问题?

多级缓存通常指. Mysql - Java程序本地缓存 - Redis.

  1. 缓存访问. 本地 - Reids - Mysql顺序.
  2. 缓存更新. Mysql更新 - Reids失效 - 本地失效
  • 如何保证Mysql和Redis缓存的双写一致性?
    更新Mysql后, 使Redis内缓存失效. 用户再次命中时, 再次写入缓存.

这篇关于[个人感悟] 缓存应该考察哪些问题?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

解决JSONField、JsonProperty不生效的问题

《解决JSONField、JsonProperty不生效的问题》:本文主要介绍解决JSONField、JsonProperty不生效的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录jsONField、JsonProperty不生效javascript问题排查总结JSONField

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复