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实现乐观锁)的主要内容,如果未能解决你的问题,请参考以下文章

Redis 中级学习,学习使你快乐05(redis实现乐观锁)

Redis 中级学习,学习使你快乐04(redis事务)

Redis 中级学习,学习使你快乐04(redis事务)

Redis 中级学习,学习使你快乐04(redis事务)

Redis 入门学习,学习使我快乐01

Redis 入门学习,学习使我快乐01