Redis | 事务机制

一、简介

Redis 提供了事务的机制,由以下命令可以实现 Redis 事务:

multi 开启事务
exec 提交事务
watch 监听一个key,在提交事务之前是否发生变化,发生变化就不会提交事务,没有变化才提交
discard 取消提交事务

和 MySQL 的区别在于,当有两个客户端同时操作一条数据时,MySQL会提供行锁,另一个客户端在行锁生效时无法操作,但 Redis 没有行锁,Multi只保证事务可以提交,开启事务后,两个客户端都可以操作,谁最后提交exec,最终结果就是哪个客户端提交的结果。而且 Redis 没有事务回滚,官方只提供了取消事务 discard。

二、实例
1、multi 开启事务

这里我们打开两个客户端进行演示:
我们先插入一个值
在这里插入图片描述
然后客户端 1 和客户端 2同时开启事务

multi

客户端 1 执行以下命令,执行完命令后就会进入队列

set key lol

客户端 2 执行命令

set key cf 

客户端 1 进行提交

exec

提交成功,我们可以查到结果
在这里插入图片描述
我们此时在客户端 2 也进行提交

exec

在这里插入图片描述
结果为最后客户端 2 修改的值,也就是说,Redis 多个客户端同时开启事务,都可以对数据进行操作,谁最后提交事务,结果就是谁的。

2、watch 监听 key

watch 命令可以解决上面出现的问题,监听一个key,在提交事务之前是否发生变化,发生变化就不会提交事务,没有变化才提交。

客户端 1 执行命令

watch key
multi
set key java

在这里插入图片描述
客户端 2 执行以下命令

set key js
exec

这时我们无法成功提交,因为 key 值在客户端 1 已经发生了改变
在这里插入图片描述

3、discard 取消事务

discard 可以帮我们取消事务
在这里插入图片描述
—— 完

ABOUT

公众号:【星尘Pro】
github:https://github.com/huangliangyun

推荐阅读
史上最全,最完美的 JAVA 技术体系思维导图总结,没有之一!
全站导航 | 文章汇总!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星尘Pro

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值