事务处理,在很多语言中都会存在,java 开发中就经常遇到。小编在上家公司工作开发时,redis 主要应用在前端登录,用来保存短信验证码的。redis 的事务处理虽然没有涉及,不过也是非常有用的。redis 事务的作用: 串联多个命令,防止其他命令插队。下面小编展示一下如何进行 redis 的事务操作。
1,登录redis。小编下面的指令演示是在 docker 安装的redis 里面进行的。如果各位的Linux 环境还没有安装配置好 docker,可以参考小编之前的文章: Ubuntu 部署 Docker 完整步骤。如果各位的 docker 还没有安装配置好 redis, 也可以去翻看小编之前的文章:Docker 部署 Redis 完整步骤
2,进入组队阶段。
127.0.0.1:6379> multi
OK
3,输出多次指令操作。
127.0.0.1:6379> set k1 v1
QUEUED
127.0.0.1:6379> set k2 v2
QUEUED
4,执行阶段
127.0.0.1:6379> exec
1) OK
2) OK
5,撤销命令。
127.0.0.1:6379> discard
OK
6,组队中,如果有错误,则无法进行执行。
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set k4 v4
QUEUED
127.0.0.1:6379> set k5
(error) ERR wrong number of arguments for 'set' command
127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
7,组队中的错误没有抛出,则执行阶段,有错误的不能执行,其他可以执行
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set k1 v1
QUEUED
127.0.0.1:6379> incr k1 ##(此处无法执行,但是处于组队阶段,不会报错)
QUEUED
127.0.0.1:6379> exec
1) OK
2) (error) ERR value is not an integer or out of range