Redis学习(3)redis事务、乐观锁

    技术2024-03-12  58

    1、redis事务

    Redis单条命令时保证原子性,但事务不保证原子性 Redis事务没有隔离级别的概念,只有发起执行命令的时候才会执行

    1.1正常执行事务

    multi==>开启事务 …输入相关执行代码 exec==>执行事务 discard==>放弃、取消事务(事务队列中的命令都不会被执行) 多条命令入栈可保证同时成功同时失败 如果命令出错,所有入队指令都不会执行 如果运行时出错,但没有语法错误,那么其他入队命令是可以正常执行的==>所以事务不保证原子性

    1.2 监控

    悲观锁:

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

    乐观锁:

    很乐观,认为什么时候都不会出问题,所以不会上锁!更新数据的时候去判断一下,在此期间是否有人修改过这个数据,获取version更新的时候比较version
    1.3 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 OK 127.0.0.1:6379> multi OK 127.0.0.1:6379> decrby money 20 QUEUED 127.0.0.1:6379> incrby money 50 QUEUED 127.0.0.1:6379> exec 1) (integer) 80 2) (integer) 130 127.0.0.1:6379>

    事务操作执行失败,多开虚拟机进行操作,下侧窗口先加上监视,上侧窗口先行操作,然后执行下侧事务 watch可以当作redis的乐观锁使用!!!

    事务执行失败后,需要重新加上监视,实现事务控制
    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) 10
    Processed: 0.122, SQL: 9