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

相关内容

热门资讯

wpk有外挂!wpk到底有没有... wpk有外挂!wpk到底有没有辅助(透视)外挂透视挂辅助工具(从前有挂);软件透明挂更新新赛季,主要...
aapoker俱乐部!aapo... aapoker俱乐部!aapoker有手游版吗,(aapoker德州线上)一直有挂(详细辅助科技教程...
wpk俱乐部!微扑克发牌规律性... wpk俱乐部!微扑克发牌规律性总结(透视)外挂透明挂辅助app(竟然真的是有挂);小薇(透视辅助)致...
aapoker有挂!AA PO... aapoker有挂!AA POKER下载软件,(aapoker透明挂)一贯真的有挂(详细辅助透牌教程...
wpk透明挂!wpk俱乐部会员... 此外,数据分析德州()辅助神器app还具备辅助透视行为开挂功能,通过对客户透明挂的深入研究,你可以了...
aapoker辅助!aa扑克有... 1、aapoker辅助!aa扑克有挂吗,(aapoker开发)起初存在有挂(详细辅助AI教程)(UU...
wpk ai辅助!wpk俱乐部... wpk ai辅助!wpk俱乐部管理后台(透视)外挂透明挂辅助挂(切实是有挂);1分钟了解详细教程(微...
aapoker透明挂!Aapo... aapoker透明挂!Aapoker app,(aa扑克智能)先前是真的有挂(详细辅助AI教程)是由...
wpk透明挂!wpk发牌为什么... wpk透明挂!wpk发牌为什么这么离谱(透视)外挂透明挂辅助app(原来是真的有挂);支持2-10人...
aapoker有挂!aapok... aapoker有挂!aapoker怎么设置牌局,(aa poker辅助软件)确实真的有挂(详细辅助技...