美文网首页
第三章:小功能大用处-Redis Shell

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

作者: super_pcm | 来源:发表于2019-08-02 11:06 被阅读0次

    3.2 Redis Shell

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

    3.2.1 redis-cli详解

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

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

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

    • -x
      -x选项代表从标准输入(stdin)读取数据作为redis-cli的最后一个参数,例如下面的操作会将字符串world作为set hello的值.
    echo "world" | redis-cli -x set hello
    
    • -c
      -c(cluster)选项是连接Redis Cluster节点时需要使用的,-c选项可以防止moved和ask异常,有关Redis Cluster将在第10章介绍。
    • -a
      如果Redis配置了密码,可以用-a(auth)选项,有了这个选项就不需要手动输入auth命令。
    • --scan和--pattern
      --scan选项和--pattern选项用于扫描指定模式的键,相当于使用scan命令
    • --slave
      --slave选项是把当前客户端模拟成当前Redis节点的从节点,可以用来获取当前Redis节点的更新操作,有关于Redis复制将在第6章进行详细介绍。合理的利用这个选项可以记录当前连接Redis节点的一些更新操作,这些更新操作很可能是实际开发业务时需要的数据。
    • --rdb
      --rdb选项会请求Redis实例生成并发送RDB持久化文件,保存在本地。可使用它做持久化文件的定期备份。有关Redis持久化将在第5章进行详细介绍。
    • --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
    
    • --bigkeys
      --bigkeys选项使用scan命令对Redis的键进行采样,从中找到内存占用比较大的键值,这些键可能是系统的瓶颈。
    • --eval
      --eval选项用于执行指定Lua脚本
    • --latency
      latency有三个选项,分别是--latency、--latency-history、--latency-dist。它们都可以检测网络延迟,对于Redis的开发和运维非常有帮助。
    • --stat
      --stat选项可以实时获取Redis的重要统计信息,虽然info命令中的统计信息更全,但是能实时看到一些增量的数据(例如requests)对于Redis的运维还是有一定帮助的.
    • --raw和--no-raw
      --no-raw选项是要求命令的返回结果必须是原始的格式,--raw恰恰相反,返回格式化后的结果。如果你要返回中文内容的话,需要使用--raw.

    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等。

    相关文章

      网友评论

          本文标题:第三章:小功能大用处-Redis Shell

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