
课程咨询: 400-996-5531 / 投诉建议: 400-111-8989
认真做教育 专心促就业
随着互联网的不断发展,越来越多的人都通过学习达内java培训课程实现了再就业,而本文我们就通过案例分析来简单了解一下,redis服务器事务基础知识分享。
一、事务:
1.事务概述:
1.1什么是事务:
指可以一次执行多个命令,本质是一组命令的集合。
一个事务中的所有命令都会序列化,按顺序的串行化执行而不会被其他命令插入,不许加塞。
即:一个队列中,一次性、顺序性、排他性的执行一系列命令。
1.2与传统关系型数据库的事务相比redis事务的不同之处:
我觉得关键的一个不同就是redis事务不能保证原子性,在MySQL的一个事务里的命令要么全部成功要么全部失败,
但是在redis事务里,它只会把这个事务里的一系列命令执行完,不管成功与否,事务都算结束了。
2.事务的常用操作:
2.1事务正常执行:
输入MULTI命令标记开启一个事务,之后的每条命令都会进入对列,显示QUEUED即已经进入队列。
输入EXEC命令,会执行事务块内(队列)的所有命令。
2.2放弃事务:
在事务块内输入命令DISCARD,该事务块内的所有命令不会执行,并且退出该事务块。
2.3事务异常(执行前异常):
执行前异常一般是这种命令出错(编译错误)的异常
2.4事务异常(执行后异常):
执行后异常一般指执行错误的异常,这种异常,除了出错的命令外,正常执行的命令都会在这个事务块执行后成功运行。不能保证原子性的原因。
2.5watch监控:
1)加监控且没有被篡改的情况:
2)加监控出现加塞篡改的情况:
说明:
watch命令是一种乐观锁的实现,Redis在修改的时候会检测数据是否被更改,如果更改了,则执行失败
一个窗口蓝色框5步执行结果返回为空,也就是相当于是失败,整个事务的命令都不会成功执行,相当于DISCARD
复习:悲观锁和乐观锁
悲观锁(PessimisticLock),顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。
乐观锁(OptimisticLock),顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据。
乐观锁策略:提交版本必须大于记录当前版本才能执行更新
redis是性能优先的数据库,肯定是使用的乐观锁实现,因为悲观锁实现会频繁加锁,对性能的消耗大。
3)unwatch:
开启unwatch后,在该命令之前的监控全部失效,不会对数据进行监控
4)注意:
一旦执行了EXEC,之前加的监控锁都会被取消掉;当客户端连接断开时,所有监控锁会被取消。
【免责声明】本文系本网编辑部分转载,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与管理员联系,我们会予以更改或删除相关文章,以保证您的权益!请读者仅作参考。更多内容请加抖音太原达内IT培训学习了解。