zoukankan      html  css  js  c++  java
  • Redis_监控

    监控

    1. 乐观锁和悲观锁

    • 悲观锁

      • 很悲观, 认为什么时候都会出问题
      • 无论做什么, 都会加锁
    • 乐观锁

      • 很乐观, 认为什么时候都不会出问题
      • 不会上锁, 更新数据的时候去判断一下, 在此期间, 是否有人修改过这个数据 (version)

    2. Redis的监视测试

    1. 正常执行成功

    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 
    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
    

    监视 money 对象

    事务正常结束, 数据期间没有发生变动, 这个时候就正常执行成功!

    2. 执行失败

    使用 watch 可以当做 Redis 的乐观锁操作

    在线程执行事务的过程中, 另一个线程修改了加锁的对象

    事务

    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> get money
    "80"
    127.0.0.1:6379> set money 1000
    OK
    

    插队后事务执行的结果

    127.0.0.1:6379> exec
    (nil)
    

    3. 执行失败后的操作

    127.0.0.1:6379> unwatch
    OK
    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
    1) (integer) 990
    2) (integer) 30
    
    • unwatch 解锁

    • 如果在执行 watch 命令之后, exec 命令或 discard 命令先被执行了的话, 那么就不需要再执行 unwatch了

    • 如果修改失败, 获得最新值即可

  • 相关阅读:
    C#-项目属性设置
    SQL--连接字符串总结
    希尔排序实现(不太满意)
    选择排序实现
    用位运算实现 | 与 ^ 的功能
    如何初始化一个定长List<T>
    线程池与Threadlocal
    常用类
    基本数据类型介绍
    eclipse快捷键
  • 原文地址:https://www.cnblogs.com/wang-sky/p/13858134.html
Copyright © 2011-2022 走看看