在定位問(wèn)題、測(cè)試等時(shí)候經(jīng)常需要對(duì)memcache的數(shù)據(jù)進(jìn)行一些操作,但是其本身沒(méi)有自帶的客戶(hù)端,所以只能通過(guò)telnet來(lái)進(jìn)行操作。
通過(guò)telnet連接memcache。
memcache寫(xiě)入操作
telnet寫(xiě)入memcache命令格式
參數(shù)詳解:
1.<command name> 可以是”set”, “add”, “replace”。
set:<key>不存在時(shí)添加,<key>存在時(shí)覆蓋。
add:<key>不存在時(shí)添加,<key>存在時(shí)則會(huì)操作失敗。
replace:<key>不存在時(shí)添加失敗,<key>存在時(shí)替換數(shù)據(jù)
2.<key> 保存數(shù)據(jù)的key
3.<flags> 是一個(gè)16位的無(wú)符號(hào)的整數(shù)(以十進(jìn)制的方式表示)。
該標(biāo)志將和需要存儲(chǔ)的數(shù)據(jù)一起存儲(chǔ),并在客戶(hù)端get數(shù)據(jù)時(shí)返回。
客戶(hù)可以將此標(biāo)志用做特殊用途,此標(biāo)志對(duì)服務(wù)器來(lái)說(shuō)是透明的。
4.<exptime> 過(guò)期的時(shí)間。
0表示存儲(chǔ)的數(shù)據(jù)永遠(yuǎn)不過(guò)時(shí)(但可被服務(wù)器算法:LRU 等替換)。
非0(unix時(shí)間),當(dāng)過(guò)期后,服務(wù)器可以保證用戶(hù)得不到該數(shù)據(jù)(以服務(wù)器時(shí)間為標(biāo)準(zhǔn))。
5.<bytes> 需要存儲(chǔ)的字節(jié)數(shù)(不包含最后的”/r/n”),當(dāng)用戶(hù)希望存儲(chǔ)空數(shù)據(jù)時(shí),可以為0
6.最后客戶(hù)端需要加上”/r/n”作為”命令頭”的結(jié)束標(biāo)志。
7.<data block>/r/n
緊接著”命令頭”結(jié)束之后就要發(fā)送數(shù)據(jù)塊(即希望存儲(chǔ)的數(shù)據(jù)內(nèi)容),最后加上”/r/n”作為此次通訊的結(jié)束。
telnet響應(yīng)命令
當(dāng)以上數(shù)據(jù)發(fā)送結(jié)束之后,服務(wù)器將返回一個(gè)應(yīng)答。可能有如下的情況:
1.STORED/r/n:表示存儲(chǔ)成功
2.NOT_STORED/r/n: 表示存儲(chǔ)失敗,但是該失敗不是由于錯(cuò)誤。
> 通常這是由于”add”或者”replace”命令本身的要求所引起的,或者該項(xiàng)在刪除隊(duì)列之中。
示例
獲取Key&Value
獲取命令格式
參數(shù)詳解:
1.<key>*: 表示一個(gè)或者多個(gè)key(以空格分開(kāi))
2./r/n:命令結(jié)束
響應(yīng)結(jié)果
服務(wù)器端將返回0個(gè)或者多個(gè)的數(shù)據(jù)項(xiàng)。每個(gè)數(shù)據(jù)項(xiàng)都是由一個(gè)文本行和一個(gè)數(shù)據(jù)塊組成。當(dāng)所有的數(shù)據(jù)項(xiàng)都接收完畢將收到END/r/n每一項(xiàng)的數(shù)據(jù)結(jié)構(gòu):
參數(shù)詳解:
1.<key> 希望得到存儲(chǔ)數(shù)據(jù)的key
2.<falg> 發(fā)送set命令時(shí)設(shè)置的標(biāo)志項(xiàng)
3.<bytes>發(fā)送數(shù)據(jù)塊的長(zhǎng)度(不包含”/r/n”)
4./r/n 文本行的結(jié)束標(biāo)志
5.<data block> 希望接收的數(shù)據(jù)項(xiàng)。
6./r/n 接收一個(gè)數(shù)據(jù)項(xiàng)的結(jié)束標(biāo)志。
PS:如果有些key出現(xiàn)在get命令行中但沒(méi)有返回相應(yīng)的數(shù)據(jù),這意味著服務(wù)器中不存在改項(xiàng),可能是超時(shí)了,或者被刪除了.
示例
刪除KeyValue:
檢查Memcache服務(wù)器狀態(tài)
在這里可以看到memcache的獲取次數(shù),當(dāng)前連接數(shù),寫(xiě)入次數(shù),已經(jīng)命中率等;
清空統(tǒng)計(jì)數(shù)據(jù):
清空所有鍵值
注:flush并不會(huì)將items刪除,只是將所有的items標(biāo)記為expired,因此這時(shí)memcache依舊占用所有內(nèi)存。
退出
其他命令
1.顯示各個(gè)slab的信息,包括chunk的大小、數(shù)目、使用情況等
2.顯示各個(gè)slab中item的數(shù)目和最老item的年齡(最后一次訪問(wèn)距離現(xiàn)在的秒數(shù))
3.設(shè)置或者顯示詳細(xì)操作記錄
參數(shù)為on,打開(kāi)詳細(xì)操作記錄
參數(shù)為off,關(guān)閉詳細(xì)操作記錄
參數(shù)為dump,顯示詳細(xì)操作記錄(每一個(gè)鍵值get、set、hit、del的次數(shù))
4.顯示某個(gè)slab中的前l(fā)imit_num個(gè)key列表
<key_name>:鍵名
<value_length>:值長(zhǎng)度(單位字節(jié))
<expire_time|access_time>:memcached 1.2.2及以前版本顯示的是 訪問(wèn)時(shí)間(timestamp)
新聞熱點(diǎn)
疑難解答
圖片精選