redis之事务

什么是事务

Redis 的事务和 MySQL 的事务概念上是类似的. 都是把一系列操作绑定成一组. 让这一组能够批量执 行. 但是注意体会 Redis 的事务和 MySQL 事务的区别:

但是注意体会 Redis 的事务和 MySQL 事务的区别:

• 弱化的原子性: redis 没有 "回滚机制" . **只能做到这些操作 "批量执行".**不能做到 "一个失败就恢复到 初始状态".也就是说redis的原子性不确保执行是否成功,没有回滚机制,不能回滚

• 不保证一致性: 不涉及 "约束". 也没有回滚. MySQL 的一致性体现的是运行事务前和运行后 , 结果都 是合理有效的, 不会出现中间非法状态.

• 不需要隔离性: 也没有隔离级别, 因为不会并发执行事务 (redis 单线程处理请求) .

• 不需要持久性: 是保存在内存的. 是否开启持久化, 是redis-server 自己的事情, 和事务无关.

Redis 事务本质上是在服务器上搞了一个 "事务队列". 每次客户端在事务中进行一个操作, 都会把命令先 发给服务器, 放到 "事务队列" 中(但是并不会立即执行) 而是会在真正收到 EXEC 命令之后, 才真正执行队列中的所有操作.

事务操作

MULTI 开启一个事务,执行成功返回ok

执行multi后,并没有真正执行,可以看到返回结果时queued,此时只是讲这多个请求保存在了服务器的事务队列中,此时另开一个窗口可以看见,是无法查询到key对应的值的。

EXEC 真正执行事务

当执行exec后,服务器才真正执行了事务队列里的请求,此时才能查询到对应的数据

DISCARD 放弃当前事务.

此时直接清空事务队列. 之前的操作都不会真正执行到

WATCH

watch监控某个key是否在事务执行之前发生了改变

在执行事务的时候,如果某个事务中修改的值被别的客户端修改了,此时就容易出现数据不一致的问 题.

在上述场景中,就可以使用watch来解决该问题

WATCH key → 先监视一个或多个键

MULTI → 开启事务块

SET key 111 → 在事务块中执行命令

EXEC → 执行事务(如果被监视的 key 未被修改,则事务成功执行)

如图,watch key后,另一客户端修改key之后,再执行exec会发现返回nil,随后get key得到的值为被修改后的值222

unwatch 取消监控

WATCH key1 key2

MULTI

... 一些命令 ...

DISCARD # 取消事务,但不会自动取消 WATCH

UNWATCH # 如果需要,手动取消监视

redis 的watch就相当于基于版本号这样的机制来实现的"乐观锁"

总结:

相关推荐
2401_883600252 小时前
SQL视图名称冲突如何避免_建立规范化的命名空间与管理
jvm·数据库·python
殷紫川2 小时前
PostgreSQL vs MySQL:Java 选型指南与实战避坑
数据库·mysql·postgresql
Treh UNFO2 小时前
SQL 注入详解:原理、危害与防范措施
数据库·sql·oracle
m0_640309302 小时前
CSS中如何让浮动元素撑开父容器_深度解析清除浮动
jvm·数据库·python
2301_816660212 小时前
Golang bufio怎么读取用户输入_Golang标准输入读取教程【详解】
jvm·数据库·python
hsjcjh2 小时前
PostgreSQL 查看数据库及表中数据占用空间大小
数据库·postgresql·oracle
解救女汉子2 小时前
Golang如何创建和删除目录_Golang目录操作教程【完整】
jvm·数据库·python
小猿姐2 小时前
数据库漏洞自动同步,KubeBlocks Addon 安全能力再升级
数据库·安全
ClouGence2 小时前
从 Spanner 到 StarRocks:把云账单砍掉 80%
数据库·dba