【2023】Redis事务

1.什么是Redis事务

Redis事务是一组命令的集合,这些命令要么全部执行,要么全部不执行。它们被视为一个单独的操作单元,要么完全成功,要么完全失败。
Redis事务可以用来实现ACID属性(原子性、一致性、隔离性、持久性)。

ACID是一组属性的缩写:

1️⃣:原子性,是指一个Redis事务中的所有操作要么全部完成,要么全部不完成;
2️⃣:一致性是指在事务开始和结束时,数据库的状态必须是一致的;
3️⃣:隔离性是指多个事务之间的操作是相互独立的,不会相互干扰;
4️⃣:持久性是指事务的操作必须被持久化到磁盘上,即使在发生故障时也能恢复数据库状态。

Redis事务通常用于以下几个方面:

1️⃣: 批量操作:使用事务可以将多个操作放在同一批次中执行,以减少网络延迟和服务器负载。这在需要执行多个操作来更新相同数据集的情况下特别有用。

2️⃣:原子性:在事务中执行的所有操作要么全部执行成功,要么全部失败回滚。这种原子性保证了在并发环境下的数据一致性。

3️⃣:锁定操作:事务可以获得锁定某些键,以确保在整个事务执行期间该键不被其他客户端修改。

4️⃣:消息队列:使用Redis事务队列可以将多个命令作为一个原子操作处理,从而在保证数据一致性的同时实现消息队列功能。

总之,Redis事务提供了一种灵活的方式来执行多个操作,保证数据的一致性、并发性和可靠性。

2.Redis事务相关命令

  • multi:开始一个新的redis事务
  • exec:执行一个或多个命令(作为事务结束)
  • discard:放弃当前事务,回滚所有已执行命令
  • commit:提交当前redis事务,确保所有命令执行或不执行是一个整体

3.Redis事务相关示例

通过multi创建一个事务:

  • 普通方式创建一个键值对,返回结果为“OK”
127.0.0.1:6379> set age 20
OK
  • 通过事务方式创建
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> set name 'zhangsan'
QUEUED
127.0.0.1:6379(TX)> get name
QUEUED
127.0.0.1:6379(TX)> set id 001
QUEUED
127.0.0.1:6379(TX)> exec
1) OK
2) "zhangsan"
3) OK

通过multi创建一个事务,事务内执行三条命令,返回结果均为QUEUED,exec会执行事务,并返回该事务内所有执行结果。

通过discard命令撤销事务中的操作:

127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> set name1 'yyang'
QUEUED
127.0.0.1:6379(TX)> set age1 24
QUEUED
127.0.0.1:6379(TX)> discard
OK
127.0.0.1:6379> get name1
(nil)
127.0.0.1:6379> get age1
(nil)

事务内操作要么全都做,要么全不做。
通过multi开始一个事务,里面执行两次set,在执行撤销命令后,用get查找键发现是空。

4.Redis持久化与事务持久性关系

Redis持久化是指将Redis数据存储到磁盘上,以保证在重启Redis服务器或发生故障时能够恢复数据库状态。Redis持久化可以使用RDB和AOF两种持久化策略之一,其中RDB持久化使用二进制日志记录数据,而AOF持久化使用追加日志记录数据。

事务持久性是指将一组命令的执行结果存储到磁盘上,以确保在发生故障时能够恢复这些命令的执行结果。事务持久性是通过在每个事务开始和结束时使用SAVE和BGSAVE命令来实现的,这些命令会将事务的执行结果存储到数据库中。

在Redis事务中,如果所有命令的执行都是原子性的,那么所有操作的执行结果都会被自动保存到磁盘上,即使在发生故障时也能恢复事务的执行结果。因此,事务持久性可以通过使用Redis持久化来实现。但是,如果某个命令的执行结果不是原子性的,那么在发生故障时可能无法恢复这些命令的执行结果,因此需要使用事务持久化。

因此,在使用Redis时,建议同时使用Redis持久化和事务持久化,以确保在发生故障时能够恢复数据库状态和命令执行结果。

猜你喜欢

转载自blog.csdn.net/qq_42527269/article/details/131303847
今日推荐