Redis事务

绝地灬酷狼 2023-06-05 08:14 26阅读 0赞

1. Redis事务

Redis 事务可以一次执行多个命令, 并且带有以下三个重要的保证:

  1. 批量操作在发送 EXEC 命令前被放入队列缓存。
  2. 收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。
  3. 在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。

一个事务从开始到执行会经历以下三个阶段:

  • 开始事务:multi。
  • 命令入队:QUEUED状态。
  • 执行事务:exec。

2. 开始事务:MULTI

3. 执行事务:EXEC

在这里插入图片描述
单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的。

事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。

3. 监听:WATCH

在事务执行过程中,如果不希望操作的对象被修改,可以使用watch进行监视,一旦被修改了,那么在事务提交时,将会失败。

在这里插入图片描述

4. 取消监听:UNWATCH

取消 WATCH 命令对所有 key 的监视。

5. 事务取消:DISCARD

取消事务,放弃执行事务块内的所有命令。

发表评论

表情:
评论列表 (有 0 条评论,26人围观)

还没有评论,来说两句吧...

相关阅读

    相关 RedisRedis事务

    一、Redis事务的概念 1.1、事务本质 Redis 事务的本质是一组命令的集合。 事务支持一次执行多个命令,一个事务中所有命令都会被序列化。在事务执行过程,会按

    相关 Redis 事务

    Redis 事务 > 可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其他命令插入,不许加塞。 在一个队列中,一次

    相关 Redis 事务

    Redis 事务 Redis 事务可以一次执行多个命令, 并且带有以下两个重要的保证: 批量操作在发送 EXEC 命令前被放入队列缓存。 收到 EXEC 命

    相关 redis事务

     可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入,不许加塞。一个队列中,一次性、顺序性、排他性的执行一系列命

    相关 redis事务

    redis事务 可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行执行而不会被其它命令插入,不许加塞。 特点:一个队列中,一

    相关 redis 事务

    redis 事务可以一次执行多个命令 批量操作在发送exec命令前被放入队列缓存 收到exec命令后进入事务执行,事务中任间命令执行失败,其余命令依然被执行,已执行指令不回

    相关 Redis事务

    如果你对Redis总体上没有认识,建议先看看我之前的博客,对Redis有详细的介绍。 [和面试官从NoSql谈起【Redis】][NoSql_Redis] [【Re