码迷,mamicode.com
首页 > 其他好文 > 详细

Redis 事务

时间:2016-05-05 07:15:22      阅读:238      评论:0      收藏:0      [点我收藏+]

标签: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"

本文出自 “技术博客” 博客,请务必保留此出处http://raytech.blog.51cto.com/7602157/1770178

Redis 事务

标签:redis 事务

原文地址:http://raytech.blog.51cto.com/7602157/1770178

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!