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

在这里插入图片描述


前言

缓存, 根据冯诺依曼计算机模型, 无非是为了更高效的交互, 使用内存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.mzph.cn/news/854079.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

调用第三方系统的签名设计与校验实例讲解与实践

在现代软件开发中,调用第三方系统API已经成为常见需求。为了保证数据传输的安全性和完整性,许多API采用了签名机制。本文将详细讲解如何设计与校验调用第三方系统的签名,以确保双方通信的安全和可靠。 #### 一、签名机制的意义 签名机制主要…

C语言之顺序结构以及程序调试的debug宏

一:C语言中的顺序结构 1:最浅显的顺序结构理解:三种结构之一 (1)代码执行的时候没有遇到判断跳转或者循环,默认是顺序执行的。执行完上一句则开始执行下一句。 (2)顺序结构说明cpu的工作状态&a…

类Copy方法:BeanUtils.copyProperties

类Copy方法:BeanUtils.copyProperties 需求场景 比如有时候我们想要把数据库里面的数据导出到excel表中,比如想要把数据库中的用户数据导出到excel表格中; 假设我们程序代码中与数据库对接的实体类是User,用于展示到前端的实体类…

Fiddler抓包工具介绍

下载 下载:Web Debugging Proxy and Troubleshooting Tools|Fiddler 进去要填一个表 汉化版 百度网盘 请输入提取码 提取码:xq9t 下载过附件之后分别把两个文件 点开fiddler就ok了 配置https fiddler要想抓到https包(解密的),点击tools->options勾选三个对…

总结之Docker(四)——镜像修改非ROOT用户权限后生成新镜像并发布

Docker拉去目标镜像 docker pull redis:6.2.5如果出现拉去过程超时,或者连接失败。 添加镜像加速器,以阿里云为例,阿里云目前推广提供镜像加速器,需要登录。 https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors 生成…

HMI(人机交互)应用的15大领域,欢迎补充。

HMI(Human-Machine Interface,人机界面)可以应用于许多不同的场景和行业,包括但不限于以下几个方面: 工业控制系统:HMI在工业生产中广泛应用,用于监控和控制生产过程。例如,工厂中的…

NewStarCTF_RE(week1,2)

[NewStarCTF 2023 公开赛道]easy_RE ida 可能会把 一个数组或字符串拆开,可以通过计算地址,知道是一起的 也有的会藏在汇编窗口 Segments IDA的Segments窗口 :shiftf7 https://www.cnblogs.com/sch01ar/p/9477697.html ida 各种窗口也是需要…

AMD平台,5600X+6650XT,虚拟机安装macOS 14(2024年6月)

AMD平台安装macOS 14的麻烦,要比Intel平台多的多,由于macOS从13开始,对CPU寄存器的读取进行了改变,导致AMD平台只要安装完macOS 13及以后版本,开机后就报五国语言错误,不断重启。改vmx文件,被证…

mongodb command

1. start and stop ./mongod --dbpath -dbpath /data/shard1/db --logpath -dbpath /data/shard1/db/logs/mongodb.log --fork mongod --shutdown --dbpath /data/shard1/db MongoDB基础篇-03-启动与关闭_mongodb启动和关闭-CSDN博客 2. 查看分片数据分布 mongo mongo01.c…

用React编写一个密码组件表单

theme: condensed-night-purple highlight: atelier-cave-light 背景介绍 我们在使用网站或者应用程序的登录界面或创建帐户界面时,往往避免不了需要用户输入密码这一步骤,而用户是否可以选择看见他们输入的密码是十分重要的一项功能。尤其是在当输入的…

Java面向对象-final关键字

Java面向对象-final关键字 一、final1、修饰变量2、修饰方法3、修饰类4、案例 一、final 可以修饰变量、方法、类 1、修饰变量 final修饰一个变量,变量的值不可以改变,这个变量就变成一个字符常量,约定俗称的规定:名字大写。 f…

【flink实战】flink-connector-mysql-cdc导致mysql连接器报类型转换错误

文章目录 一. 报错现象二. 方案二:重新编译打包flink-connector-cdc1. 排查脚本2. 重新编译打包flink-sql-connector-mysql-cdc-2.4.0.jar3. 测试flink环境 三. 方案一:改造flink连接器 一. 报错现象 flink sql任务是:mysql到hdfs的离线任务&…

IPTCP知识

1. IP: IP地址是一个32位的二进制数,通常被分割为4个“8位二进制数”IP地址分类:A类地址、B类地址、C类地址、D类地址、E类地址 A类地址分配给规模特别大的网络使用,B类地址分配给一般的中型网络,C类地址分配给小型网…

短URL服务设计

引言 在营销系统里,为了增加系统的活跃用户数,经常会有各种各样的营销活动。这类活动几乎都是为了充分利用存量用户的价值,促使他们分享产品或App以达到触达到更多用户的目的。又或者是出于营销目的,群发优惠券触达短信这种场景。…

MVC 框架安全

在现代 Web 开发中,使用 MVC 架构是一种流行的做法。MVC 是 Model-View-Controller 的缩写,它将 Web 应用分为三层,View 层负责用户视图、页面展示等工作;Controller 负责应 用的逻辑实现,接收 View 层传入的用户请求&…

016基于SSM+Jsp的医院远程诊断系统

开发语言:Java框架:ssm技术:JSPJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包…

HDU - 5651 xiaoxin juju needs help(Java JS Python C C++)

题目来源 Problem - 5651 (hdu.edu.cn) 题目描述 众所周知,小新是一位才华横溢的程序员。当他还是小学六年级的学生时,他就知道回文字符串了。 今年夏天,他在腾讯实习。一天,他的领导来找小新帮忙。他的领导给了他一个字符串&a…

MySQL之优化服务器设置(五)

优化服务器设置 高级InnoDB设置 innodb_old_blocks_time InnoDB有两段缓冲池LRU(最近最少使用)链表,设计目的是防止换出长期很多次的页面。像mysqldump产生的这种一次性的(大)查询,通常会读取页面到缓冲池的LRU列表,从中读取需要的行&…

Android 支持库迁移到AndroidX

对应官方文档: developer.android.com/jetpack/and… 简单点说就是,对App开发者而言,AndroidX更加友好,因为我们引入时,只需要关注AndroidX中具体的需要引入的构件版本即可。且大部分具体的构件,具有一致的…

Ansys Mechanical|学习方法

Ansys Mechanical是Ansys的旗舰产品之一,涉及的学科体系全面丰富,包括的力学分支主要有理论力学,振动理论,连续介质力学,固态力学,物理力学,爆炸力学及应用力学等。 在自媒体及数字经济飞速发展…