Redis事务怎么用

发布时间:2021-11-11 09:56:47 作者:小新
来源:亿速云 阅读:144

小编给大家分享一下Redis事务怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

事务:
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> sadd "user:1:state" 1
QUEUED
127.0.0.1:6379> SADD "user:2:state" 2
QUEUED
127.0.0.1:6379> EXEC
1) (integer) 1
2) (integer) 1

由MULTI发起事务,后面的sadd命令来实现关注和被关注的操作,redis并没有执行这些命令,而是返回QUEUED表示这两条命令已经进入等待执行的事务队列中。
当exec之后告诉redis将等待的食物队列中的所有命令按照发送顺序依次执行。exec的返回值顺序和命令的顺序相同。


1.语法错误:
语法错误指命令不存在或者命令的参数个数不对,如下:
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set name Mike
QUEUED
127.0.0.1:6379> errorcommand name
(error) ERR unknown command 'errorcommand'
127.0.0.1:6379> EXEC
(error) EXECABORT Transaction discarded because of previous errors.
由于存在不正确的命令,redis直接返回错误把整个事务discard了。它连语法正确的都不会执行,如下:
127.0.0.1:6379> MGET name
1) (nil)


2.运行错误:运行错误是命令执行时出现的错误,比如使用了错误命令操作数据类型。
这种错误redis会继续执行,redis无法发现错误。
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set name hello
QUEUED
127.0.0.1:6379> SADD name 3
QUEUED
127.0.0.1:6379> SET name "abc"
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
3) OK
127.0.0.1:6379> GET name
"abc"

这种错误只能依赖程序员去把握与检查错误。


WATCH命令:监控一个或多个键,一但其中某个键值被修改,之后的事务就不会执行。监控会一直持续到exec命令。
127.0.0.1:6379> SET key 1
OK
127.0.0.1:6379> WATCH key
OK
127.0.0.1:6379> SET key 2
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET key 3
QUEUED
127.0.0.1:6379> EXEC
(nil)    // 返回nil,说明监视的ticket已经改变了,事务就取消了.
127.0.0.1:6379> GET key
"2"

发布/订阅 分别发布者和订阅者,订阅者可以订阅一个或者若干个频道,而发布者可以向指定的频道发布消息。所有订阅此频道的订阅者都会受到此消息
发布消息:
127.0.0.1:6379> PUBLISH newsChannel "good morning news report"
(integer) 0
暂时没有订阅者返回为0

订阅消息:
127.0.0.1:6379> SUBSCRIBE newsChannel
Reading messages... (press Ctrl-C to quit)
1) "subscribe"    //subscribe 表示订阅成功的反馈。第二个值是成功订阅的频道名,第三个值是当前客户端订阅的频道数量。
如果是message 这个类型回复是我们关心的,表示接收到的消息,第二个值表示产生消息的频道名称。第三个值是消息的内容。
unsubscribe 取消订阅某个频道,第二个值是对应的频道名称,第三个值是当前客户端订阅的频道数量。
2) "newsChannel"
3) (integer) 1
利用publish 再次发布消息:
127.0.0.1:6379> PUBLISH newsChannel "News 2"
(integer) 1
订阅频道:
127.0.0.1:6379> SUBSCRIBE newsChannel
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "newsChannel"
3) (integer) 1
^[[A1) "message"
2) "newsChannel"
3) "News 2"
可以按照正则表达式订阅多个频道:
127.0.0.1:6379> PSUBSCRIBE news*
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "news*"
3) (integer) 1

PSUBSCRIBE去订阅以news开头任意字符结尾的频道.
127.0.0.1:6379> PSUBSCRIBE news*
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "news*"
3) (integer) 1
1) "pmessage"
2) "news*"
3) "newsChannel"
4) "News 3"

以上是“Redis事务怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. Redis中的事务/锁
  2. redis事务解析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

redis

上一篇:如何进行第二代网关GateWay的搭建

下一篇:Django中的unittest应用是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》