Redis 事物

MULTI 、 EXEC 、 DISCARD 和 WATCH 是 Redis 事务的基础。

Multi 和 Exec


Multi:开启一个事务,它总是返回 OK 。执行之后, 客户端可以继续向服务器发送任意多条命令, 这些命令不会立即被执行, 而是被放到一个队列中, 当 EXEC 命令被调用时, 所有队列中的命令才会被执行。

另一方面, 通过调用 DISCARD , 客户端可以清空事务队列, 并放弃执行事务。

下面我们试一试这两个命令

以年龄为例:

Redis 事物

1.开启事物

Redis 事物

2.修改数据

Redis 事物

这个时候我们再查看一次年龄,发现还是25,说明事物还没被提交前所有的修改操作都不会生效

Redis 事物

3.提交事物

Redis 事物

再次查看数据,事务提交后修改操作生效了

Redis 事物

Watch


被 WATCH 的键会被监视,并会发觉这些键是否被改动过了。 如果有至少一个被监视的键在 EXEC 执行之前被修改了, 那么整个事务都会被取消, EXEC 返回空多条批量回复(null multi-bulk reply)来表示事务已经失败。

我们再来举个例子

还是以年龄为例:

当前age是23

Redis 事物

1.watch:监视你,接下来age这个数据只能在我这个线程里面操作了,其他地方动了这个数据就会报警

Redis 事物

2.开启事物

Redis 事物

3.这时候新开一个窗口,修改age

Redis 事物

4.回到原先的窗口,现在数据已经被其他线程修改了,我们看下再修改还会有效么

Redis 事物

5.提交事务

Redis 事物

这次的结果不是ok,说明watch监视成功了,我们再看看当前age是多少呢

Redis 事物

这就是watch的用法

Discard


当执行 DISCARD 命令时, 事务会被放弃, 事务队列会被清空, 并且客户端会从事务状态中退出:

这个命令比较简单,这里就不做过多的解释了,直接举例子了

Redis 事物

以上就是redis事物的基本操作

上一篇:安卓自动化测试工具MonkeyRunner之使用ID进行参数化,以及List选择某项和弹出框点击确定的写法


下一篇:Microsoft Orleans构建高并发、分布式的大型应用程序框架