黄东旭关于基础软件产品价值的思考
1505
2023-04-19
一篇文章带你彻底搞懂Redis 事务
Redis 事务简介
Redis 只是提供了简单的事务功能。其本质是一组命令的集合,事务支持一次执行多个命令,在事务执行过程中,会顺序执行队列中的命令,其他客户端提交的命令请求不会插入到本事务执行命令序列中。命令的执行过程是顺序执行的,但不能保证原子性。无法像 MySQL 那样,有隔离级别,出了问题之后还能回滚数据等高级操作。后面会详细分析。
Redis 事务基本指令
Redis 提供了如下几个事务相关的基础指令。
MULTI开启事务,Redis 会将后续命令加到队列中,而不真正执行它们,直到后续使用EXEC来原子化的顺序执行这些命令 EXEC执行所有事务块内的命令 DISCARD取消事务,放弃执行事务块内所有的命令 WATCH监视一个或多个 key,若事务在执行前,这些 key 被其他命令修改,则事务被终端,不会执行事务中的任何命令 UNWATCH取消 WATCH命令对所有 keys 的监视
一般情况下,一个简单的 Redis 事务主要分为如下几个部分:
执行命令MULTI开启一个事务。 开启事务之后,执行命令的多个命令会依次被放入一个队列,放入成功则会返回QUEUED消息。 执行命令EXEC提交事务,Redis 会依次执行队列中的命令,并依次返回所有命令的结果。(若想放弃提交事务,则执行DISCARD)。
下图简单介绍了下 Redis 事务执行的过程:
实例分析
下面我们来通过一些实际具体例子,来体会下 Redis 中的事务。前面我们也说到 Redis 的事务不是正真的事务,是无法完全满足标准事务的ACID特性的。通过下面的例子,我们来看看,Redis 的“破产版”事务到底存在什么问题。
[A]正常执行提交
?
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。