Redis 中级学习,学习使你快乐05(redis实现乐观锁)
Posted 偶像java练习生
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis 中级学习,学习使你快乐05(redis实现乐观锁)相关的知识,希望对你有一定的参考价值。
监控! watch (面试常问)
悲观锁:
- 很悲观,认为什么时候都会出问题,无论干什么都会加锁!会影响性能的!
乐观锁: - 很乐观,认为什么时候都不会出问题,所以不会上锁!更新数据的时候去判断一下,在此期间是否有人修改过这个数据,相对性能会好很多。
- 拓展:mysql 通过获取 version 来做乐观锁!(mysql)
- 更新的时候比较version
Redis 监视测试
正常执行成功!
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>
127.0.0.1:6379> INCRBY out 20
QUEUED
127.0.0.1:6379> exec
1) (integer) 80
2) (integer) 20
当多条线程来更改money 时,我们用watch 来监控这个money 的值,最后执行exec 事务时,会执行失败。
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>
127.0.0.1:6379> INCRBY out 20
QUEUED
127.0.0.1:6379> exec
1) (integer) 80
2) (integer) 20
127.0.0.1:6379> watch 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)
//打开另一个窗口执行,线程执行如下命令:
127.0.0.1:6379> get money
"80"
127.0.0.1:6379> set money 1000
OK
如果修改失败,获取最新的值就好了
以上是关于Redis 中级学习,学习使你快乐05(redis实现乐观锁)的主要内容,如果未能解决你的问题,请参考以下文章