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更简单有效。

相关内容

热门资讯

透视模拟器"德普之星... 透视模拟器"德普之星怎么设置埋牌"详细辅助实用技巧(一贯真的有挂)亲,关键说明,德普之星怎么设置埋牌...
两分钟了解!麻雀智能辅助软件,... 两分钟了解!麻雀智能辅助软件,大巴杭州辅助(本来真的是有挂)1、游戏颠覆性的策略玩法,独创攻略技巧玩...
透视软件!hhpoker真的有... 透视软件!hhpoker真的有透视吗(透视)永久脚本辅助器(详细辅助详细教程)1、全新机制【hhpo...
透视新版"聚星ai辅... 透视新版"聚星ai辅助工具下载"详细辅助新2025教程(本来存在有挂)1、许多玩家不知道聚星ai辅助...
透视教程!pokermaste... 透视教程!pokermaster修改器(透视)本来存在有挂(详细辅助wepoke教程)1、许多玩家不...
九分钟了解!小程序财神十三张祈... 九分钟了解!小程序财神十三张祈福,长城互娱辅助(确实真的是有挂)1、这是跨平台的小程序财神十三张祈福...
透视科技!wepoker底牌透... 透视科技!wepoker底牌透视(透视)永久脚本辅助助手(详细辅助透视教程);所有人都在同一条线上,...
透视计算"wepok... 透视计算"wepoker透视辅助下载"详细辅助必胜教程(总是真的有挂)1、透视计算"wepoker透...
透视科技!德州局HHpoker... 透视科技!德州局HHpoker透视脚本(透视)一贯真的是有挂(详细辅助技巧教程);1、完成的残局,帮...
第8分钟了解!中至余干510k... 第8分钟了解!中至余干510k控制输赢,闲来贵州黑科技辅助软件(好像存在有挂)1、构建自己的闲来贵州...