在telnet下操作memcache詳解(操作命令詳解)
在定位問(wèn)題、測(cè)試等時(shí)候經(jīng)常需要對(duì)memcache的數(shù)據(jù)進(jìn)行一些操作,但是其本身沒(méi)有自帶的客戶端,所以只能通過(guò)telnet來(lái)進(jìn)行操作。
通過(guò)telnet連接memcache。
telnet 127.0.0.1 11211
memcache寫(xiě)入操作
telnet寫(xiě)入memcache命令格式
<command name> <key> <flags> <exptime> <bytes>\r\n <data block>\r\n
參數(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ǔ),并在客戶端get數(shù)據(jù)時(shí)返回。
客戶可以將此標(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ù)器可以保證用戶得不到該數(shù)據(jù)(以服務(wù)器時(shí)間為標(biāo)準(zhǔn))。
5.<bytes> 需要存儲(chǔ)的字節(jié)數(shù)(不包含最后的”\r\n”),當(dāng)用戶希望存儲(chǔ)空數(shù)據(jù)時(shí),可以為0
6.最后客戶端需要加上”\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)答??赡苡腥缦碌那闆r:
1.STORED\r\n:表示存儲(chǔ)成功
2.NOT_STORED\r\n: 表示存儲(chǔ)失敗,但是該失敗不是由于錯(cuò)誤。
> 通常這是由于”add”或者”replace”命令本身的要求所引起的,或者該項(xiàng)在刪除隊(duì)列之中。
示例
set key 32 0 10\r\n
helloworld\r\n
STORED\r\n
獲取Key&Value
獲取命令格式
get <key>*\r\n
參數(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):
VALUE <key> <flags> <bytes>\r\n
<data block>\r\n
參數(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í)了,或者被刪除了.
示例
get key
VALUE key 32 10
helloworld
END
刪除KeyValue:
參數(shù)詳解:
1.<key> 需要被刪除數(shù)據(jù)的key
2.<time> 客戶端希望服務(wù)器將該數(shù)據(jù)刪除的時(shí)間(unix時(shí)間或者從現(xiàn)在開(kāi)始的秒數(shù))
3.\r\n命令頭的結(jié)束
檢查Memcache服務(wù)器狀態(tài)
在這里可以看到memcache的獲取次數(shù),當(dāng)前連接數(shù),寫(xiě)入次數(shù),已經(jīng)命中率等;
pid : 進(jìn)程id
uptime :總的運(yùn)行時(shí)間,秒數(shù)
time : 當(dāng)前時(shí)間
version : 版本號(hào)
……
curr_items : 當(dāng)前緩存中的KeyValue數(shù)量
total_items : 曾經(jīng)總共經(jīng)過(guò)緩存的KeyValue數(shù)量
bytes : 所有的緩存使用的內(nèi)存量
curr_connections 當(dāng)前連接數(shù)
….
cmd_get : 總獲取次數(shù)
cmd_set : 總的寫(xiě)入次數(shù)
get_hits : 總的命中次數(shù)
miss_hits : 獲取失敗次數(shù)
…..
bytes_read : 總共讀取的流量字節(jié)數(shù)
bytes_written : 總的寫(xiě)入流量字節(jié)
limit_maxbytes : 最大允許使用的內(nèi)存量,字節(jié)
清空統(tǒng)計(jì)數(shù)據(jù):
stats reset
清空所有鍵值
flush_all
注:flush并不會(huì)將items刪除,只是將所有的items標(biāo)記為expired,因此這時(shí)memcache依舊占用所有內(nèi)存。
退出
quit\r\n
其他命令
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)
相關(guān)文章
DataGrip2022導(dǎo)入和導(dǎo)出sql文件圖文教程
這篇文章主要給大家介紹了關(guān)于DataGrip2022導(dǎo)入和導(dǎo)出sql文件的相關(guān)資料,DataGrip的導(dǎo)出功能也是相當(dāng)強(qiáng)大,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10DBeaver操作所有數(shù)據(jù)庫(kù)管理工具使用詳解
這篇文章主要為大家介紹了一款操作所有數(shù)據(jù)庫(kù)工具DBeaver使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07最近關(guān)于Navicat到期的完美解決辦法(親測(cè)有效)
這篇文章主要介紹了最近關(guān)于Navicat到期的完美解決辦法(親測(cè)有效),本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02數(shù)據(jù)庫(kù)連接池Druid與Hikari對(duì)比詳解
這篇文章主要為大家介紹了數(shù)據(jù)庫(kù)連接池Druid與Hikari對(duì)比詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02分布式數(shù)據(jù)存儲(chǔ)系統(tǒng)的三要素
大家好,本篇文章主要講的是分布式數(shù)據(jù)存儲(chǔ)系統(tǒng)的三要素,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12Select data from an Excel sheet in MSSQL
Select data from an Excel sheet in MSSQL...2007-06-06在PostgreSQL中使用日期類型時(shí)一些需要注意的地方
這篇文章主要介紹了在PostgreSQL中使用日期類型時(shí)一些需要注意的地方,包括時(shí)間戳和日期轉(zhuǎn)換等方面,需要的朋友可以參考下2015-04-04用SQL Server訪問(wèn)Sybase中的表的方法
2008-01-01MySQL與Redis如何保證數(shù)據(jù)一致性詳解
在高并發(fā)的業(yè)務(wù)場(chǎng)景下數(shù)據(jù)庫(kù)大多數(shù)情況都是用戶并發(fā)訪問(wèn)最薄弱的環(huán)節(jié),所以就需要使用redis做一個(gè)緩沖操作,讓請(qǐng)求先訪問(wèn)到redis,而不直接訪問(wèn)Mysql等數(shù)據(jù)庫(kù),這篇文章主要給大家介紹了關(guān)于MySQL與Redis如何保證數(shù)據(jù)一致性的相關(guān)資料,需要的朋友可以參考下2021-08-08