redis-cli的全部参数,可以执行redis-cli-help命令来进 行查看

1.-r

-r(repeat)选项代表将命令执行多次,例如下面操作将会执行三次ping 命令:

redis-cli -r 3 ping 
PONG 
PONG 
PONG

2.-i

-i(interval)选项代表每隔几秒执行一次命令,但是-i选项必须和-r选 项一起使用,下面的操作会每隔1秒执行一次ping命令,一共执行5次:

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

注意-i的单位是秒,不支持毫秒为单位,但是如果想以每隔10毫秒执行 一次,可以用-i0.01,例如:

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

例如下面的操作利用-r和-i选项,每隔1秒输出内存的使用量,一共输出 100次:

redis-cli -r 100 -i 1 info | grep used_memory_human 
used_memory_human:2.95G 
used_memory_human:2.95G 
...................... 
used_memory_human:2.94G

3.-x

-x选项代表从标准输入(stdin)读取数据作为redis-cli的最后一个参 数,例如下面的操作会将字符串world作为set hello的值:

$ echo "world" | redis-cli -x set hello 
OK

4.-c

-c(cluster)选项是连接Redis Cluster节点时需要使用的,-c选项可以防 止moved和ask异常,有关Redis Cluster将在后面介绍。

5.-a

如果Redis配置了密码,可以用-a(auth)选项,有了这个选项就不需要 手动输入auth命令。

6.–scan和–pattern

–scan选项和–pattern选项用于扫描指定模式的键,相当于使用scan命令。

7.–slave

–slave选项是把当前客户端模拟成当前Redis节点的从节点,可以用来 获取当前Redis节点的更新操作,有关于Redis复制将在第6章进行详细介 绍。合理的利用这个选项可以记录当前连接Redis节点的一些更新操作,这 些更新操作很可能是实际开发业务时需要的数据。
下面开启第一个客户端,使用–slave选项,看到同步已完成:

$ redis-cli --slave 
SYNC with master, discarding 72 bytes of bulk transfer... 
SYNC done. Logging commands from master.

再开启另一个客户端做一些更新操作:

redis-cli 127.0.0.1:6379> set hello world 
OK 
127.0.0.1:6379> set a b 
OK 
127.0.0.1:6379> incr count 1 
127.0.0.1:6379> get hello "world"

第一个客户端会收到Redis节点的更新操作:

redis-cli --slave 
SYNC with master, discarding 72 bytes of bulk transfer... 
SYNC done. Logging commands from master. 
"PING" 
"PING" 
"PING" 
"PING" 
"PING" 
"SELECT","0" 
"set","hello","world" 
"set","a","b" 
"PING" 
"incr","count"

注意 PING命令是由于主从复制产生的,第6章会对主从复制进行介绍。

8. --rdb

–rdb选项会请求Redis实例生成并发送RDB持久化文件,保存在本地。 可使用它做持久化文件的定期备份。有关Redis持久化将在第5章进行详细介 绍。

9. --pipe

–pipe选项用于将命令封装成Redis通信协议定义的数据格式,批量发送 给Redis执行,有关Redis通信协议将在第4章进行详细介绍,例如下面操作 同时执行了set hello world和incr counter两条命令:

echo -en '*3\r\n$3\r\nSET\r\n$5\r\nhello\r\n$5\r\nworld\r\n*2\r\n$4\r\nincr\r\ n$7\r\ncounter\r\n' | redis-cli --pipe

10. --bigkeys

–bigkeys选项使用scan命令对Redis的键进行采样,从中找到内存占用比 较大的键值,这些键可能是系统的瓶颈。

11. --eval

–eval选项用于执行指定Lua脚本,有关Lua脚本的使用将在3.4节介绍。

12. --latency

latency有三个选项,分别是–latency、–latency-history、–latency-dist。 它们都可以检测网络延迟,对于Redis的开发和运维非常有帮助。

(1)–latency

该选项可以测试客户端到目标Redis的网络延迟,例如当前拓扑结构如 图3-4所示。客户端B和Redis在机房B,客户端A在机房A,机房A和机房B是 跨地区的。

025、工具_redis-cli_Redis

客户端B:

redis-cli -h {machineB} --latency 
min: 0, max: 1, avg: 0.07 (4211 samples)

客户端A:

redis-cli -h {machineB} --latency 
min: 0, max: 2, avg: 1.04 (2096 samples)

可以看到客户端A由于距离Redis比较远,平均网络延迟会稍微高一些。

(2)–latency-history
–latency的执行结果只有一条,如果想以分时段的形式了解延迟信息, 可以使用–latency-history选项:

redis-cli -h 10.10.xx.xx --latency-history 
min: 0, max: 1, avg: 0.28 (1330 samples) -- 15.01 seconds range… 
min: 0, max: 1, avg: 0.05 (1364 samples) -- 15.01 seconds range

可以看到延时信息每15秒输出一次,可以通过-i参数控制间隔时间。

(3)–latency-dist 该选项会使用统计图表的形式从控制台输出延迟统计信息。

13. --stat

–stat选项可以实时获取Redis的重要统计信息,虽然info命令中的统计信 息更全,但是能实时看到一些增量的数据(例如

requests)对于Redis的运维 还是有一定帮助的,如下所示: 
redis-cli --stat ------- data ------ --------------------- load -------------------- - child - 
keys mem clients blocked requests connections 
2451959 3.43G 1162 0 7426132839 (+0) 1337356 
2451958 3.42G 1162 0 7426133645 (+806) 1337356 … 
2452182 3.43G 1161 0 7426150275 (+1303) 1337356

14. --raw和 --no-raw

–no-raw选项是要求命令的返回结果必须是原始的格式,–raw恰恰相反,返回格式化后的结果。 在Redis中设置一个中文的value:

$redis-cli set hello "你好" 
OK

如果正常执行get或者使用–no-raw选项,那么返回的结果是二进制格 式:

$redis-cli get hello 
"\xe4\xbd\xa0\xe5\xa5\xbd" 

$redis-cli --no-raw get hello 
"\xe4\xbd\xa0\xe5\xa5\xbd"

如果使用了–raw选项,将会返回中文:

$redis-cli --raw get hello
你好