redis 事务可以一次执行多个命令。
常用命令:
使用步骤:
示例:
multi //标记事务开始
set name "zhangsan" //依次输入多个命令。输入一条命令后会提示“queued”,表示此条命令已入队
set age 20
get name
exec //执行事务,会依次执行事务块内的命令,依次显示执行结果。
exec是执行事务,如果想取消事务,将exec换为discard即可。
单个 redis 命令的执行是原子性的,但 redis 并没有在事务上增加任何维持原子性的机制,所以 redis 事务的执行不是原子性的。
事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。
比如执行事务时,第一条执行成功,第二条执行失败,此时并不会回滚之前的操作(此处指第一条、第二条命令),而是继续执行后面的命令。但会显示第二条的结果是fail。
即事务中任意命令执行失败,其余的命令依然被执行。
在事务执行过程中,其他客户端提交的命令请求不会插入到事务执行命令队列中。
redis2.6以后的版本,在服务器内置了lua环境(lua解释器),可以通过eval命令执行lua脚本。
如对本文有疑问, 点击进行留言回复!!
express+mongoose实现对mongodb增删改查操作详解
修复 Mac brew 安装 mongodb 报 Error: No available formula with the name ‘mongodb’ 问题详解
网友评论