redis的事务处理

Posted lxhyty

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis的事务处理相关的知识,希望对你有一定的参考价值。

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

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

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

  1. 开始事务
  2. 命令入队
  3. 执行事务

3、事务处理相关命令

  • 命令名称:multi
  • 语法:multi
  • 功能:
    • 标记一个事务块的开始
  • 返回值:
    • 总是返回OK

 

  • 命令名称:exec
  • 语法:exec
  • 功能:
    • 执行所有事务块内的命令。
  • 返回值:
    • 事务块内所有命令的返回值,按命令执行的先后顺序排列。
    • 当操作被打断时,返回空值nil。

 

  • 命令名称:discard
  • 语法:discard
  • 功能:
    • 取消事务,放弃执行事务块内的所有命令。
  • 返回值:
    • 总是返回OK

 

  • 命令名称:watch
  • 语法:watch key [key……]
  • 功能:
    • 监视一个(或多个)key,如果在事务执行之前这个(或这些)key被其他命令所改动,那么事务将被打断。
  • 返回值:
    • 总是返回OK

 

  • 命令名称:unwatch
  • 语法:unwatch
  • 功能:
    • 取消watch命令对所有key的监视。
    • 如果在执行watch命令之后,exec命令或discard命令先被执行了的话,那么久不需要再执行unwatch了
  • 返回值:总是返回OK

以上是关于redis的事务处理的主要内容,如果未能解决你的问题,请参考以下文章

关于django出现重复点击,多事务处理

Mybatis事务处理

面试官:小伙子你给我说说MySq|并发事务处理细节

NetCore微服务实现事务一致性masstransit之saga使用

springCloud分布式事务实战案例需求及实现步骤

springCloud分布式事务实战案例需求及实现步骤