1、redis的事务
- 可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入,不许加塞
2、redis事务
常用命令
命令 | 功能 |
---|---|
discard | 取消事务,放弃执行事务块内所有命令 |
exec | 执行所有事务块内的命令 |
multi | 标记一个事务块开始 |
unwatch | 取消WATCH命令对所有key的监视 |
watch | 监视1个或多个key,如果在事务执行之前这个key被其他命令所改动,那么事务将被打断 |
1)正常执行
2)放弃事务
3)redis语法错误(回滚)
有点像编译时异常
4)执行错误抛出
像运行时异常
5)watch监控
① 监控了key,如果key被修改了,后面一个事务的执行失效
②可以通过unwatch取消全部监控
③一旦执行了exec之前加的监控锁都会被取消掉了
3、三个阶段
1)开启:以MULTI开始一个事务
2)入队:将多个命令入队到事务中,接到这些命令并不会立即执行,而是放到等待执行的事务队列里面
3)执行:由EXEC命令触发事务
4、三个特性
1)单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
2)没有隔离级别的概念:队列中的命令没有提交之前都不会实际的被执行,因为事务提交前任何指令都不会被实际执行,也就不存在”事务内的查询要看到事务里的更新,在事务外查询不能看到”这个让人万分头痛的问题
3)不保证原子性:redis同一个事务中如果有一条命令执行失败,其后的命令仍然会被执行,没有回滚