Redis事务及其锁机制

目录

一、Redis事务及其锁机制

1.Redis的事务定义

2.Multi、Exec、discard

3.事务的错误处理

(1)编译阶段错误

(2)执行阶段错误 

 3.Redis中的的锁机制

(1)悲观锁

(2)乐观锁

4.WATCH key [key ...]

5.unwatch


一、Redis事务及其锁机制

1.Redis的事务定义

        Redis事务是一个单独的隔离操作:

        事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。

        Redis事务的主要作用就是串联多个命令防止别的命令插队。

2.MultiExecdiscard

Multi: 命令组队

Exec: 执行队伍命令

discard: 放弃组队

 案例:

3.事务的错误处理

        在组队的命令中,可能会出现两种不同的错误,一种发生在编译阶段,一种发生执行阶段

(1)编译阶段错误

        ※在编译阶段,你输入命令是不会报错误的,只有在执行exec命令时,才会报告错误,而出现这种错误,事务是不会执行的,所有命令一并取消

案例:

(2)执行阶段错误 

        ※在执行阶段,如果发现队伍中有命令执行错误,则报告错误,其他命令正常执行

案例:

 3.Redis中的的锁机制

如欲了解更多锁内容,请访问:https://blog.csdn.net/weixin_59216829/article/details/126839698

(1)悲观锁

        总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁。(预期锁冲突严重)

(2)乐观锁

         假设数据一般情况下不会产生并发冲突,所以在数据进行提交更新的时候,才会正式对数据是否产生并发冲突进行检测,如果发现并发冲突了,则让返回用户错误的信息,让用户决定如何去做(预期锁冲突概率低)

        乐观锁适用于多读的应用类型,这样可以提高吞吐量Redis就是利用这种check-and-set机制实现事务的。

4.WATCH key [key ...]

        在执行multi之前,先执行watch key1 [key2],可以监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

5.unwatch

        取消 WATCH 命令对所有 key 的监视,如果在执行 WATCH 命令之后,EXEC 命令或DISCARD 命令先被执行了的话,那么就不需要再执行UNWATCH 了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

摸鱼儿hzj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值