Redis保证了ACID原则

原子性

Redis中的事务,如果出现命令错误比如指令不存在,那么整个事务中的命令都不会被执行,但如果是语法性错误,那么除了错误指令抛出异常,其他指令正常执行。
此外,Redis单条指令也是保证原子性的,比如添加多个元素,其中一个出现错误,那么都不会添加成功。

一致性

  • 入队错误: 如果一个事务在入队命令的过程中,出现了命令不存在,或者命令的格式不正确等情况,那么Redis将拒绝执行这个事务
  • 执行错误: 即使在事务的执行过程中发生了错误,服务器也不会中断事务的执行,它会继续执行事务中余下的其他命令,并且已执行的命令(包括执行命令所产生的结果)不会被出错的命令影响
  • 服务器停机: 如果Redis服务器在执行事务的过程中停机,那么根据服务器所使用的持久化模式,可能有以下情况出现:
    1.如果服务器运行在无持久化的内存模式下,那么重启之后的数据库将是空白的,因此数据总是一致的
    2.如果服务器运行在RDB模式下,那么在事务中途停机不会导致不一致性,因为服务器可以根据现有的RDB文件来恢复数据,从而将数据库还原到一个一致的状态。如果找不到可供使用的RDB文件,那么重启之后的数据库将是空白的,而空白数据库总是一致的
    3.如果服务器运行在AOF模式下,那么在事务中途停机不会导致不一致性,因为服务器可以根据现有的AOF文件来恢复数据,从而将数据库还原到一个一致的状态。如果找不到可供使用的AOF文件,那么重启之后的数据库将是空白的,而空白数据库总是一致的

隔离性

Redis是单线程模型,所以总是以串行方式执行,也自然具有隔离性

持久性

Redis是基于内存存储的,但是他提供的持久化rdb,aof操作,也保证了数据的持久性。

猜你喜欢

转载自blog.csdn.net/AIJXB/article/details/115049814