redis:事务与锁
创始人
2024-02-17 16:01:08

事务

Redis事务是指将多条命令加入队列,一次批量执行多条命令,每条命令会按顺序执行,事务执行过程中不会受客户端传入的命令请求影响

相关命令

  • MULTI:标识一个事务的开启,即开启事务;
  • EXEC:执行事务中的所有命令,即提交;
  • DISCARD:放弃事务;和回滚不一样,Redis事务不支持回滚。
  • WATCH:监视Key改变,用于实现乐观锁。如果监视的Key的值改变,事务最终会执行失败。
  • UNWATCH:放弃监视。

Redis事务和关系型数据库的事务不太一样,它不保证原子性,也没有隔离级别的概念

当事务开启时,事务期间的命令并没有执行,而是加入队列,只有执行EXEC命令时,事务中的命令才会按照顺序一一执行,从而事务间就不会导致数据脏读、不可重复读、幻读的问题,因此就没有隔离级别

在通过EXEC执行事务时,其中命令执行失败不会影响到其他命令的执行,并没有保证同时成功和同时失败的原子操作

乐观锁:就是非常乐观,做什么事都往好处想; 对于数据库操作,就认为每次操作数据的时候都认为别的操作不会修改,所以不会加锁,而是通过一个类似于版本的字段来标识该数据是否修改过,在执行本次操作前先判断是否修改过,如果修改过就放弃本次操作重新再来;

悲观锁:就是非常悲观,做什么事都觉得不好;对于数据库操作,每次操作数据数据都会认为别的操作会修改当前数据,说以都要对其进行加锁,类似于表锁和行锁。

Redis中也有锁机制,但是它是一种乐观锁,不同于MySQL,MySQL中的锁是悲观锁

Redis中可以使用watch来监视一个目标,如果执行事务之前被监视目标发生了修改,则取消本次事务

三种方式可以取消监视

  • 事务执行之后,不管是否执行成功还好是失败,都会取消对应的监视;
  • 当监视的客户端断开连接时,也会取消监视;
  • 可以手动UNWATCH取消所有Key的监视;

相关内容

热门资讯

希拉里称一直呼吁公开爱泼斯坦文... 转自:京报网_北京日报官方网站 #希拉里回应爱泼斯坦案没...
奥巴马:“外星人确实存在,但…... 当地时间14日,在最新发布的访谈视频中,美国前总统奥巴马称“外星人确实存在”,但情况和外界的猜测有所...
视频丨两张列车时刻表跨越十年 ... (来源:千龙网) 今年春运,全国铁路平均每天上千万人次的...
我总领馆提醒:中国公民近期避免... 2月15日,大阪市中央区道顿堀发生一起持刀伤人事件,造成1人死亡、2人受伤,其中1人失去意识。15日...
火车票候补订单先到先得!没买到... (来源:半月谈)转自:半月谈 【#火车票候补订单先到先得...