3.2、Redis Shell

Redis Shell

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

  1. redis-cli详解

    • -r

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

      redis-cli -r 3 ping
      PONG
      PONG
      PONG
      
    • -i

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

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

      注意-i的单位是秒,不支持毫秒为单位,但是如果想以每隔10毫秒执行一
      次,可以用-i 0.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.95G
      
    • -x

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

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

      -c(cluster)选项是连接Redis Cluster节点是需要使用的,-c选项可以
      防止moved和ask异常

    • -a

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

    • --scan和--pattern

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

    • --slave

      --slave选项是把当前客户端模拟成当前Redis节点的从节点,可以用来获
      取当前Redis节点的更新操作。合理的利用这个选项可以记录当前连接Redis
      节点的一些更新操作,这些更新操作很可能是实际开发业务是需要的数据。

      下面开启第一个客户端,使用--slave选项,看到同步已完成:

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

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

      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 --slava
      SYNC with master,discarding 72 bytes of bulk trandfer...
      SYNC done. Logging commands from master.
      "PING"
      "PING"
      "PING"
      "PING"
      "PING"
      "PING"
      "SELECT","0"
      "set","hello","world"
      "set","a","b"
      "PING"
      "incr","count"
      
    • --rdb

      --rdb选项会请求Redis实例生成并发送RDB持久化文件,保存到本地。可使
      用它做持久化文件的定期备份。

    • --pipe

      --pipe选项用于将命令封装成Redis通信协议定义的数据格式,批量发送给
      Redis执行,例如下面操作同时执行了set hello world和incr counter
      两条命令:

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

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

    • --eval

      --eval选项用于执行指定Lua脚本

    • --latency

      latency有三个选项,分别是--latency、--latency-history、
      --latency-dist。它们都可以检测网络延迟

      (1)--latency

        该选项可以测试客户端到目标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

        该选项会使用统计图表的形式从控制台输出延迟统计信息。
      
    • --stat

      --stat选项可以实时获取Redis的重要统计信息,虽然info命令中的统计信
      息更全,但是能实时看到一些增量的数据(例如requests)对于Redis的运
      维还是有一定帮助的

      redis-cli --stat

    • --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
      你好
      
  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只是简单检测,如果有质疑可以使用更加专业的内存
    检测工具。

    通常无需每次开启Redis实例是都执行--test-memory选项,该功能更偏向于调
    试和测试,例如,想快速沾满机器内存做一些极端条件的测试。

  3. redis-benchmark 详解

    redis-benchmark可以为Redis做基准性能测试,它提供了很多选项帮助开发和
    运维人员测试Redis的相关性能。

    • -c

      -c(clients)选项代表客户端的并发数量(默认是50)。

    • -n < requests >

      -n(num)选项代表客户端请求总量(默认是100000)。
      例如redis-benchmark -c 100 -n 20000代表100各个客户端同时请求
      Redis,一共执行20000次。redis-benchmark会对各类数据结构的命令进
      行测试,并给出性能指标:

      =====GET=====
          20000 requests  completed in 0.27 seconds
          100 parallel clients
          3 bytes payload
          keep alive: 1
      99.11% <= 1 milliseconds
      100.00% <= 1 milliseconds
      73529.41 requests per second
      

      例如上面一共执行了20000次get操作,在0.27秒完成,每个请求数据了是3
      个字节,99.11%的命令执行命令小于1毫秒,Redis每秒可以处理73529.41
      次get请求。

    • -q

      -q选项仅仅显示redis-benchmark的requests per second信息,例如:

      $redis-benchmark -c 100 -n 20000 -q
      PING_INLINE: 74349.45 requests per second
      PING_BULK: 68728.52 requests per second
      SET: 71174.38 requests per second
      ...
      LRANGE_500 (first 450 elements):11299.44 requests per second
      LRANGE_600 (first 600 elements):9319.67 requests per second
      MSET (10 keys): 70671.38 requests per second
      
    • -r

      在一个空的Redis上执行了redis-benchmark会发现只有3个键:

      127.0.0.1:6379> dbsize
      (integer) 3
      127.0.0.1:6379> keys *
      1) "counter:__rand_int__"
      2) "mylist"
      3) "key:__rand_int__"
      

      如果想向Redis插入更多的键,可以执行使用-r(random)选项,可以向
      Redis插入更多随机的键。

      $redis-benchmark -c 100 -n 20000 -r 10000

      -r选项会在key、counter键上加一个12位的后缀,-r 10000代表只对后四
      位做随机处理(-r)。例如上面操作后,key的数量和结果结构如下:

      127.0.0.1:6379> dbsize
      (integer) 18641
      127.0.0.1:6379> scan 0
      1) "14336"
      2) 1) "key:000000004580”
         2) "key:000000004519"
         ...
         3) "key:000000002113"
      
    • -P

      -P选项代表每个请求pipeline的数据了(默认为1)

    • -k < boolean >

      -l选项代表客户端是否使用keepalive,1为使用,0为不使用,默认值为1.

    • -t

      -t选项可以对指定命令进行基准测试。

      redis-benchmark -t get, set -q
      SET: 98619.32 requests per second
      GET: 97560.98 requests per second
      
    • --csv

      --csv选项会将结果按照csv格式输出,便于后续处理,如导出到Excel等。

      redis-benchmark -t get, set --csv
      "SET", "81300.81"
      "GET", "79051.38"
      
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容