BoyChai's Blog - 悲观锁 https://blog.boychai.xyz/index.php/tag/%E6%82%B2%E8%A7%82%E9%94%81/ Redis-NoSQL数据库(事务和锁机制) https://blog.boychai.xyz/index.php/archives/37/ 2022-09-09T11:21:14+00:00 事务Redis 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。Redis 事务的主要作用就是串联多个命令防止别的命令插队。Multi、Exec、Discard从输入 Multi 命令开始,输入的命令都会依次进入命令队列中,但不会执行,直到输入 Exec 后,Redis 会将之前的命令队列中的命令依次执行。组队的过程中可以通过 Discard 来放弃组队。当组队中某个命令出现了报告错误,执行时整个的所有队列都会被取消。特性单独的隔离操作事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。没有隔离级别的概念队列中的命令没有提交之前都不会实际被执行,因为事务提交前任何指令都不会被实际执行。不保证原子性事务中如果有一条命令执行失败,其后的命令仍然会被执行,没有回滚 。持久化锁悲观锁悲观锁(Pessimistic Lock),即每次去拿数据的时候都认为有其他线程会修改,所以每次在拿数据的时候都会上锁,这样其他线程想要拿到这个数据就会被 block 直到成功拿到锁。(效率低)乐观锁乐观锁(Optimistic Lock),即每次去拿数据的时候都认为其他线程不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间有没有其他线程去更新这个数据,可以使用版本号等机制。乐观锁适用于多读的应用类型,这样可以提高吞吐量。Redis 就是利用这种 check-and-set 机制实现事务的。Watch、unwatch在执行 multi 之前,先执行 watch key1 [key2]**,可以监视一个(或多个 )**key 。如果在事务执行之前这个 key 被其他命令所改动,那么事务将被打断。取消 WATCH 命令对所有 key 的监视。如果在执行 WATCH 命令之后,EXEC 命令或 DISCARD 命令先被执行,那么就不需要再执行 UNWATCH 。