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发布/订阅通道中发布消息, 通过 SUBSCRIBE
或PUBLISH
进行订阅。
$ 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 服务监控