【Redis数据库】命令学习笔记——发布订阅、事务、脚本、连接等命令汇总

本篇基于redis 4.0.11版本,学习发布订阅、事务、脚本、连接的相关命令。

Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

序号 命令 描述 事例 结果
SUBSCRIBE channel [channel ...]  订阅给定的一个或多个频道的信息。 创建了订阅频道名为redisChat:SUBSCRIBE redisChat Reading messages... (press Ctrl-C to quit)

1) "subscribe"

2) "redisChat"

3) (integer) 1
PUBLISH channel message  将信息发送到指定的频道。 将haha发布到mychannel渠道:publish mychannel haha 本窗口:"2"   --返回订阅数量

订阅窗口:1)  "message"

 2)  "mychannel"

 3)  "haha"
PSUBSCRIBE pattern [pattern ...]  订阅一个或多个符合给定模式的频道。 订阅my开头模式的频道:PSUBSCRIBE my* Reading messages... (press Ctrl-C to quit)

1) "psubscribe"  # 返回值的类型:显示订阅成功

2) "my*"   # 订阅的模式

3) (integer) 1   # 目前已订阅的模式的数量

----------------------

1) "pmessage"  # 返回值的类型:信息

2) "my*"   # 信息匹配的模式

3) "mychannel"  # 信息本身的目标频道

4) "haha"   # 信息的内容  
PUBSUB subcommand [argument [argument ...]]  查看订阅与发布系统状态。 打印所有活跃频道:PUBSUB CHANNELS

订阅者数量:PUBSUB NUMSUB mychannel
1) "mychannel"

2) "redisChat"

---------------

1) "mychannel"

2) (integer) 1
UNSUBSCRIBE [channel [channel ...]]  指退订给定的频道。    
PUNSUBSCRIBE [pattern [pattern ...]]  退订所有给定模式的频道。    

Redis 事务可以一次执行多个命令,收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行,在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。

序号 命令 描述 事例 结果
DISCARD  取消事务,放弃执行事务块内的所有命令。 127.0.0.1:6379> MULTI

OK

127.0.0.1:6379> SET greeting "hello"

QUEUED

127.0.0.1:6379> DISCARD

OK
 
MULTI  标记一个事务块的开始。 127.0.0.1:6379> MULTI

OK

127.0.0.1:6379> SET book-name "Mastering C++ in 21 days"

QUEUED

127.0.0.1:6379> GET book-name

QUEUED

127.0.0.1:6379> SADD tag "C++" "Programming" "Mastering Series"

QUEUED

127.0.0.1:6379> SMEMBERS tag

QUEUED

127.0.0.1:6379> EXEC
1) OK

2) "Mastering C++ in 21 days"

3) (integer) 3

4) 1) "Programming"

   2) "C++"

   3) "Mastering Series"
EXEC  执行所有事务块内的命令。
WATCH key [key ...]  监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。 WATCH lock lock_times ok
UNWATCH  取消 WATCH 命令对所有 key 的监视。 UNWATCH ok

Redis 脚本使用 Lua 解释器来执行脚本。 Redis 2.6 版本通过内嵌支持 Lua 环境。执行脚本的常用命令为 EVAL

序号 命令 描述 事例 结果
1 EVAL script numkeys key [key ...] arg [arg ...] 执行 Lua 脚本 eval "return {KEYS[1],KEYS[2],KEYS[3],ARGV[1]}" 3 key1 key2 first second 1) "key1"

2) "key2"

3) "first"

4) "second"
2 EVALSHA sha1 numkeys key [key ...] arg [arg ...] 执行 Lua 脚本    
3 SCRIPT EXISTS script [script ...] 查看指定的脚本是否已经被保存在缓存当中 SCRIPT EXISTS 232fd51614574cf0867b83d384a5e898cfd24e5a 1) (integer) 1
4 SCRIPT FLUSH 从脚本缓存中移除所有脚本    
5 SCRIPT KILL 杀死当前正在运行的 Lua 脚本    
6 SCRIPT LOAD script 将脚本 script 添加到脚本缓存中,但并不立即执行这个脚本 SCRIPT LOAD "return 'hello moto'"

"232fd51614574cf0867

b83d384a5e898cfd24e5a"

连接 redis 服务命令:

序号 命令 描述 事例 结果
1

AUTH password

验证密码是否正确    
2

ECHO message

打印字符串 ECHO HAHA "HAHA"
3

PING

查看服务是否运行 PING  PONG # 客户端和服务器连接正常
4

QUIT

关闭当前连接    
5

SELECT index

切换到指定的数据库 SELECT 2  OK
6 CONFIG get requirepass 是否设置了密码验证   1) "requirepass" 

2) "" # 密码
7 CONFIG set requirepass "summer" 设置密码   OK
8

config get maxclients

查询最大连接数   1) "maxclients"

2) "10000"
9 client list 连接到 redis 服务的客户端列表   id=1748 addr=127.0.0.1:56980 fd=8 name= age=30 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=32768 obl=0 oll=0 omem=0 events=r cmd=client

数据备份与恢复:

序号 命令 描述 结果
1

save

该命令将在 redis 安装目录中创建dump.rdb文件 OK
2

config  get  dir

输出的 redis 安装目录 1) "dir"

2) "/tmp"
3

BGSAVE

该命令在后台执行 Background saving started

上一篇:【Redis数据库】命令学习笔记——列表(list)+集合(set)+有序集合(sorted set)(17+15+20个超全字典版)

下一篇:【Redis数据库】Java 使用 jedis

上一篇:JavaScipt实现倒计时方法总结


下一篇:sys.syslockinfo--master..syslockinfo