当前位置:网站首页>Redis common interview questions
Redis common interview questions
2022-08-02 15:33:00 【Caviar :P】
来自:小林coding
Redis 是一种基于内存的数据库,Read and write operations on data are done in memory,因此读写速度非常快,常用于缓存,消息队列、分布式锁等场景.
# 为什么用 Redis 作为 MySQL 的缓存?
1、Redis 具备高性能
假如用户第一次访问 MySQL 中的某些数据.这个过程会比较慢,因为是从硬盘上读取的.The data accessed by this user is cached Redis 中,这样下一次再访问这些数据的时候就可以直接从缓存中获取了,操作 Redis 缓存就是直接操作内存,所以速度相当快.
2、 Redis 具备高并发
单台设备的 Redis 的 QPS(Query Per Second,每秒钟处理完请求的次数) 是 MySQL 的 10 倍,Redis 单机的 QPS Can break easily 10w,而 MySQL 单机的 QPS hard to break 1w.
所以,直接访问 Redis Able to withstand requests is far greater than direct access MySQL 的,所以我们可以考虑把数据库中的部分数据转移到缓存中去,这样用户的一部分请求会直接到缓存这里而不用经过数据库.
# Redis What are the data types and usage scenarios?
- String 类型的应用场景:缓存对象、常规计数、分布式锁、共享 session 信息等.
- List 类型的应用场景:消息队列(但是有两个问题:1. 生产者需要自行实现全局唯一 ID;2. 不能以消费组形式消费数据)等.
- Hash 类型:缓存对象、购物车等.
- Set 类型:聚合计算(并集、交集、差集)场景,比如点赞、共同关注、抽奖活动等.
- Zset 类型:排序场景,比如排行榜、电话和姓名排序等.
# Redis How to achieve data loss?
Redis All read and write operations are in memory,所以 Redis performance will be high,但是当 Redis 重启后,内存中的数据就会丢失,That is to ensure that the data in memory will not be lost,Redis Implemented the mechanism of data persistence,This mechanism will store the data to disk,这样在 Redis Rebooting will restore the original data from the disk.
Redis There are three ways of data persistence:
- AOF 日志:每执行一条写操作命令,就把该命令以追加的方式写入到一个文件里;
- RDB 快照:将某一时刻的内存数据,以二进制的方式写入磁盘;
- 混合持久化方式:Redis 4.0 新增的方式,集成了 AOF 和 RBD 的优点;
Redis 内存满了,会发生什么?
在 Redis of running memory reaches a certain threshold,就会触发内存淘汰机制,这个阀值就是我们设置的最大运行内存,此值在 Redis 的配置文件中可以找到,配置项为 maxmemory.
Redis 内存淘汰策略共有八种,这八种策略大体分为「不进行数据淘汰」和「进行数据淘汰」两类策略.
1、不进行数据淘汰的策略
noeviction(Redis3.0之后,默认的内存淘汰策略) :它表示当运行内存超过最大设置内存时,不淘汰任何数据,而是不再提供服务,直接返回错误.
2、进行数据淘汰的策略
针对「进行数据淘汰」这一类策略,又可以细分为「在设置了过期时间的数据中进行淘汰」和「在所有数据范围内进行淘汰」这两类策略.
如何避免缓存雪崩?
通常我们为了保证缓存中的数据与数据库中的数据一致性,会给 Redis 里的数据设置过期时间,当缓存数据过期后,用户访问的数据如果不在缓存里,业务系统需要重新生成缓存,因此就会访问数据库,并将数据更新到 Redis 里,这样后续请求都可以直接命中缓存.
那么,当大量缓存数据在同一时间过期(失效)时,如果此时有大量的用户请求,都无法在 Redis 中处理,于是全部请求都直接访问数据库,从而导致数据库的压力骤增,严重的会造成数据库宕机,从而形成一系列连锁反应,造成整个系统崩溃,这就是缓存雪崩的问题.
发生缓存雪崩有两个原因:
- 大量数据同时过期;
- Redis 故障宕机;
For the cache avalanche problem,We can use two solutions.
- Randomly scatter cache invalidation times: 我们可以在原有的失效时间基础上增加一个随机值(比如 1 到 10 分钟)In this way, the expiration time of each cache is not repeated,It also reduces the probability of cache collective failure.
- 后台更新缓存,设置缓存不过期: We can update cached data through a background service,This avoids cache avalanches caused by cache invalidation,The cache concurrency problem can also be avoided to a certain extent.
如何避免缓存击穿?
我们的业务通常会有几个数据会被频繁地访问,比如秒杀活动,这类被频地访问的数据被称为热点数据.如果缓存中的某个热点数据过期了,此时大量的请求访问了该热点数据,就无法从缓存中读取,直接访问数据库,数据库很容易就被高并发的请求冲垮,这就是缓存击穿的问题.
可以发现缓存击穿跟缓存雪崩很相似,你可以认为缓存击穿是缓存雪崩的一个子集. 应对缓存击穿可以采取前面说到两种方案:
- 互斥锁方案,It is guaranteed that only one business thread requests the cache at the same time,未能获取互斥锁的请求,要么等待锁释放后重新读取缓存,要么就返回空值或者默认值.
- 不给热点数据设置过期时间,由后台异步更新缓存,或者在热点数据准备要过期前,提前通知后台线程更新缓存以及重新设置过期时间;
如何避免缓存穿透?
当发生缓存雪崩或击穿时,数据库中还是保存了应用要访问的数据,一旦缓存恢复相对应的数据,就可以减轻数据库的压力,而缓存穿透就不一样了.
当用户访问的数据,既不在缓存中,也不在数据库中,导致请求在访问缓存时,发现缓存缺失,再去访问数据库时,发现数据库中也没有要访问的数据,没办法构建缓存数据,来服务后续的请求.那么当有大量这样的请求到来时,数据库的压力骤增,这就是缓存穿透的问题.
缓存穿透的发生一般有这两种情况:
- 业务误操作,缓存中的数据和数据库中的数据都被误删除了,所以导致缓存和数据库中都没有数据;
- 黑客恶意攻击,故意大量访问某些读取不存在数据的业务;
应对缓存穿透的方案,常见的方案有三种.
- 非法请求的限制:当有大量恶意请求访问不存在的数据的时候,也会发生缓存穿透,因此在 API 入口处我们要判断求请求参数是否合理,请求参数是否含有非法值、请求字段是否存在,如果判断出是恶意请求就直接返回错误,避免进一步访问缓存和数据库.
- Set empty or default value:当我们线上业务发现缓存穿透的现象时,可以针对查询的数据,在缓存中设置一个空值或者默认值,这样后续请求就可以从缓存中读取到空值或者默认值,返回给应用,而不会继续查询数据库.
# How to design a caching strategy,It is possible to dynamically cache hot data?
Due to limited data storage,The system does not need to store all the data in the cache,而Just cache some of the hot data,So we need to design a strategy for dynamic caching of hot data.The general idea of the strategy for dynamic caching of hot data:The ranking is done by the latest access time of the data,And filter out infrequently accessed data,Only frequently accessed data is left.
# 常见的缓存更新策略?
Common cache update strategies are shared3种:
- Cache Aside(旁路缓存)策略;
- Read/Write Through(读穿 / 写穿)策略;
- Write Back(写回)策略;
Cache Aside(旁路缓存)策略是最常用的,应用程序直接与「数据库、缓存」交互,并负责对缓存的维护,该策略又可以细分为「读策略」和「写策略」.
写策略的步骤:
- 先更新数据库中的数据,再删除缓存中的数据.
读策略的步骤:
- 如果读取的数据命中了缓存,则直接返回数据;
- 如果读取的数据没有命中缓存,则从数据库中读取数据,然后将数据写入到缓存,并且返回给用户.
注意,写策略的步骤的顺序顺序不能倒过来,即不能先删除缓存再更新数据库,原因是在「读+写」并发的时候,会出现缓存和数据库的数据不一致性的问题.
Cache Aside 策略适合读多写少的场景,不适合写多的场景,因为当写入比较频繁时,缓存中的数据会被频繁地清理,这样会对缓存的命中率有一些影响.
边栏推荐
- pygame绘制弧线
- MATLAB绘图命令fimplicit绘制隐函数图形入门详解
- In-depth understanding of Golang's Map
- Win7遇到错误无法正常开机进桌面怎么解决?
- Codeforces Round #624 (Div. 3)
- Win10电脑需要安装杀毒软件吗?
- Spark及相关生态组件安装配置——快速回忆
- MATLAB制作简易小动画入门详解
- KiCad Common Shortcuts
- Compilation error D8021: Invalid numeric argument '/Wextra' cl command line error d8021 invalid numeric argument '/Wextra'
猜你喜欢
What should I do if Windows 10 cannot connect to the printer?Solutions for not using the printer
C语言函数参数传递模式入门详解
软件测试基础知识(背)
Mysql lock
What should I do if I install a solid-state drive in Win10 and still have obvious lags?
6.统一记录日志
How to reinstall Win7 system with U disk?How to reinstall win7 using u disk?
Use tencent cloud builds a personal blog
4. Publish Posts, Comment on Posts
奇技淫巧-位运算
随机推荐
Mysql lock
3.用户上传头像
General syntax and usage instructions of SQL (picture and text)
关于c语言的调试技巧
IPV4和IPV6是什么?
How to simulate 1/3 probability with coins, and arbitrary probability?
Masters and Masters
Publish module to NPM should be how to operate?Solutions to problems and mistake
队列与栈
win10系统更新错误代码0x80244022怎么办
In-depth understanding of Golang's Map
Software Testing Basics (Back)
总结计算机网络超全面试题
6.统一记录日志
奇技淫巧-位运算
为vscode配置clangd
MATLAB图形加标注的基本方法入门简介
win11一直弹出用户账户控制怎么解决
开心一下,9/28名场面合集
二叉树遍历之后序遍历(非递归、递归)入门详解