博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Redis | 事务机制
阅读量:4104 次
发布时间:2019-05-25

本文共 786 字,大约阅读时间需要 2 分钟。

一、简介

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 keymultiset key java

在这里插入图片描述

客户端 2 执行以下命令

set key jsexec

这时我们无法成功提交,因为 key 值在客户端 1 已经发生了改变

在这里插入图片描述

3、discard 取消事务

discard 可以帮我们取消事务

在这里插入图片描述
—— 完

ABOUT

公众号:【星尘Pro】

github:

推荐阅读

转载地址:http://iyfsi.baihongyu.com/

你可能感兴趣的文章
动态库调动态库
查看>>
Kubernetes集群搭建之CNI-Flanneld部署篇
查看>>
k8s web终端连接工具
查看>>
手绘VS码绘(一):静态图绘制(码绘使用P5.js)
查看>>
手绘VS码绘(二):动态图绘制(码绘使用Processing)
查看>>
基于P5.js的“绘画系统”
查看>>
《达芬奇的人生密码》观后感
查看>>
论文翻译:《一个包容性设计的具体例子:聋人导向可访问性》
查看>>
基于“分形”编写的交互应用
查看>>
《融入动画技术的交互应用》主题博文推荐
查看>>
链睿和家乐福合作推出下一代零售业隐私保护技术
查看>>
Unifrax宣布新建SiFAB™生产线
查看>>
艾默生纪念谷轮™在空调和制冷领域的百年创新成就
查看>>
NEXO代币持有者获得20,428,359.89美元股息
查看>>
Piper Sandler为EverArc收购Perimeter Solutions提供咨询服务
查看>>
RMRK筹集600万美元,用于在Polkadot上建立先进的NFT系统标准
查看>>
JavaSE_day12 集合
查看>>
JavaSE_day14 集合中的Map集合_键值映射关系
查看>>
Day_15JavaSE 异常
查看>>
异常 Java学习Day_15
查看>>