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)一贯真的有挂(详细模拟器多开)1、每一步都需要思考,不同水...
透视了解!wepoker钻石怎... 透视了解!wepoker钻石怎么看底牌,wepoker有插件吗(详细破解辅助插件)1、首先打开wep...
透视存在!aa poker辅助... 透视存在!aa poker辅助,sohoo poker辅助(果然真的有挂)1、游戏颠覆性的策略玩法,...
透视免费!aapoker ai... 透视免费!aapoker ai插件(透视)透视插件(一贯真的是有挂)1、实时aapoker ai插件...
透视系统!wpk辅助,(WPk... 透视系统!wpk辅助,(WPk)真是真的有挂(详细辅助购买)1)wpk辅助辅助挂:进一步探索wpk辅...
透视玄学!wepoker究竟有... 透视玄学!wepoker究竟有没有透视,wepoker辅助器(详细有透视方法)1)wepoker究竟...
透视app!佛手在线大菠萝技巧... 透视app!佛手在线大菠萝技巧,epoker有透视吗(好像真的是有挂);1、让任何用户在无需佛手在线...
透视系统!aapoker怎么控... 透视系统!aapoker怎么控制牌(透视)透视软件(都是真的是有挂);1、进入到aapoker怎么控...
透视辅助!wpk德州局透视,(... 透视辅助!wpk德州局透视,(WPK)本来存在有挂(详细免费辅助)1)wpk德州局透视辅助挂:进一步...
透视最新!wepokerplu... 透视最新!wepokerplus作弊,黑侠破解wepoker(详细破解器激活码)1、黑侠破解wepo...