Redis-3.0.503 事务-12
2022/8/12 2:23:43
本文主要是介绍Redis-3.0.503 事务-12,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1.Redis 事务定义
Redis 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
Redis 事务的主要作用就是串联多个命令防止别的命令插队。
乐观锁 (Optimistic Lock),顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。乐观锁适用于多读的应用类型,这样可以提高吞吐量。
Redis 就是利用这种 check-and-set 机制实现事务的。
2.事务的开启
Multi、Exec、discard
Redis 事务中有 Multi、Exec 和 discard 三个指令,在 Redis 中,从输入 Multi 命令开始,输入的命令都会依次进入命令队列中,但不会执行,直到输入 Exec 后,Redis 会将之前的命令队列中的命令依次执行。而组队的过程中可以通过 discard 来放弃组队。
开启事务,进行执行
开启事务,放弃组队
3.Redis 事务中的两大命令错误:
(1) 组队中某个命令出现了错误,执行时整个的所有队列都会被取消。
例如:在设置键值对的时候,没有对键赋值,就会报错,在这种情况下去执行,队列就会呗取消。
(2) 如果执行阶段某个命令报出了错误,则只有报错的命令不会被执行,而其他的命令都会执行,不会回滚。
例如:在组队命令中,对一个String使用其他类型的命令,那么在执行时,只有该语句不会执行,其他语句照样执行。
4.如何在Redis中使用乐观锁
watch命令
在执行 multi 之前,先执行 watch key1 [key2],可以监视一个 (或多个) key ,如果在事务执行之前这个 (或这些) key 被其他命令所改动,那么事务将被打断。
在上图中,都对k1进行了监视,开启队列后,都对k1进行修改操作,执行任务队列后,先执行的客户端完成了对k1的修改,第二个客户端在执行后发现k1的版本号不对了,第二个客户端的事务就被打断了。
unwatch命令
这篇关于Redis-3.0.503 事务-12的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-24Redis资料:新手入门快速指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-07Redis高并发入门详解
- 2024-12-07Redis缓存入门:新手必读指南
- 2024-12-07Redis缓存入门:新手必读教程
- 2024-12-07Redis入门:新手必备的简单教程
- 2024-12-07Redis入门:新手必读的简单教程
- 2024-12-06Redis入门教程:从安装到基本操作
- 2024-12-06Redis缓存入门教程:轻松掌握缓存技巧