素手烹茶|Redis 事务也叫事务吗?,不支持原子性的( 三 )
通过watch命令在事务执行之前监控了多个keys , 倘若在watch之后有任何key的值发生变化 , exec命令执行的事务都将被放弃 , 同时返回Null应答以通知调用者事务执行失败 。
悲观锁
悲观锁(PessimisticLock) , 顾名思义 , 就是很悲观 , 每次去拿数据的时候都认为别人会修改 , 所以每次在拿数据的时候都会上锁 , 这样别人想拿这个数据就会block直到它拿到锁 。 传统的关系型数据库里边就用到了很多这种锁机制 , 比如行锁 , 表锁等 , 读锁 , 写锁等 , 都是在做操作之前先上锁
乐观锁
乐观锁(OptimisticLock) , 顾名思义 , 就是很乐观 , 每次去拿数据的时候都认为别人不会修改 , 所以不会上锁 , 但是在更新的时候会判断一下在此期间别人有没有去更新这个数据 , 可以使用版本号等机制 。 乐观锁适用于多读的应用类型 , 这样可以提高吞吐量 。 乐观锁策略:提交版本必须大于记录当前版本才能执行更新
WATCH命令的实现原理在代表数据库的server.h/redisDb结构类型中 , 都保存了一个watched_keys字典 , 字典的键是这个数据库被监视的键 , 而字典的值是一个链表 , 链表中保存了所有监视这个键的客户端 , 如下图 。
推荐阅读
- 素手烹茶|- 高性能低损耗的 Goroutine 池,Ants
- 素手烹茶|Pro体验:敢越级超轻薄的5G天玑旗舰,realme真我X7
- 素手烹茶|速度为之乍舌,一天一价已是常事,华为手机价格疯狂上涨
- 素手烹茶|| 奔驰、小米正式牵手!雷军:这是自己十分期待的合作,资讯
- 素手烹茶|电脑小白求解
- 素手烹茶|以后买手机千万要注意,手机变卡顿的真正元凶居然是它
- 素手烹茶|元的多设备协同办公神器,小过 A4 纸的华为 MateBook X,7999
- 素手烹茶|自己装一个移动硬盘
- 空白键|redis学习第一篇
- 素手烹茶|看看你贡献了几台?很现实的数据,苹果手机在中国历年销量