redis学习(八) redis事物处理

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 取消监视

上一篇 hash操作命令
下一篇 redis发布订阅命令

猜你喜欢

转载自blog.csdn.net/u011943534/article/details/82285205