1.事务: 一组命令的集合,一个事务中的所有命令都被序列化,在事务执行过程会按照顺序执行; redis中单条命令具有原子性,但事务本身不具有原子性.
2.redis事务: 一次性,顺序性,排他性的执行一序列命令
a. 开启事务(multi) b. 命令入队 c. 执行事务( exec), 执行完事务就不存在 d. 放弃事务( discard )
127.0.0.1:6379> multi #开启事务
OK
127.0.0.1:6379> set k1 v1 #命令入队
QUEUED
127.0.0.1:6379> get k1
QUEUED
127.0.0.1:6379> exec #执行事务
1) OK
2) "v1"
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> multi #开启事务
OK
127.0.0.1:6379> set k2 v2
QUEUED
127.0.0.1:6379> discard #放弃事务
OK
127.0.0.1:6379> get k2
(nil)
编译型异常(命令有错) : 事务中的命令都不会被执行
127.0.0.1:6379> multi #开启事务
OK
127.0.0.1:6379> set k3 v3
QUEUED
127.0.0.1:6379> set1 k4 v4 #出错的命令在命令入队时抛异常
(error) ERR unknown command `set1`, with args beginning with: `k4`, `v4`,
127.0.0.1:6379> exec #执行事务时抛异常
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get k3
(nil)
运行时异常 : 事务中命令存在语法错误,那么在执行命令的时候,其他命令正常执行,错误命令抛异常
127.0.0.1:6379> set k5 "v5"
OK
127.0.0.1:6379> multi #开启事务
OK
127.0.0.1:6379> incr k5
QUEUED
127.0.0.1:6379> set k6 v6
QUEUED
127.0.0.1:6379> get k6
QUEUED
127.0.0.1:6379> exec #其他命令正常执行,错误命令抛异常
1) (error) ERR value is not an integer or out of range
2) OK
3) "v6"
127.0.0.1:6379>