个人做视频网站视频储存,迅博威网站建设,工程施工公司,可以看封禁网站的浏览器1、Redis锁存在哪些问题及如何解决#xff1f;
1、死锁问题
加过期时间设定
2、原子性问题
通过“set…nx...ex…”命令#xff0c;将加锁、过期命令编排到一起#xff0c;它们是原子操作了#xff0c;可以避免死锁。
3、释放其他线程的锁问题
当过期时间设置小于线程…1、Redis锁存在哪些问题及如何解决
1、死锁问题
加过期时间设定
2、原子性问题
通过“set…nx...ex…”命令将加锁、过期命令编排到一起它们是原子操作了可以避免死锁。
3、释放其他线程的锁问题
当过期时间设置小于线程执行时间时因锁过期被其他线程重新获取前面的线程删掉的是其他线程的锁。
解决
通过在value添加线程标识来解决释放锁的时候进行线程标识判断只删除属于自己的锁。这里又存在了原子性的问题可以通过lua脚本或者直接使用Redisson框架解决。使用看门狗进行锁续期
4、可重入锁问题
redisson组件已经解决。
5、锁竞争问题
并发量大的时候会降低系统并发性能。
解决
锁细化乐观锁读写锁
2、缓存和数据库的数据一致性怎么解决
1、先删缓存再删数据库再延迟避免删除之前读到数据老数据的若干线程还没有将结果写入缓存此时就会出现无效删除删一次缓存
2、先删数据库再删缓存如果删除失败支持重试可以发送给MQ
删除缓存的操作可以通过cannal监听数据更新问题通知springboot应用进行删除来实现。
总结推荐使用方法2因为方法1中的延迟删除也可能会失败。相对来说方法2更简单有效。