加过期时间设定
通过“set…nx...ex…”命令,将加锁、过期命令编排到一起,它们是原子操作了,可以避免死锁。
当过期时间设置小于线程执行时间时,因锁过期被其他线程重新获取,前面的线程删掉的是其他线程的锁。
解决:
redisson组件已经解决。
并发量大的时候,会降低系统并发性能。
解决:
1、先删缓存,再删数据库,再延迟(避免删除之前读到数据老数据的若干线程还没有将结果写入缓存,此时就会出现无效删除)删一次缓存;
2、先删数据库,再删缓存(如果删除失败支持重试(可以发送给MQ))
删除缓存的操作可以通过cannal监听数据更新问题通知springboot应用进行删除来实现。
总结:推荐使用方法2,因为方法1中的延迟删除也可能会失败。相对来说方法2更简单有效。
下一篇:分布式缓存与Redis