一文搞懂redis事务

来自文章集合:一文带你搞懂redis使用过程(持续更新中)

Redis事务

Redis事务可以一次执行多个命令,是一个原子操作:要么全部被执行,要么全部都不执行。

Redis事务通过MULTI命令开始事务,通过EXEC命令提交事务。在MULTI和EXEC之间的命令将按顺序放入队列中,而不会立即执行。这种特性使得Redis事务可以确保多个命令的原子性操作,避免了其他客户端在执行这些命令期间的干扰。

需要注意Redis的事务并不具备传统关系型数据库中那样的回滚功能,因此在执行失败时无法进行回滚。这意味着,即使事务中的某些命令失败,其他命令仍将继续执行。

redis的事务使用

下面是一个简单使用事务的例子:

json 复制代码
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set redis_text "hello world"
QUEUED
127.0.0.1:6379> get redis_text
QUEUED
127.0.0.1:6379> set redis_text "HELLO WORLD"
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) "hello world"
3) OK

使用中途,想取消事务,放弃事务块内的所有命令:DISCARD

json 复制代码
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> get redis_text
QUEUED
127.0.0.1:6379> set redis_text "Hello"
QUEUED
127.0.0.1:6379> discard
OK

为了避免有一个键被其他客户端修改,可以使用WATCH命令监视的指定键,那么在执行EXEC命令之前,如果监视的键被修改,整个事务都将被取消。下面的例子用来展示,执行事务期间监听key发生了变化的情况

json 复制代码
// redis客户端1,监视键 mykey,如果该键的值在事务期间发生变化,事务将被取消
127.0.0.1:6379> WATCH mykey
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET mykey "new value"
QUEUED
127.0.0.1:6379> EXEC
(nil)

//	redis客户端2,在redis客户端1执行事务期间执行
127.0.0.1:6379> set mykey "new value"
OK

取消所有监听可以使用:UNWATCH

redis事务使用场景

根据redis事务的原子性操作方式,常被用于保持一致性的批量操作的场景:

  1. 转账:多个账户之间进行资金转移时,通过Redis事务可以确保在资金转移的过程中不会出现中断,避免因为某些命令执行失败而造成资金损失。
  2. 缓存更新:当需要同时更新多个缓存时,通过Redis事务可以确保所有缓存都得到正确更新,避免因为某些缓存更新失败而导致数据不一致。

引申

redis事务的特点

  1. 原子性支持有限:redis的事务是原子性的,要么全部执行,要么全部不执行,没有中间状态。然而,redis并不提供回滚机制,即使其中一个命令执行失败,其他命令仍然会执行。

  2. 快速执行:因为redis是内存数据库,所以redis事务通常比传统的关系型数据库事务执行的要快,而关系型数据库则通常需要涉及磁盘访问。

  3. 命令预处理:redis事务将一系列命令进行 排队,只有在EXEC命令被调用时才会一次性执行这些命令。

关系型数据库的特点:

  1. 支持ACID属性: 关系型数据库事务支持ACID(原子性、一致性、隔离性和持久性)属性,这确保了数据的完整性和一致性。
  2. 数据持久性: 关系型数据库通常将数据持久化到磁盘上,确保数据不会因系统故障而丢失。
  3. 回滚支持: 关系型数据库具有回滚机制,可以回滚未完成的事务,确保在出现错误时数据库的一致性和稳定性。

redis事务和关系型数据库的优缺点比较

  1. redis事务对于简单的操作十分高效,适合执行一系列快速的命令。然而,他不具备关系型数据库的完整性保证
  2. 关系型数据库事务在保证数据的一致性和完整性方面更加强大,但其执行速度可能较慢,尤其是涉及大量IO操作的情况。

在实际应用中,根据具体需求和场景来选择使用Redis事务或关系型数据库事务。

相关推荐
声声codeGrandMaster18 分钟前
Django框架的前端部分使用Ajax请求一
前端·后端·python·ajax·django
会飞的架狗师33 分钟前
【Spring Cloud Gateway】Nacos整合遇坑记:503 Service Unavailable
java·开发语言
重生之后端学习2 小时前
02-前端Web开发(JS+Vue+Ajax)
java·开发语言·前端·javascript·vue.js
duapple6 小时前
Golang基于反射的ioctl实现
开发语言·后端·golang
字节源流8 小时前
关于maven的依赖下不下来的问题
java·maven
pjx9878 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡
prinrf('千寻)9 小时前
MyBatis-Plus 的 updateById 方法不更新 null 值属性的问题
java·开发语言·mybatis
老华带你飞9 小时前
实习记录小程序|基于SSM+Vue的实习记录小程序设计与实现(源码+数据库+文档)
java·数据库·spring boot·小程序·论文·毕设·实习记录小程序
在未来等你9 小时前
互联网大厂Java求职面试:AI与大模型应用集成及云原生挑战
java·微服务·ai·kubernetes·大模型·embedding·spring ai
my_styles9 小时前
docker-compose部署项目(springboot服务)以及基础环境(mysql、redis等)ruoyi-ry
spring boot·redis·后端·mysql·spring cloud·docker·容器