Redis 的事务机制

Redis 的事务并不是严格意义上的事务,它只是一种将多个命令打包,然后一次性、按顺序地执行的机制,它并不具备原子性,Redis 的原子性是针对单条命令的,批量指令的原子性无法保证。

这是官网上的说明 :

From redis docs on transactions:

It's important to note that even when a command fails, all the other commands in the queue are processed -- Redis will not stop the processing of commands.

Redis 的事务基本上可以分为三个阶段:

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

MUTLI 命令用于开启事务,EXEC 命令用于执行事务,DISCARD 命令用于取消事务。

Redis 的事务不能回滚,如果在事务执行过程中出现错误,那么 Redis 会继续执行剩余的命令,而不是回滚。

因为 Redis 是单线程的,所以 Redis 会将事务中的所有命令按照顺序执行,期间不会有其他命令插入。

使用场景

数据同步操作:在同步数据到多个缓存或数据集时,确保每个数据源的一致性更新是很关键的。通过 Redis 事务,可以保证多个键值对同时更新。

shell 复制代码
MULTI
SET key1 value1
SET key2 value2
SET key3 value3
EXEC

批量操作:当需要在短时间内完成大量 Redis 操作时,使用事务可以减少网络开销。通过事务执行所有命令,只需要发送一次请求,减少了重复发送消息的需要。

shell 复制代码
MULTI
LPUSH list_key item1
LPUSH list_key item2
LPUSH list_key item3
EXEC

计数器操作:在分布式系统中,可能需要统计一些任务完成的数量;这种场景下,使用原子性操作来保证递增或递减的正确性。

shell 复制代码
MULTI
INCR completed_tasks
DECR pending_tasks
EXEC

注意

因为 Redis 的事务并不具备原子性,所以在使用事务时,需要注意以下几点:

  1. 不能取代数据库事务
  2. 本质是一组打包的命令
  3. 不能回滚
相关推荐
步十人12 小时前
【Redis】持久化机制
数据库·redis·缓存
yurenpai(27届找实习中)13 小时前
redis_点评(25.附件店铺—把数据库里的店铺按【类型分组】,批量导入Redis 的 GEO 地理位置结构)
java·redis·缓存
闪电悠米13 小时前
黑马点评-优惠券秒杀-05_local_lock_cluster_problem
java·spring boot·redis·缓存
西安邮电大学14 小时前
Redis为什么快?
java·redis·后端·其他·面试
稚枭天卓15 小时前
mac 安装 redis
redis·macos
yurenpai(27届找实习中)15 小时前
redis_点评(26.附近店铺——实现附近商家功能)
数据库·spring boot·redis
不剪发的Tony老师16 小时前
RedisME:一个现代化、轻量级Redis管理工具
数据库·redis
消失的旧时光-194316 小时前
企业认证与安全体系(四):企业登录认证流程全解析——JWT、Redis、Spring Security 如何协同工作?
redis·安全·spring·spring security·jwt
愤怒的苹果ext16 小时前
Spring Boot Redis Stream队列
spring boot·redis·消息队列·stream
MageGojo17 小时前
短链还原 API 怎么接入:展开跳转链路、查看状态码和最终落地页
数据库·redis·缓存