悲观锁:
很悲观,认为什么时候都会出问题,无论做什么都会加锁!
乐观锁:
很乐观,认为什么时候都不会出问题,所以不会上锁! 更新数据的时候去判断一下,在此期间是否有人修改过这个数据,
获取version
更新的时候比较 version
edis测监视测试
# 正常执行成功!
127.0.0.1:6379> set money 100 OK
127.0.0.1:6379> set out 0 OK
127.0.0.1:6379> watch money # 监视 money 对象
OK
127.0.0.1:6379> multi # 事务正常结束,数据期间没有发生变动,这个时候就正常执行成功!
OK
127.0.0.1:6379> DECRBY money 20 QUEUED
127.0.0.1:6379> INCRBY out 20 QUEUED
127.0.0.1:6379> exec
1)(integer) 80
2)(integer) 20
# 测试多线程修改值 , 使用watch 可以当做redis的乐观锁操作!
127.0.0.1:6379> watch money # 监视 money OK
127.0.0.1:6379> multi OK
127.0.0.1:6379> DECRBY money 10 QUEUED
127.0.0.1:6379> INCRBY out 10 QUEUED
127.0.0.1:6379> exec # 执行之前,另外一个线程,修改了我们的值,这个时候,就会导致事务执行失
败!
(nil)
如果修改失败,获取最新的值就好