悲观锁
很悲观,觉得无论什么时候都会出问题,无论什么都会枷锁
乐观锁
很乐观,觉得无论什么时候都不会出现问题,所以不会上锁 ! 更逊数据的时候去判断一下在此期间是否有人修改过这个数据
监视器
- 获取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)
执行失败
执行失败应该怎么做
待补充!