1、redis的事务

  • 可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入,不许加塞

2、redis事务

常用命令

命令

功能

discard

取消事务,放弃执行事务块内所有命令

exec

执行所有事务块内的命令

multi

标记一个事务块开始

unwatch

取消WATCH命令对所有key的监视

watch

监视1个或多个key,如果在事务执行之前这个key被其他命令所改动,那么事务将被打断

1)正常执行

redis setbit一次性设置_redis


2)放弃事务

redis setbit一次性设置_redis_02


3)redis语法错误(回滚)有点像编译时异常

redis setbit一次性设置_序列化_03


redis setbit一次性设置_回滚_04


4)执行错误抛出像运行时异常

redis setbit一次性设置_序列化_05

5)watch监控

① 监控了key,如果key被修改了,后面一个事务的执行失效

redis setbit一次性设置_序列化_06


②可以通过unwatch取消全部监控

③一旦执行了exec之前加的监控锁都会被取消掉了

3、三个阶段

1)开启:以MULTI开始一个事务

2)入队:将多个命令入队到事务中,接到这些命令并不会立即执行,而是放到等待执行的事务队列里面

3)执行:由EXEC命令触发事务

4、三个特性

1)单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。

2)没有隔离级别的概念:队列中的命令没有提交之前都不会实际的被执行,因为事务提交前任何指令都不会被实际执行,也就不存在”事务内的查询要看到事务里的更新,在事务外查询不能看到”这个让人万分头痛的问题

3)不保证原子性:redis同一个事务中如果有一条命令执行失败,其后的命令仍然会被执行,没有回滚