前言

提示:本文章是日常学习内容的总结,并非全部原创;仅供大家参考借鉴,并无其他商业用途。Bilibili搜索关注:狂神说
真正在公司中的实践:NoSQL + RDBMS 一起使用才是最强的,阿里巴巴的架构演进!
技术没有高低之分,就看你如何去使用!(提升内功,思维的提高!)
云计算的长征之路:阿里云的这群疯子

Redis-事务概括

Redis 事务本质:一组命令的集合!
一个事务中的所有命令都会被序列化,在事务执行过程的中,会按照顺序执行!
一次性、顺序性、排他性!执行一些列的命令!
Redis事务没有没有隔离级别的概念
所有的命令在事务中,并没有直接被执行!只有发起执行命令的时候才会执行!Exec
Redis单条命令式保存原子性的,但是事务不保证原子性!
redis的事务:
开启事务(multi)
命令入队(…)
执行事务(exec)

正常执行事务

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

放弃事务

# 开启事务 
127.0.0.1:6379> multi 
OK
127.0.0.1:6379> set k1 v1 
QUEUED 
127.0.0.1:6379> set k2 v2 
QUEUED 
127.0.0.1:6379> set k4 v4 
QUEUED 
# 取消事务 
127.0.0.1:6379> DISCARD 
OK
# 事务队列中命令都不会被执行! 
127.0.0.1:6379> get k4 
(nil)

编译型异常

(代码有问题! 命令有错!) ,事务中所有的命令都不会被执行!

127.0.0.1:6379> multi 
OK
127.0.0.1:6379> set k1 v1 
QUEUED 
127.0.0.1:6379> set k2 v2 
QUEUED 
127.0.0.1:6379> set k3 v3 
QUEUED 
127.0.0.1:6379> getset k3     # 错误的命令 
(error) ERR wrong number of arguments for 'getset' command 
127.0.0.1:6379> set k4 v4 
QUEUED 
127.0.0.1:6379> set k5 v5 
QUEUED 
127.0.0.1:6379> exec          # 执行事务报错! 
(error) EXECABORT Transaction discarded because of previous errors. 
127.0.0.1:6379> get k5        # 所有的命令都不会被执行! 
(nil)

运行时异常

如果事务队列中存在语法性错误,那么执行命令的时候,其他命令是可以正常执行的,错误命令抛出异常!

127.0.0.1:6379> set k1 "v1" 
OK
127.0.0.1:6379> multi 
OK
127.0.0.1:6379> incr k1       # 会执行的时候失败! 
QUEUED 
127.0.0.1:6379> set k2 v2 
QUEUED 
127.0.0.1:6379> set k3 v3 
QUEUED 
127.0.0.1:6379> get k3 
QUEUED 
127.0.0.1:6379> exec 
#  虽然第一条命令报错了,但是 依旧正常执行成功了!
1) (error) ERR value is not an integer or out of range  
2) OK
3) OK 
4) "v3" 
127.0.0.1:6379> get k2 
"v2" 
127.0.0.1:6379> get k3 
"v3"
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐