redis锁的应用

思路:

使用redis的特性setnx key value   如果不存在就设置 key 和value,操作完成后del key 删除key ,让下一个线程去获取这个key

设置好了以后当第二个线程去 setnx的时候,会返回错误,保证redis数据同时只能被一个线程访问

SET key value [EX seconds] [PX milliseconds] [NX|XX]

setnx 有个问题,如果在操作过程中程序崩溃,则会变成死锁,所以添加一个超时设置

set name  123 ex 20 nx

设置name123 超时为 20 秒,  nx表示 如果key不存在就执行set, xx表示 如果key存在就执行set

但是同样这个也会存在一个问题 ,就是如果超时时间内用户没有操作完成,key会自动过期,还是会产生数据不安全

redis的watch特性

watch  key    就是观察一个key,如果key被修改则redis事务操作失败

watch name;

multi

set name 20 

exec

这是exec会操作失败,

不管不是在本线程操作,或者其他线程操作,如果key的值被更改事务执行就会失败

发布了166 篇原创文章 · 获赞 26 · 访问量 15万+

猜你喜欢

转载自blog.csdn.net/qq_28710983/article/details/104608395