思路:
使用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的值被更改事务执行就会失败