当前位置: 首页 > news >正文

Redis面试题(五)

文章目录

  • 前言
  • 一、使用过 Redis 做异步队列么,你是怎么用的?有什么缺点?
  • 二、 什么是缓存穿透?如何避免?什么是缓存雪崩?何如避免?
  • 总结


前言

  1. 使用过 Redis 做异步队列么,你是怎么用的?有什么缺点?
  2. 什么是缓存穿透?如何避免?什么是缓存雪崩?何如避免?

`

一、使用过 Redis 做异步队列么,你是怎么用的?有什么缺点?

一般使用 list 结构作为队列,rpush 生产消息,lpop 消费消息。当 lpop 没有消息的时候,要适当 sleep
一会再重试。
缺点:
在消费者下线的情况下,生产的消息会丢失,得使用专业的消息队列如 rabbitmq 等。
能不能生产一次消费多次呢?
使用 pub/sub 主题订阅者模式,可以实现 1:N 的消息队列。


二、 什么是缓存穿透?如何避免?什么是缓存雪崩?何如避免?

缓存穿透
一般的缓存系统,都是按照 key 去缓存查询,如果不存在对应的 value,就应该去后端系统查找(比如DB)。一些恶意的请求会故意查询不存在的 key,请求量很大,就会对后端系统造成很大的压力。这就叫做缓存穿透。
如何避免?

  1. 对查询结果为空的情况也进行缓存,缓存时间设置短一点,或者该 key 对应的数据 insert 了之后清理缓存。
  2. 对一定不存在的 key 进行过滤。可以把所有的可能存在的 key 放到一个大的 Bitmap 中,查询时通过该 bitmap 过滤。
    缓存雪崩
    当缓存服务器重启或者大量缓存集中在某一个时间段失效,这样在失效的时候,会给后端系统带来很大压力。导致系统崩溃。
    如何避免?
  3. 在缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量。比如对某个 key 只允许一个线
    程查询数据和写缓存,其他线程等待。
  4. 做二级缓存,A1 为原始缓存,A2 为拷贝缓存,A1 失效时,可以访问 A2,A1 缓存失效时间设置为短期,A2 设置为长期
  5. 不同的 key,设置不同的过期时间,让缓存失效的时间点尽量均匀

总结

  1. 使用过 Redis 做异步队列么,你是怎么用的?有什么缺点?
  2. 什么是缓存穿透?如何避免?什么是缓存雪崩?何如避免?
http://www.lryc.cn/news/174713.html

相关文章:

  • 组队竞赛(int溢出问题)
  • Swift SwiftUI 隐藏键盘
  • Python与数据分析--Pandas-1
  • 如何完美通过token获取用户信息(springboot)
  • 2023 “华为杯” 中国研究生数学建模竞赛(B题)深度剖析|数学建模完整代码+建模过程全解全析
  • 文件相关工具类
  • 18795-2012 茶叶标准样品制备技术条件
  • C++11互斥锁的使用
  • unity 桌面程序
  • echarts统一纵坐标y轴的刻度线,刻度线对齐。
  • 一个数据库版本兼容问题
  • 学习Nano编辑器:入门指南、安装步骤、基本操作和高级功能
  • 在北京多有钱能称为富
  • Chrome扩展程序开发随记
  • 使用命令行快速创建Vite项目
  • int *a, int **a, int a[], int *a[]的区别
  • leetcode100----双指针
  • ORM基本操作
  • c语言进阶部分详解(指针进阶2)
  • Java基础(一)——Hello World,8种数据类型,键盘录入
  • JAVA学习笔记(IF判断结构)
  • 【跟小嘉学 PHP 程序设计】二、PHP 基本语法
  • 面试总结之微服务篇
  • ElementUI之登陆+注册
  • 新版kafka可视化界面组件
  • ​P1102 A-B 数对 【双指针(尺取法)】​
  • Flutter绘制拖尾效果
  • 【Newman+Jenkins】实施接口自动化测试
  • kr 第三阶段(六)C++ 逆向
  • 医药行业安全生产信息化建设分享