redis 事务
redis 事务的本质:一组命令的集合!一个事务中的所有命令都会被序列化,在事务执行过程中,会按照顺序执行!一次性,顺序性,排他性!
- redis 事务没有隔离级别的概念
- 所有的命令在事务中,并没有直接被执行!只有发起执行命令(exec)的时候才会执行
- redis 单条命令是保证原子性的,但是事务不保证原子性
常用命令
命令 | 说明 |
---|---|
multi | 开启事务 |
exec | 执行事务 |
discard | 取消事务,事务队列中所有命令都不会执行 |
redis 事务异常
- 编译型异常,代码或命令有错误,队列中所有命令都不会执行
- 执行时异常,代码正确,运行错误(如 1/0 错误),只出错命令不执行,其他命令正常执行
示例
## 正常执行事务
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> set key2 value2
QUEUED
127.0.0.1:6379> get key1
QUEUED
127.0.0.1:6379> set key3 value3
QUEUED
127.0.0.1:6379> exec
1) OK
2) OK
3) "value1"
4) OK
127.0.0.1:6379> get key3
"value3"
## 取消事务
127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> set key2 value2
QUEUED
127.0.0.1:6379> discard
OK
127.0.0.1:6379> get key1
(nil)
127.0.0.1:6379> get key2
(nil)
## 编译型异常
127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> settttt key2 value2
(error) ERR unknown command 'settttt'
127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get key1
(nil)
127.0.0.1:6379> get key2
(nil)
## 执行时异常
127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> set mykey hello
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> incr mykey
QUEUED
127.0.0.1:6379> set key2 value2
QUEUED
127.0.0.1:6379> exec
1) OK
2) (error) ERR value is not an integer or out of range ## mykey为String类型,不能自增,执行出错,其他命令执行正常
3) OK
127.0.0.1:6379> get mykey
"hello"
127.0.0.1:6379> get key1
"value1"
127.0.0.1:6379> get key2
"value2"