redis的事务(部分支持事务)

2020-06-15  本文已影响0人  码农小钰

redis的事务是一次执行多个命令,本质是一组命令的集合.一个事务中的所有命令都会序列化,按照顺序地串行话执行而不会被其他命令插入,不许加塞.

image.png
redis的常用命令
image.png
image.png
watch指令,类似悲观锁,事务提交时如果key的值被别的客户端改变,这个事务队列都不会执行通过watch指令在事务执行之前监控了多个keys,倘若在watch之后又如何key的值发生了改变,execml执行的事务都将被放弃,同时返回Nullmulti-bulk应答通知调用者事务执行失败
image.png
redis事务的三阶段和三特性:
redis三阶段
开启事务: multi
入队:将多个命令入队到事务中,接到这些命令并不会立即执行,而是放到等待执行事务的队列中
执行:有EXEC命令触发事务
特性:1.单独的隔离操作:事务中的所有命令都会序列化,按顺序地执行.事务在执行的过程中不会被其他客户端发送过来的命令所打断
2.没有隔离级别的概念:队列中的命令没有提交之前都不会实际的被执行,因为事务提交前都不会被实际的执行,也就不存在"事务内的查询要看到事务里的更新,在事务外查询不能看到"
3.不保证原子性:redis同一个事务中如果有一条命令执行失败,其后的命令仍然会被执行不会回滚.
上一篇 下一篇

猜你喜欢

热点阅读