Redis事务

Redis事务本质

一组命令的集合!一个事务中所有命令都会被顺序化,在事务执行过程中,会按照顺序执行。

一次性、顺序性、排他性!执行一系列的命令


Reis事务没有隔离级别的概念!整个事务不保证原子性。先开启事务,再将命令放入队列,执行exec命令时才执行事务!


所有的命令在事务中,并没有直接被执行!只有发起执行命令的时候才会执行!Exec


Redis单条命令是保证原子性的,但事务不保证原子性


Redis事务异常一般有两种情况:


       1.编译行异常,即事务中有命令格式(代码有问题,命令错误)有问题,编译时都不通过,所有命令都不会执行;


       2.运行时异常,事务中命令语句存在语法性,那么执行命令时,其他命令可以正常执行(这里也可以看出Redis事务不保证原子性),错误命令抛出异常,其他命令正常执行


Redis事务顺序


——开启事务(multi)


——命令入队(写命令语句)


——执行事务(exec)


Redis事务测试

关于基础命令不了解的,可以查看我前面关于Redis基础的博客内容。


127.0.0.1:6379> multi            #开启事务
OK
127.0.0.1:6379(TX)> set k1 v1      #命令语句入队列
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> mget k1 k2
QUEUED
127.0.0.1:6379(TX)> set k3 v3
QUEUED
127.0.0.1:6379(TX)> exec    #执行事务
1) OK
2) OK
3) 1) "v1"
   2) "v2"
4) OK

127.0.0.1:6379> multi          #开启事务
OK
127.0.0.1:6379(TX)> set k4 v4
QUEUED
127.0.0.1:6379(TX)> discard     #放弃事务
OK
127.0.0.1:6379> get k4                #事务队列中命令都不会被执行
(nil)

//编译行异常,即事务中有命令格式(代码有问题,命令错误)有问题,编译时都不通过,所有命令都不会执行
127.0.0.1:6379> multi    #开启事务
OK
127.0.0.1:6379(TX)> set k1 v1
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> get k1 k2    #get多个key,语法错误
(error) ERR wrong number of arguments for 'get' command
127.0.0.1:6379(TX)> mget k1 k2
QUEUED
127.0.0.1:6379(TX)> set k3 v3
QUEUED
127.0.0.1:6379(TX)> exec
(error) EXECABORT Transaction discarded because of previous errors.    #整个事务都失败了,都不执行

//运行时异常,事务中命令语句存在语法性,那么执行命令时,其他命令可以正常执行(这里也可以看出Redis事务不保证原子性),错误命令抛出异常
127.0.0.1:6379> multi                         #开启事务
OK
127.0.0.1:6379(TX)> set k1 v1        #命令入队
QUEUED
127.0.0.1:6379(TX)> incr k1            #命令入队(字符串不能自增)
QUEUED
127.0.0.1:6379(TX)> get k1            #命令入队
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> exec
1) OK
2) (error) ERR value is not an integer or out of range     #结果抛出异常
3) "v1"
4) OK
127.0.0.1:6379> get k1                        #其中一条命令报错了,其他命令还是成功了
"v1"
127.0.0.1:6379> get k2
"v2"