本文共 786 字,大约阅读时间需要 2 分钟。
Redis 提供了事务的机制,由以下命令可以实现 Redis 事务:
multi 开启事务
exec 提交事务 watch 监听一个key,在提交事务之前是否发生变化,发生变化就不会提交事务,没有变化才提交 discard 取消提交事务
和 MySQL 的区别在于,当有两个客户端同时操作一条数据时,MySQL会提供行锁,另一个客户端在行锁生效时无法操作,但 Redis 没有行锁,Multi只保证事务可以提交,开启事务后,两个客户端都可以操作,谁最后提交exec,最终结果就是哪个客户端提交的结果。而且 Redis 没有事务回滚,官方只提供了取消事务 discard。
这里我们打开两个客户端进行演示:
我们先插入一个值 然后客户端 1 和客户端 2同时开启事务multi
客户端 1 执行以下命令,执行完命令后就会进入队列
set key lol
客户端 2 执行命令
set key cf
客户端 1 进行提交
exec
提交成功,我们可以查到结果
我们此时在客户端 2 也进行提交exec结果为最后客户端 2 修改的值,也就是说,Redis 多个客户端同时开启事务,都可以对数据进行操作,谁最后提交事务,结果就是谁的。
watch 命令可以解决上面出现的问题,监听一个key,在提交事务之前是否发生变化,发生变化就不会提交事务,没有变化才提交。
客户端 1 执行命令
watch keymultiset key java客户端 2 执行以下命令
set key jsexec
这时我们无法成功提交,因为 key 值在客户端 1 已经发生了改变
discard 可以帮我们取消事务
—— 完公众号:【星尘Pro】
github:
推荐阅读
转载地址:http://iyfsi.baihongyu.com/