【Redis】redis事务的特性?真的没有原子性吗?

866 阅读1分钟

Redis事务

事务的四大特性我们都知道是ACID:1. 原子性2. 一致性3. 隔离性4. 持久性

它们的定义如下:

1. 原子性:事务是程序执行的最小单位,事务中的命令要么全部一起执行,要么就都不执行(如果有一个命令不能执行,那所有命令不能执行)。 2. 一致性:数据在事务执行前后保持一致,所有事物对数据的读取结果相同。 3. 隔离性:事务在提交前,对其他事务不可见。 4.持久性:事务一旦提交,数据会永久保存,即使系统崩溃数据也不丢失。

由于Redis事务不支持回滚,很多人说因此Redis事务不满足原子性,真的吗?看看官方文档:

redis.io/topics/tran… 在这里插入图片描述

Either all of the commands or none are processed, so a Redis transaction is also atomic.

因为部分它满足原子性的定义,要么事务中的指令要么一起执行,要么就都不执行。

因此Redis事务是原子性的,或者说它做到了它认为的原子性。但是注意:Redis事务中如果有一个命令不能执行,其他命令还是会照常执行。

Redis事务是满足隔离性的。

Redis持久化可以保证部分的持久性。

Redis事务不满足一致性。一致性是事务执行前后都有数据的一致,而Redis不支持回滚。

参考

redis.io/topics/tran…