自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Redis命令行工具有趣的罕見用法

數(shù)據(jù)庫(kù) 其他數(shù)據(jù)庫(kù) Redis
我們天天都在使用 Redis 內(nèi)置的命令行工具 redis-cli,久而久之以為它就是一個(gè)簡(jiǎn)單的交互式 Redis 數(shù)據(jù)結(jié)構(gòu)手工操作程序,但是它背后強(qiáng)大的功能絕大多數(shù)同學(xué)可能聞所未聞。本節(jié)我們一起來(lái)挖掘這些鮮為人知的有趣用法。

我們天天都在使用 Redis 內(nèi)置的命令行工具 redis-cli,久而久之以為它就是一個(gè)簡(jiǎn)單的交互式 Redis 數(shù)據(jù)結(jié)構(gòu)手工操作程序,但是它背后強(qiáng)大的功能絕大多數(shù)同學(xué)可能聞所未聞。本節(jié)我們一起來(lái)挖掘這些鮮為人知的有趣用法。

執(zhí)行單條命令

平時(shí)在訪問(wèn) Redis 服務(wù)器,一般都會(huì)使用 redis-cli 進(jìn)入交互模式,然后一問(wèn)一答來(lái)讀寫服務(wù)器,這種情況下我們使用的是它的「交互模式」。還有另外一種「直接模式」,通過(guò)將命令參數(shù)直接傳遞給 redis-cli 來(lái)執(zhí)行指令并獲取輸出結(jié)果。 

  1. $ redis-cli incrby foo 5 
  2. (integer) 5 
  3. $ redis-cli incrby foo 5 
  4. (integer) 10 

如果輸出的內(nèi)容較大,還可以將輸出重定向到外部文件 

  1. $ redis-cli info > info.txt 
  2. $ wc -l info.txt 
  3.      120 info.txt 

上面的命令指向的服務(wù)器是默認(rèn)服務(wù)器地址,如果想指向特定的服務(wù)器可以這樣 

  1. // -n 2 表示使用第2個(gè)庫(kù),相當(dāng)于 select 2 
  2. $ redis-cli -h localhost -p 6379 -n 2 ping 
  3. PONG 

批量執(zhí)行命令

在平時(shí)線上的開發(fā)過(guò)程中,有時(shí)候我們免不了要手工造數(shù)據(jù),然后導(dǎo)入 Redis。通常我們會(huì)編寫腳本程序來(lái)做這件事。不過(guò)還有另外一種比較便捷的方式,那就是直接使用 redis-cli 來(lái)批量執(zhí)行一系列指令。 

  1. $ cat cmds.txt 
  2. set foo1 bar1 
  3. set foo2 bar2 
  4. set foo3 bar3 
  5. ...... 
  6. $ cat cmds.txt | redis-cli 
  7. OK 
  8. OK 
  9. OK 
  10. ... 

上面的指令使用了 Unix 管道將 cat 指令的標(biāo)準(zhǔn)輸出連接到 redis-cli 的標(biāo)準(zhǔn)輸入。其實(shí)還可以直接使用輸入重定向來(lái)批量執(zhí)行指令。 

  1. $ redis-cli < cmds.txt 
  2. OK 
  3. OK 
  4. OK 
  5. ... 

set 多行字符串

如果一個(gè)字符串有多行,你希望將它傳入 set 指令,redis-cli 要如何做?可以使用 -x 選項(xiàng),該選項(xiàng)會(huì)使用標(biāo)準(zhǔn)輸入的內(nèi)容作為最后一個(gè)參數(shù)。 

  1. $ cat str.txt 
  2. Ernest Hemingway once wrote, 
  3. "The world is a fine place and worth fighting for." 
  4. I agree with the second part. 
  5. $ redis-cli -x set foo < str.txt 
  6. OK 
  7. $ redis-cli get foo 
  8. "Ernest Hemingway once wrote,\n\"The world is a fine place and worth fighting for.\"\nI agree with the second part.\n" 

重復(fù)執(zhí)行指令

redis-cli 還支持重復(fù)執(zhí)行指令多次,每條指令執(zhí)行之間設(shè)置一個(gè)間隔時(shí)間,如此便可以觀察某條指令的輸出內(nèi)容隨時(shí)間變化。 

  1. // 間隔1s,執(zhí)行5次,觀察qps的變化 
  2. $ redis-cli -r 5 -i 1 info | grep ops 
  3. instantaneous_ops_per_sec:43469 
  4. instantaneous_ops_per_sec:47460 
  5. instantaneous_ops_per_sec:47699 
  6. instantaneous_ops_per_sec:46434 
  7. instantaneous_ops_per_sec:47216 

如果將次數(shù)設(shè)置為 -1 那就是重復(fù)無(wú)數(shù)次永遠(yuǎn)執(zhí)行下去。如果不提供 -i 參數(shù),那就沒有間隔,連續(xù)重復(fù)執(zhí)行。在交互模式下也可以重復(fù)執(zhí)行指令,形式上比較怪異,在指令前面增加次數(shù) 

  1. 127.0.0.1:6379> 5 ping 
  2. PONG 
  3. PONG 
  4. PONG 
  5. PONG 
  6. PONG 
  7. # 下面的指令很可怕,你的屏幕要憤怒了 
  8. 127.0.0.1:6379> 10000 info 
  9. ....... 

導(dǎo)出 csv

redis-cli 不能一次導(dǎo)出整個(gè)庫(kù)的內(nèi)容為 csv,但是可以導(dǎo)出單條指令的輸出為 csv 格式。 

  1. $ redis-cli rpush lfoo a b c d e f g 
  2. (integer) 7 
  3. $ redis-cli --csv lrange lfoo 0 -1 
  4. "a","b","c","d","e","f","g" 
  5. $ redis-cli hmset hfoo a 1 b 2 c 3 d 4 
  6. OK 
  7. $ redis-cli --csv hgetall hfoo 
  8. "a","1","b","2","c","3","d","4" 

當(dāng)然這種導(dǎo)出功能比較弱,僅僅是一堆字符串用逗號(hào)分割開來(lái)。不過(guò)你可以結(jié)合命令的批量執(zhí)行來(lái)看看多個(gè)指令的導(dǎo)出效果。 

  1. $ redis-cli --csv -r 5 hgetall hfoo 
  2. "a","1","b","2","c","3","d","4" 
  3. "a","1","b","2","c","3","d","4" 
  4. "a","1","b","2","c","3","d","4" 
  5. "a","1","b","2","c","3","d","4" 
  6. "a","1","b","2","c","3","d","4" 

看到這里讀者應(yīng)該明白 --csv 參數(shù)的效果就是對(duì)輸出做了一次轉(zhuǎn)換,用逗號(hào)分割,僅此而已。

執(zhí)行 lua 腳本

在 lua 腳本小節(jié),我們使用 eval 指令來(lái)執(zhí)行腳本字符串,每次都是將腳本內(nèi)容壓縮成單行字符串再調(diào)用 eval 指令,這非常繁瑣,而且可讀性很差。redis-cli 考慮到了這點(diǎn),它可以直接執(zhí)行腳本文件。 

  1. 127.0.0.1:6379> eval "return redis.pcall('mset', KEYS[1], ARGV[1], KEYS[2], ARGV[2])" 2 foo1 foo2 bar1 bar2 
  2. OK 
  3. 127.0.0.1:6379> eval "return redis.pcall('mget', KEYS[1], KEYS[2])" 2 foo1 foo2 
  4. 1) "bar1" 
  5. 2) "bar2" 

下面我們以腳本的形式來(lái)執(zhí)行上面的指令,參數(shù)形式有所不同,KEY 和 ARGV 之間需要使用逗號(hào)分割,并且不需要提供 KEY 的數(shù)量參數(shù) 

  1. $ cat mset.txt 
  2. return redis.pcall('mset', KEYS[1], ARGV[1], KEYS[2], ARGV[2]) 
  3. $ cat mget.txt 
  4. return redis.pcall('mget', KEYS[1], KEYS[2]) 
  5. $ redis-cli --eval mset.txt foo1 foo2 , bar1 bar2 
  6. OK 
  7. $ redis-cli --eval mget.txt foo1 foo2 
  8. 1) "bar1" 
  9. 2) "bar2" 

如果你的 lua 腳本太長(zhǎng),--eval 將大有用處。

監(jiān)控服務(wù)器狀態(tài)

我們可以使用 --stat 參數(shù)來(lái)實(shí)時(shí)監(jiān)控服務(wù)器的狀態(tài),間隔 1s 實(shí)時(shí)輸出一次。 

  1. $ redis-cli --stat 
  2. ------- data ------ --------------------- load -------------------- - child - 
  3. keys       mem      clients blocked requests            connections 
  4. 2          6.66M    100     0       11591628 (+0)       335 
  5. 2          6.66M    100     0       11653169 (+61541)   335 
  6. 2          6.66M    100     0       11706550 (+53381)   335 
  7. 2          6.54M    100     0       11758831 (+52281)   335 
  8. 2          6.66M    100     0       11803132 (+44301)   335 
  9. 2          6.66M    100     0       11854183 (+51051)   335 

如果你覺得間隔太長(zhǎng)或是太短,可以使用 -i 參數(shù)調(diào)整輸出間隔。

掃描大 KEY

這個(gè)功能太實(shí)用了,我已經(jīng)在線上試過(guò)無(wú)數(shù)次了。每次遇到 Redis 偶然卡頓問(wèn)題,第一個(gè)想到的就是實(shí)例中是否存在大 KEY,大 KEY的內(nèi)存擴(kuò)容以及釋放都會(huì)導(dǎo)致主線程卡頓。如果知道里面有沒有大 KEY,可以自己寫程序掃描,不過(guò)這太繁瑣了。redis-cli 提供了 --bigkeys 參數(shù)可以很快掃出內(nèi)存里的大 KEY,使用 -i 參數(shù)控制掃描間隔,避免掃描指令導(dǎo)致服務(wù)器的 ops 陡增報(bào)警。 

  1. $ ./redis-cli --bigkeys -i 0.01 
  2. # Scanning the entire keyspace to find biggest keys as well as 
  3. # average sizes per key type.  You can use -i 0.1 to sleep 0.1 sec 
  4. # per 100 SCAN commands (not usually needed). 
  5.  
  6. [00.00%] Biggest zset   found so far 'hist:aht:main:async_finish:20180425:17' with 1440 members 
  7. [00.00%] Biggest zset   found so far 'hist:qps:async:authorize:20170311:27' with 2465 members 
  8. [00.00%] Biggest hash   found so far 'job:counters:6ya9ypu6ckcl' with 3 fields 
  9. [00.01%] Biggest string found so far 'rt:aht:main:device_online:68:{-4}' with 4 bytes 
  10. [00.01%] Biggest zset   found so far 'machine:load:20180709' with 2879 members 
  11. [00.02%] Biggest string found so far '6y6fze8kj7cy:{-7}' with 90 bytes 

redis-cli 對(duì)于每一種對(duì)象類型都會(huì)記錄長(zhǎng)度最大的 KEY,對(duì)于每一種對(duì)象類型,刷新一次最高記錄就會(huì)立即輸出一次。它能保證輸出長(zhǎng)度為 Top1 的 KEY,但是 Top2、Top3等 KEY 是無(wú)法保證可以掃描出來(lái)的。一般的處理方法是多掃描幾次,或者是消滅了 Top1 的 KEY 之后再掃描確認(rèn)還有沒有次大的 KEY。

采樣服務(wù)器指令

現(xiàn)在線上有一臺(tái) Redis 服務(wù)器的 OPS 太高,有很多業(yè)務(wù)模塊都在使用這個(gè) Redis,如何才能判斷出來(lái)是哪個(gè)業(yè)務(wù)導(dǎo)致了 OPS 異常的高。這時(shí)可以對(duì)線上服務(wù)器的指令進(jìn)行采樣,觀察采樣的指令大致就可以分析出 OPS 占比高的業(yè)務(wù)點(diǎn)。這時(shí)就要使用 monitor 指令,它會(huì)將服務(wù)器瞬間執(zhí)行的指令全部顯示出來(lái)。不過(guò)使用的時(shí)候要注意即使使用 ctrl+c 中斷,否則你的顯示器會(huì)噼里啪啦太多的指令瞬間讓你眼花繚亂。 

  1. $ redis-cli --host 192.168.x.x --port 6379 monitor 
  2. 1539853410.458483 [0 10.100.90.62:34365] "GET" "6yax3eb6etq8:{-7}" 
  3. 1539853410.459212 [0 10.100.90.61:56659] "PFADD" "growth:dau:20181018" "2klxkimass8w" 
  4. 1539853410.462938 [0 10.100.90.62:20681] "GET" "6yax3eb6etq8:{-7}" 
  5. 1539853410.467231 [0 10.100.90.61:40277] "PFADD" "growth:dau:20181018" "2kei0to86ps1" 
  6. 1539853410.470319 [0 10.100.90.62:34365] "GET" "6yax3eb6etq8:{-7}" 
  7. 1539853410.473927 [0 10.100.90.61:58128] "GET" "6yax3eb6etq8:{-7}" 
  8. 1539853410.475712 [0 10.100.90.61:40277] "PFADD" "growth:dau:20181018" "2km8sqhlefpc" 
  9. 1539853410.477053 [0 10.100.90.62:61292] "GET" "6yax3eb6etq8:{-7}"  

診斷服務(wù)器時(shí)延

平時(shí)我們?cè)\斷兩臺(tái)機(jī)器的時(shí)延一般是使用 Unix 的 ping 指令。Redis 也提供了時(shí)延診斷指令,不過(guò)它的原理不太一樣,它是診斷當(dāng)前機(jī)器和 Redis 服務(wù)器之間的指令(PING指令)時(shí)延,它不僅僅是物理網(wǎng)絡(luò)的時(shí)延,還和當(dāng)前的 Redis 主線程是否忙碌有關(guān)。如果你發(fā)現(xiàn) Unix 的 ping 指令時(shí)延很小,而 Redis 的時(shí)延很大,那說(shuō)明 Redis 服務(wù)器在執(zhí)行指令時(shí)有微弱卡頓。 

  1. $ redis-cli --host 192.168.x.x --port 6379 --latency 
  2. min: 0, max: 5, avg: 0.08 (305 samples) 

時(shí)延單位是 ms。redis-cli 還能顯示時(shí)延的分布情況,而且是圖形化輸出。 

  1. $ redis-cli --latency-dist 

 

 

圖片 

 

這個(gè)圖形的含義作者沒有描述,讀者們可以嘗試破解一下。

遠(yuǎn)程 rdb 備份

執(zhí)行下面的命令就可以將遠(yuǎn)程的 Redis 實(shí)例備份到本地機(jī)器,遠(yuǎn)程服務(wù)器會(huì)執(zhí)行一次bgsave操作,然后將 rdb 文件傳輸?shù)娇蛻舳?。遠(yuǎn)程 rdb 備份讓我們有一種“秀才不出門,全知天下事”的感覺。 

  1. $ ./redis-cli --host 192.168.x.x --port 6379 --rdb ./user.rdb 
  2. SYNC sent to master, writing 2501265095 bytes to './user.rdb' 
  3. Transfer finished with success. 

模擬從庫(kù)如果你想觀察主從服務(wù)器之間都同步了那些數(shù)據(jù),可以使用 redis-cli 模擬從庫(kù)。 

  1. $ ./redis-cli --host 192.168.x.x --port 6379 --slave 
  2. SYNC with master, discarding 51778306 bytes of bulk transfer... 
  3. SYNC done. Logging commands from master. 
  4. ... 

從庫(kù)連上主庫(kù)的第一件事是全量同步,所以看到上面的指令卡頓這很正常,待首次全量同步完成后,就會(huì)輸出增量的 aof 日志。 

責(zé)任編輯:龐桂玉 來(lái)源: 數(shù)據(jù)和云
相關(guān)推薦

2017-06-15 10:32:56

OracleDBV命令行工具

2014-10-31 10:50:28

Linux命令行工具

2010-07-15 10:47:22

Perl命令行

2015-05-25 10:40:22

Linux命令行技巧

2014-09-11 10:57:02

命令行

2020-12-10 16:16:08

工具代碼開發(fā)

2020-12-11 06:44:16

命令行工具開發(fā)

2011-01-18 19:11:26

Postfix命令行

2023-06-09 07:45:29

Kuberneteskubectl

2013-11-15 09:43:15

JDK工具

2010-07-15 10:58:23

Perl命令行程序

2010-11-24 17:12:17

MySQL命令行

2013-12-09 14:29:13

OpenStack命令行工具API

2010-02-04 15:17:48

Linux wget

2018-04-03 13:50:27

Linux容器命令行工具

2010-07-15 12:45:30

Perl命令行

2010-07-20 14:27:46

Perl命令行

2015-07-01 09:15:46

linuxQuora命令行

2013-05-21 14:58:08

系統(tǒng)監(jiān)視glances開源

2018-05-04 09:15:35

PythonPlumbum命令行
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)