Redis-乐观锁->监视器

45 阅读1分钟

悲观锁

很悲观,觉得无论什么时候都会出问题,无论什么都会枷锁

乐观锁

很乐观,觉得无论什么时候都不会出现问题,所以不会上锁 ! 更逊数据的时候去判断一下在此期间是否有人修改过这个数据

监视器

  • 获取version
  • 更新的时候比较version

监视器测试

正常执行成功

127.0.0.1:6379> set moeny 200
OK
127.0.0.1:6379> set out 0
OK
127.0.0.1:6379> watch money
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> decrby money 20
QUEUED
127.0.0.1:6379(TX)> incrby out 20
QUEUED
127.0.0.1:6379(TX)> exec
1) (integer) -20
2) (integer) 20

测试多线程修改值,使用watch当作redis的乐观锁

线程一

127.0.0.1:6379> set money 200
OK
127.0.0.1:6379> set out 0
OK
127.0.0.1:6379> watch money
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> decrby money 20
QUEUED
127.0.0.1:6379(TX)> incrby out 20
QUEUED

到这里还没有执行 被另一个线程拿到执行时间

线程二

127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> set money 500
QUEUED
127.0.0.1:6379(TX)> exec
1) OK

这里修改了 money的值 这时候线程一拿到了执行时间

127.0.0.1:6379> set money 200
OK
127.0.0.1:6379> set out 0
OK
127.0.0.1:6379> watch money
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> decrby money 20
QUEUED
127.0.0.1:6379(TX)> incrby out 20
QUEUED
127.0.0.1:6379(TX)> exec
(nil)

执行失败

执行失败应该怎么做

待补充!