美文网首页
redis-cli 详细用法

redis-cli 详细用法

作者: 饱饱抓住了灵感 | 来源:发表于2023-02-06 11:55 被阅读0次

redis-cli 是Redis的客户端命令行界面

  • 它对命令大小写不敏感,如: ping、Ping、PING是同一个命令
  • 但是对变量大小写敏感,A、a是两个变量

它主要有两种模式:

  • 一种是交互模式,用户可以在其中键入命令并获得回复;
  • 另一种模式是通过redis-cli发送命令,然后打印在标准输出上

redis-cli未指定主机和端口时,默认连接127.0.0.1 端口 6379 的服务实例。

参数 解释
-h 主机
-p 端口
-a 密码, 后者后续通过auth来显示认证
-n 指定数据库0~15

例子:

$ redis-cli -h 127:0:0:1 -p 6379 -a root ping
PONG

一、交互模式

启动
$ redis-cli
127.0.0.1:6379> ping
PONG
127.0.0.1:6379> select 2
OK
127.0.0.1:6379[2]> dbsize
(integer) 1
127.0.0.1:6379[2]> select 0
OK
127.0.0.1:6379> dbsize
(integer) 50
处理连接和重新连接 connect

connect通过指定我们要连接的主机名和端口,在交互模式下使用该命令可以连接到不同的实例:

127.0.0.1:6379> connect baobao 6379
baobao:6379> ping
PONG
重复运行命令

通过在命令名称前加上一个数字,可以多次运行相同的命令:

127.0.0.1:6379> 5 incr foo
(integer) 1
(integer) 2
(integer) 3
(integer) 4
(integer) 5
清屏 clear

二、命令行模式

重复运行 -r

可以在用户选择的两次执行之间暂停的情况下,将同一命令执行指定的次数

参数 解释
-r 运行命令的次数, 若想一直重复则使用-1
-i 运行间隔, 单位是秒,如果想使用毫秒,可以用 -i 0.001

例1:对foo自增5次

$ redis-cli -r 5 incr foo
(integer) 1
(integer) 2
(integer) 3
(integer) 4
(integer) 5

例2:每隔1秒执行一次ping,执行5次

$ redis-cli -r 5 -i 1 ping
PONG
PONG
PONG
PONG
PONG

例3: 每隔1秒打印一次 RSS 内存大小

$ redis-cli -r -1 -i 1 INFO | grep rss_human
used_memory_rss_human:1.38M
used_memory_rss_human:1.38M
used_memory_rss_human:1.38M
CSV 输出 --csv

有时您可能希望使用redis-cli以快速将数据从 Redis 导出到外部程序。这可以使用 CSV(逗号分隔值)输出功能来完成:

$ redis-cli lpush mylist a b c d
(integer) 4
$ redis-cli --csv lrange mylist 0 -1
"d","c","b","a"

目前不可能像那样导出整个数据库,而只能运行带有 CSV 输出的单个命令。

从其他程序获取输入 -x

–x表示从标准输入(stdin)读取数据作为redis-cli的最后一个参数,一般与管道符在一起使用。

例如:

$ echo dbsize|redis-cli -x 
(integer) 14
$ echo world|redis-cli -n 14  -x  set hello
OK
$ redis-cli -x set foo < /etc/services
OK
批量执行命令 –-pipe

-–pipe 用于将命令封装成Redis通信协议定义的数据格式,批量发送给Redis执行。

命令格式如下

cat redis.txt | redis-cli -h 127.0.0.1 -a password - p 6379 --pipe

其中redis.txt 格式为

set myname baobao
set yourname popo

注意导入前需要进行文件格式转码

unix2dos  redis.txt 
显示格式 --raw和--no-raw

--no-raw是要求命令的返回结果必须是原始的格式,--raw恰恰相反,返回格式化后的结果。

在Redis中设置一个键,如果用get或–no-row选项,那么返回的结果是二进制格式:

[root@Redis ~]# redis-cli set hello "你好"
OK
[root@Redis ~]# redis-cli get hello
"\xe4\xbd\xa0\xe5\xa5\xbd"
[root@Redis ~]# redis-cli --no-raw get hello
"\xe4\xbd\xa0\xe5\xa5\xbd"

如果使用--raw选项,就会返回中文:

[root@Redis ~]# redis-cli --raw get hello
你好
运行Lua脚本 --eval
$ cat /tmp/script.lua
return redis.call('set',KEYS[1],ARGV[1])
$ redis-cli --eval /tmp/script.lua foo , bar
OK
扫描指定模式的键 –-scan

当数据集发生变化,可能会多次报告键,但如果自迭代开始以来该键就存在,则不会丢失任何键

$ redis-cli --scan | head -4
key-419
key-71
key-236
key-50

请注意,head -10用于打印输出的第一行。

扫描能够使用带有选项的SCAN命令的底层模式匹配功能–-pattern。

$ redis-cli --scan --pattern '*-11*'
key-115
key-114
key-113
key-112
key-111

配合wc可统计特定种类的key个数:

$ redis-cli --scan --pattern 'user:*' | wc -l

三、发布/订阅模式

redis-cli只需使用 PUBLISH命令就可以在Redis发布/订阅通道中发布消息, 通过 SUBSCRIBEPUBLISH进行订阅。

$ redis-cli psubscribe bao-*
Reading messages... (press Ctrl-C to quit)
1) "psubscribe"
2) "bao-*"
3) (integer) 1

阅读邮件消息显示,我们进入的Pub / Sub模式。当另一个客户端在某个通道中发布某些消息时(例如redis-cli PUBLISH bao-1 hello),发布/订阅模式下的CLI将显示以下内容:

1) "pmessage"
2) "bao-*"
3) "bao-1"
4) "hello"

更多功能 --hep

$ redis-cli --help

若想进行服务监控, 可查看我另一篇博客: redis 服务监控

相关文章

网友评论

      本文标题:redis-cli 详细用法

      本文链接:https://www.haomeiwen.com/subject/slltkdtx.html