第一次开票网站建设怎么开,安全通道入口,做百家好还是个人网站,专业的外贸网站建设公司排名1. 是什么 1. 官网 https://redis.io/dosc/manual/transactions/ 2. 可以一次执行多个命令#xff0c;本质是一组命令的集合。一个事务中的所有命令都会序列化#xff0c;按顺序地串行化执行而不会被其它命令插入#xff0c;不许加塞 2. 能干啥 一个队列中#xff0c;一次…1. 是什么 1. 官网 https://redis.io/dosc/manual/transactions/ 2. 可以一次执行多个命令本质是一组命令的集合。一个事务中的所有命令都会序列化按顺序地串行化执行而不会被其它命令插入不许加塞 2. 能干啥 一个队列中一次性、顺序性、排他性的执行一系列命令 3. Redis事务 VS 数据库事务 1 单独的隔离操作 Redis的事务仅仅是保证事务里的操作会被连续独占的执行redis命令执行是单线程架构在执行完事务内所有指令前是不可能再去同时执行其他客户端的请求的 2 没有隔离级别的概念 因为事务提交前任何指令都不会被实际执行也就不存在”事务内的查询要看到事务里的更新在事务外查询不能看到”这种问题了 3不保证原子性 Redis的事务 不保证原子性也就是不保证所有指令同时成功或同时失败只有决定是否开始执行全部指令的能力没有执行到一半进行回滚的能力 4 排它性 Redis会保证一个事务内的命令依次执行而不会被其它命令插入 4. 怎么用 4.1 常用命令 4.2 case1: 正常执行 MULTI EXEC 4.3 Case2: 放弃事务 MULTI DISCARD 案例演示 官网说明 4.4 Case3: 全体连坐 官网说明 官网说明 4.5 Case4: 冤头债主 官网说明 Redis不提供事务回滚的功能开发者必须在事务执行出错后自行恢复数据库状态 注意和传统数据库事务区别不一定要么一起成功要么一起失败 4.6 Case5: watch监控
4.6.1 Redis使用Watch来提供乐观锁定类似于CAS(Check-and-Set) 1. 悲观锁 悲观锁(Pessimistic Lock), 顾名思义就是很悲观每次去拿数据的时候都认为别人会修改所以每次在拿数据的时候都会上锁这样别人想拿这个数据就会block直到它拿到锁。2. 乐观锁 乐观锁(Optimistic Lock), 顾名思义就是很乐观每次去拿数据的时候都认为别人不会修改所以不会上锁但是在更新的时候会判断一下在此期间别人有没有去更新这个数据。 乐观锁策略:提交版本必须 大于 记录当前版本才能执行更新 3. CAS 4.6.2 watch 1. 初始化k1和balance两个key,先监控再开启multi保证两key变动在同一个事务内 2. 有加塞篡改 watch命令是一种乐观锁的实现Redis在修改的时候会检测数据是否被更改如果更改了则执行失败 第一个窗口蓝色框第5步执行结果返回为空也就是相当于是失败笔记见最下面官网说明 4.6.3 unwatch 4.6.4 小结 一旦执行了exec之前加的监控锁都会被取消掉了 当客户端连接丢失的时候(比如退出链接)所有东西都会被取消监视 5. 小总结 开启: 以MULTI开始一个事务 入队: 将多个命令入队到事务中接到这些命令并不会立即执行而是放到等待执行的事务队列里面执行: 由EXEC命令触发事务