Redis 事物

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

Multi 和 Exec


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

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

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

以年龄为例:

1.开启事物

2.修改数据

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

3.提交事物

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

 

Watch


 

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

我们再来举个例子

还是以年龄为例:

当前age是23

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

2.开启事物

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

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

5.提交事务

 

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

 

这就是watch的用法

 

Discard


 

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

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

 

 

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

posted @ 2018-02-23 11:20  XuMinzhe  阅读(161)  评论(0编辑  收藏  举报