1、什么是事务?
简单来说,事务(transaction)是指单个逻辑单元执行的一系列操作。
1.1、事务的四大特性ACID
事务有如下四大特性:
- 1、原子性(Atomicity): 构成事务的所有操作都必须是一个逻辑单元,要么全部执行,要么全不执行。
- 2、一致性(Consistency): 数据库在事务执行前后状态都必须是稳定的或者一致的。A(1000)给B(200)转账100后A(900),B(300)总和保持一致。
- 3、隔离性(Isolation): 事务之间相互隔离,互不影响。
- 4、持久性(Durability): 事务执行成功后数据必须写入磁盘,宕机重启后数据不会丢失。
2、Redis中的事务
Redis中的事务通过multi,exec,discard,watch这四个命令来完成。
Redis的单个命令都是原子性的,所以确保事务的就是多个命令集合一起执行。
Redis命令集合打包在一起,使用同一个任务确保命令被依次有序且不被打断的执行,从而保证事务性。
Redis是弱事务,不支持事务的回滚。
2.1、事务命令
事务命令简介
- 1、multi(开启事务)
- 用于表示事务块的开始,Redis会将后续的命令逐个放入队列,然后使用exec后,原子化的执行这个队列命令。
- 类似于mysql事务的begin
- 2、exec(提交事务)
- 执行命令队列
- 类