zoukankan      html  css  js  c++  java
  • 【redis专题(9)】事务

    Redis支持简单的事务,所谓简单是因为其不支持回滚(回滚是用队列模仿的),与mysql有以下区别

    rollback与discard的区别:
    如果已经成功执行了2条语句, 第3条语句出错
    Rollback后,前2条的语句影响消失。
    discard只是取消队列,并非回滚。要用在exec前面;

    在mutil后面的语句中, 语句出错可能有2种情况:

    1: 语法就有问题,
    这种,exec时,报错, 所有语句得不到执行

    2: 语法本身没错,但适用对象有问题. 比如 zadd 操作list对象
    Exec之后,会执行正确的语句,并跳过有不适当的语句.
    (如果zadd操作list这种事怎么避免? 这一点,由程序员负责)

    Example

    127.0.0.1:6379> multi #开启事务
    OK
    
    127.0.0.1:6379> decrby zz 100
    QUEUED
    
    127.0.0.1:6379> incrby xx 100
    QUEUED
    
    127.0.0.1:6379> exec
    1) (integer) 900
    2) (integer) 900
    
    127.0.0.1:6379> multi
    OK
    
    127.0.0.1:6379> decrby zz 100
    QUEUED
    
    127.0.0.1:6379> sadd zz haha #语法本身没有错,那整个事务中的语句都会执行;
    QUEUED
    
    127.0.0.1:6379> exec
    1) (integer) 800 
    2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
    

    悲观锁与乐观锁

    场景如下:

    我正在买票
    Ticket -1 , money -100
    而票只有1张, 如果在我multi之后,和exec之前, 票被别人买了---即ticket变成0了.
    我该如何观察这种情景,并不再提交

    • 悲观的想法: 世界充满危险,肯定有人和我抢, 给 ticket上锁, 只有我能操作. [悲观锁]
    • 乐观的想法: 没有那么多人和我抢,因此,我只需要注意,在下单之前看看有没有人更改ticket的值就可以了 [乐观锁]

    Redis的事务中,启用的是乐观锁,只负责监测key没有被改动.具体的命令:watch命令

    watch key1 key2  ... keyN
    

    作用: 监听key1 key2..keyN有没有变化,如果有变, 则事务取消

    unwatch 
    

    作用: 取消所有watch监听

    redis 127.0.0.1:6379> watch ticket
    OK
    redis 127.0.0.1:6379> multi
    OK
    redis 127.0.0.1:6379> decr ticket
    QUEUED
    redis 127.0.0.1:6379> decrby money 100
    QUEUED
    redis 127.0.0.1:6379> exec #在exec之前该数据在其他session有改动就取消事务,返回nil
    (nil)  
    redis 127.0.0.1:6379> get ticket
    "0"
    redis 127.0.0.1:6379> get money
    "200"
    
  • 相关阅读:
    四种数据库随机获取10条数据的方法
    古诗词
    一份 Spring Boot 项目搭建模板
    2020年只剩两个月,今年你是怎么过的?
    关于使用LocalDateTime进行存储,时间相差比较多的问题。
    项目中常用的19条MySQL优化
    SpringBoot注解大全
    JDK8的LocalDateTime用法
    linux代理上网5分钟搞定
    SQL简单语句作用
  • 原文地址:https://www.cnblogs.com/nixi8/p/6702853.html
Copyright © 2011-2022 走看看