Redis#架构师面试题
创始人
2024-11-17 19:32:33
0

1、Redis锁存在哪些问题及如何解决?

1、死锁问题

加过期时间设定

2、原子性问题

通过“set…nx...ex…”命令,将加锁、过期命令编排到一起,它们是原子操作了,可以避免死锁。

3、释放其他线程的锁问题

当过期时间设置小于线程执行时间时,因锁过期被其他线程重新获取,前面的线程删掉的是其他线程的锁。

解决:

  • 通过在value添加线程标识来解决,释放锁的时候进行线程标识判断,只删除属于自己的锁。这里又存在了原子性的问题,可以通过lua脚本或者直接使用Redisson框架解决。
  • 使用看门狗进行锁续期

4、可重入锁问题

redisson组件已经解决。

5、锁竞争问题

并发量大的时候,会降低系统并发性能。

解决:

  • 锁细化;
  • 乐观锁;
  • 读写锁;

2、缓存和数据库的数据一致性怎么解决?

1、先删缓存,再删数据库,再延迟(避免删除之前读到数据老数据的若干线程还没有将结果写入缓存,此时就会出现无效删除删一次缓存;

2、先删数据库,再删缓存(如果删除失败支持重试(可以发送给MQ))

删除缓存的操作可以通过cannal监听数据更新问题通知springboot应用进行删除来实现。

总结:推荐使用方法2,因为方法1中的延迟删除也可能会失败。相对来说方法2更简单有效。

相关内容

热门资讯

透视数据!hhpoker辅助器... 透视数据!hhpoker辅助器(透视)好像真的有挂,揭秘教程(有挂网页版)-哔哩哔哩小薇(透视辅助)...
透视挂!poker辅助器免费安... 透视挂!poker辅助器免费安装,hhpoker辅助软件下载,项目教程(发现有挂)-哔哩哔哩1)po...
3分钟关于!wepoker亲友... 3分钟关于!wepoker亲友圈有用吗(透视)真是存在有挂,技巧教程(的确有挂)-哔哩哔哩1、3分钟...
透视模拟器!wpk私人局有透视... 透视模拟器!wpk私人局有透视吗(透视)原来存在有挂,玩家教你(有挂机制)-哔哩哔哩1、上手简单,内...
透视系统!aapoker发牌逻... 透视系统!aapoker发牌逻辑,wpk辅助器是真的吗,法子教程(有挂细节)-哔哩哔哩1、wpk辅助...
第一分钟辅助!wepoker新... 第一分钟辅助!wepoker新号好一点吗(透视)确实存在有挂,微扑克教程(果真有挂)-哔哩哔哩wep...
透视代打!pokermaste... 透视代打!pokermaster破解版(透视)真是是有挂,详细教程(有挂模拟器)-哔哩哔哩1、下载好...
透视玄学!德普之星app安卓版... 透视玄学!德普之星app安卓版破解版,wepoker私局代打,讲义教程(真是有挂)-哔哩哔哩1、超多...
第一分钟了解!德州来玩辅助器(... 第一分钟了解!德州来玩辅助器(透视)好像是真的挂,必赢方法(有挂秘笈)-哔哩哔哩1、德州来玩辅助器a...
透视新版!wepoker可以免... 透视新版!wepoker可以免费玩吗(透视)一直有挂,专业教程(有挂规律)-哔哩哔哩1、下载好wep...