第三章:小功能大用处-Redis Shell

2019-08-02  本文已影响0人  super_pcm

3.2 Redis Shell

Redis提供了redis-cli、redis-server、redis-benchmarkShell工具。它们虽然比较简单,但是麻雀虽小五脏俱全,有时可以很巧妙地解决一些问题。

3.2.1 redis-cli详解

除了-h 和-p参数之外,redis-cli还有其他的参数,要了解全部的参数可以执行redis-cli --help命令来查看。

redis-cli -r 3 ping
redis-cli -r 5 -i 1 ping

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

echo "world" | redis-cli -x set hello
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

3.2.2 redis-server详解

redis-server除了启动Redis外,还有一个--test-memory选项。redis-server --test-memory可以用来检测当前操作系统能否稳定地分配指定容量的内存给Redis,通过这种检测可以有效避免因为内存问题造成Redis崩溃,例如下面操作检测当前操作系统能否提供1G的内存给Redis:

redis-server --test-memory 1024

整个内存检测的时间比较长。当输出passed this test时说明内存检测完毕,最后会提示--test-memory只是简单检测,如果有质疑可以使用更加专业的内存检测工具.

3.2.3 redis-benchmark详解

redis-benchmark可以为Redis做基准性能测试,它提供了很多选项帮助开发和运维人员测试Redis的相关性能,下面分别介绍这些选项.

  1. -c
    -c(clients)选项代表客户端的并发数量(默认是50)。
  2. -n<request>
    -n(num)选项代表客户端请求总量(默认是100000)。
    例如redis-benchmark -c 100 -n 20000 代表100各个客户端同时请求Redis,一共执行20000次。redis-benchmark会对各类数据结构的命令进行测试,并给出性能指标:
====== GET ======
  20000 requests completed in 0.29 seconds
  100 parallel clients
  3 bytes payload
  keep alive: 1

46.99% <= 1 milliseconds
99.38% <= 2 milliseconds
100.00% <= 2 milliseconds
69686.41 requests per second

例如上面一共执行了20000次get操作,在0.29秒完成,每个请求数据量是3个字节,99.38%的命令执行时间小于2毫秒,Redis每秒可以处理69686.41次get请求。

  1. -q
    -q选项仅仅显示redis-benchmark的requests per second信息,不显示具体的细节
  2. -r
    redis在做性能测试的时候会新建三个键,如果要插入更多的键可以使用-r选项。
127.0.0.1:6379> keys my*
1) "myset:__rand_int__"
2) "mylist"
3) "myhash"
  1. -t
    -t选项可以对指定命令进行基准测试。
redis-benchmark -t get,set  -q
  1. --csv
    --csv选项会将结果按照csv格式输出,便于后续处理,如导出到Excel等。
上一篇下一篇

猜你喜欢

热点阅读