首页 > 其他 > 详细

Redis事务

时间:2020-07-28 00:21:58      阅读:74      评论:0      收藏:0      [点我收藏+]

Redis中的事务是一组命令的集合。一个事务中的命令要么都执行,要么都不执行。事务在执行期间,服务器不会中断事务而去执行其它客户端的命令请求,它会将事务中的所有命令都执行完,然后才去处理其它客户端的命令请求。

1.multi——开启事务

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

2.命令入队列

之后所有的命令都会放入事务队列中,并不会立刻执行。

如果客户端发送的命令为EXEC,DISCARD,WATCH,MULTI四个命令中的其中一个,服务器会立刻执行这个命令。

对于这四个命令以外的其它命令,服务器并不会立刻执行,而是将这个命令放入一个事务队列中,然后向客户端返回QUEUED回复。

3.exec——执行事务

当客户端向服务器发送EXEC命令时,会立刻执行。

服务器会遍历这个客户端的事务队列,执行队列中保存的所有命令,最后将执行命令所得的结果全部返回给客户端。

4.DISCARD——放弃执行

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

 

watch命令

watch命令是一个乐观锁,可以为Redis事务提供 check-and-set (CAS)行为。它可以在EXEC命令执行前监视任意数量的键(key),在执行EXEC命令时,检查被监视的键是否已经被修改过,一旦发现被监视的键至少有一个被修改,服务器将拒绝执行事务,并向客户端返回代表事务执行失败的空回复(nil-reply)。

执行EXEC命令后会取消对所有键的监控,如果不想执行事务中的命令可以使用UNWATCH命令来取消监控。

Redis事务

原文:https://www.cnblogs.com/xibushijie/p/13387309.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!