redis学习(八) redis事物处理
redis的事物不能保证完全的原子性,实现原理大概是把一堆执行命令放入一个队列,运行exec命令的时候统一执行,如果执行过程中检测到命令有问题或discard命令不会执行整个队列,但是如果语法没问题,比如把一个String类型key当作link处理,语法没问题,这样执行exec命令的时候会执行队列里的语句,遇到错误已经执行的语句不会再回滚了。
单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的。
事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。
watch [key] 监控某个key,其他会话改变这个key,不执行事务
multi 开启事务
xxxx 命令语句1
xxxx 命令语句2
xxxx 命令语句n
discard 取消
exec 执行上面的语句
unwatch 取消监视