redis 设置分布式锁要避免死锁

1. jedis 中 setnx key value 虽然可以处理同步问题 (setnx 有返回值 1是key不存在把它设置进去,0是key已经存在了)
但是 setnx设置完后 程序的下一步 有可能挂掉 那么 这个key就永远留在redis中了,集群中的其它机器 永远就进入不了要执行的逻辑,
然而即使 在它的下一步 加入过期时间又有可能会出现问题,因为如果走不到下一步呢?同样会出现该问题(就会造成死锁)

2. 通过 jedis.set(String key, String value, String nxxx, String expx, int time) 方法可以解决上面的问题。

redis 本身是单线程所以是线程安全的,但是不代表业务就是线程安全的,所以要是用redis 的分布式锁

 

参考: https://www.cnblogs.com/JJJ1990/p/10496850.html
    https://blog.csdn.net/KingCat666/article/details/77892176

posted on 2019-04-29 11:15  gfaraway  阅读(6863)  评论(0编辑  收藏  举报

导航