使用Redis实现缓存及对应问题解决-CSDN博客

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

一、为什么需要Redis作缓存

在业务场景中如果有些数据需要极高频的存取每次都要在mysql中查询的话代价太大假如有一个存在于客户端和mysql之间的存储空间每次可以在这空间中进行存取操作就会减轻mysql的压力而redis速度快效率高的特点是实现缓存的好选择。
在这里插入图片描述
在没有加入缓存的时候客户端和服务端的工作流程如图所示
在这里插入图片描述
加入缓存之后 在每次查询数据的时候先在redis中查询如果有就直接返回如果没有再去mysql中查询在mysql中查询到之后先写入到redis中在返回给客户端。

二、实现加入缓存。

在这里插入图片描述

三、缓存的更新策略。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

先删除缓存在更新数据库

在这里插入图片描述
假如在最开始的时候缓存中和数据库中的值都是10在正常的操作流程下会得到如下的结果。
在这里插入图片描述
但是在特殊情况下如果在线程一执行的时候线程二插入进来就会造成下图的情况。
在这里插入图片描述
而这种情况发生的概率还是很高的因为更新数据库的操作还是相对于写入缓存来说是很慢的在这个过程中极有可能发生这种情况。

先操作数据库在删除缓存

在这里插入图片描述
在正常的情况下发生的是如下的操作
在这里插入图片描述
这种情况的特殊情况是当缓存中的值失效缓存中没有值数据库中的值还是10会发生下面这种情况。
在这里插入图片描述

但是这种情况的概率是小于前者的因为写入缓存的时间明显是小于更新数据库的时间的在这么短的时间内发生更新数据库的操作的概率是很小的。
综上所述应该先操作数据库再删除缓存。

四、缓存穿透。

缓存穿透指的是客户端请求的数据在缓存中和数据库都不存在这样的缓存永远不会生效这些请求都会打到数据库。
在这里插入图片描述
短期不一致的原因当查询时没有的id以null存入到redis中假如这时候真正的相同id存入到了数据库在查询时就只能查询到redis中的null值直到TTL过期解决办法是可以手动的在数据库新增的值更新放入redis中。
在这里插入图片描述
布隆过滤器是一种基于哈希的算法将二进制存入到布隆过滤器中但它只是一种概率过率他告诉你不存在的时候一定不存在但是当告诉你存在时却不一定存在。
在这里插入图片描述
要解决缓存穿透业务逻辑就会变成这个样子。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

五、缓存雪崩。

缓存雪崩是指在同一时段大量的缓存key同时失效或者redis服务宕机导致大量的请求到达数据库带来巨大压力。

在这里插入图片描述

六、缓存击穿。

在这里插入图片描述

缓存击穿实现不用考虑缓存击穿的问题
在这里插入图片描述
在这里插入图片描述
互斥锁
在这里插入图片描述
获取锁和释放锁的逻辑代码实现
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
因为就算抛异常也要释放锁所以把释放锁的代码放在finally中。
在这里插入图片描述

逻辑过期实现

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: redis