Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理。它支持字符串、哈希表、列表、集合、有序集合,位图,hyperloglogs等数据类型。内置复制、Lua脚本、LRU收回、事务以及不同级别磁盘持久化功能,同时通过Redis Sentinel提供高可用,通过Redis Cluster提供自动分区。
事务的本质是一组命令集合,一个事务的所有命令都会被序列化,在事务执行的过程会按照顺序执行
一次性、顺序性,排他性!执行一些命令!
所有的命令在事务中并没有直接被执行,只有发起执行命令的时候才会执行。
Redis 单条命令是保存原子性的,但是事务不保证原子性!
redis的事务:
- 开启事务 multi
- 命令入队
- 执行事务 exec
multi # 开启事务
set k1 v1 # 不执行 # 输出QUEUED
set k2 v2 # 不执行 # 输出QUEUED
get k2 # 不执行 # 输出QUEUED
set k3 v3 # 不执行 # 输出QUEUED
exec # 执行事务 # 输出QUEUED
# 输出
# 1) OK
# 2) OK
# 3) “v2”
# 4) OK
放弃任务(未执行的事务)
multi # 开启事务
set k1 v1 # 不执行 # 输出QUEUED
set k2 v2 # 不执行 # 输出QUEUED
get k2 # 不执行 # 输出QUEUED
set k3 v3 # 不执行 # 输出QUEUED
DISCARD # 取消事务,事务队列中的命令都不会执行
错误:
- 编译型异常
命令错误 类似于编译错误,无法执行命令 - 运行时异常
如果事务队列中存在语法错误,那么执行命令的时候其他命令可以正常执行!错误命令会抛出异常
# 编译型异常
multi # 开启事务
set k1 v1 # 不执行 # 输出QUEUED
set k2 v2 # 不执行 # 输出QUEUED
get k2 # 不执行 # 输出QUEUED
set k3 v3 # 不执行 # 输出QUEUED
getset k3 #错误命令 #输出error 编译型异常
set k4 v4 # 不执行 # 输出QUEUED
exec # 会输出error,所有的命令都不会执行
#运行型异常
multi # 开启事务
set k1 v1 # 不执行 # 输出QUEUED
incr k1 # k1 是字符串不能自增
set k2 v2 # 不执行 # 输出QUEUED
get k2 # 不执行 # 输出QUEUED
set k3 v3 # 不执行 # 输出QUEUED
getset k3 #错误命令 #输出error 编译型异常
set k4 v4 # 不执行 # 输出QUEUED
exec # 输出某一error,其他的命令继续执行