redis事物transaction

用于标记事务块的开始。Redis会将后续的命令逐个放入队列中,然后才能使用EXEC命令原子化地执行这个命令序列。

这个命令的运行格式如下所示:

MULTI
这个命令的返回值是一个简单的字符串,总是OK。

EXEC

在一个事务中执行所有先前放入队列的命令,然后恢复正常的连接状态。
当使用WATCH命令时,只有当受监控的键没有被修改时,EXEC命令才会执行事务中的命令,这种方式利用了检查再设置(CAS)的机制。

这个命令的运行格式如下所示:

EXEC
这个命令的返回值是一个数组,其中的每个元素分别是原子化事务中的每个命令的返回值。 当使用WATCH命令时,如果事务执行中止,那么EXEC命令就会返回一个Null值。

127.0.0.1:6380> multi OK 127.0.0.1:6380> xadd myStreamKey * name Jack age 29 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 28 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 27 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 26 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 25 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 24 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 23 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 22 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 21 QUEUED 127.0.0.1:6380> xadd myStreamKey * name Jack age 20 QUEUED 127.0.0.1:6380> exec 1) "1555926229541-0" 2) "1555926229541-1" 3) "1555926229541-2" 4) "1555926229541-3" 5) "1555926229541-4" 6) "1555926229541-5" 7) "1555926229541-6" 8) "1555926229541-7" 9) "1555926229541-8" 10) "1555926229541-9"

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。