监控(watch)
悲观锁:很悲观,认为什么时候都会出现问题,无论做什么都会加锁!
乐观锁:很乐观,认为什么时候都不会出现问题,所以不会上锁!更新数据的时候回去判断一下,在此期间是否有人修改过这个数据。
获取version,然后更新的时候比较version。
redis的监视测试
正常执行的情况
127.0.0.1:6379> set money 100
OK
127.0.0.1:6379> set outmoney 0
OK
127.0.0.1:6379> mulit
(error) ERR unknown command `mulit`, with args beginning with:
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decrby money 20
QUEUED
127.0.0.1:6379> incrby outmoney 20
QUEUED
127.0.0.1:6379> get money
QUEUED
127.0.0.1:6379> get incrby
QUEUED
127.0.0.1:6379> exec
1) (integer) 80
2) (integer) 20
3) "80"
4) (nil)
127.0.0.1:6379> get outmonry
(nil)
127.0.0.1:6379> get outmoney
"20"
127.0.0.1:6379>
非正常执行,两个客户端
客户端1:监视money并且提交事务,在提交事务之前,客户端2给money加上1000,然后在提交事务,我们发现事务执行失败
127.0.0.1:6379> watch money
OK
127.0.0.1:6379> decrby key 10
(integer) -10
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decrby money 10
QUEUED
127.0.0.1:6379> incrby outmoney 10
QUEUED
127.0.0.1:6379> get money
QUEUED
127.0.0.1:6379> get outmoney
QUEUED
127.0.0.1:6379> exec
(nil)
unwatch #如果发现事务执行失败就行解除监视,然后再次监视
watch money
客户端2
127.0.0.1:6379> incrby money 1000
(integer) 1080
127.0.0.1:6379>
[root@localhost ~]#