關於Redis五種類型對象的學習筆記

來源:互聯網
上載者:User

標籤:redis   五種對象   對象共用   記憶體回收   空轉時間長度   

我們在使用Redis的時候,直接接觸到的是字串對象(String),列表對象(List),雜湊對象(Hash),集合對象(Set),有序集合對象(SortedSet)這五種類型的對象,基本的命令如:String(get set) List(lpush rpush lpop rpop lrange) Hash(hget hset hlen hgetall) Set(sadd smembers smov) SortedSet(Zadd Zrange)等。

我們首先看一下redis對象的資料結構:

<span style="font-size:14px;">typedef struct redisObject {    unsigned type:4;    unsigned encoding:4;    unsigned lru:REDIS_LRU_BITS; /* lru time (relative to server.lruclock) */    int refcount;    void *ptr;} robj;</span>
其中type屬性是記錄對象的類型,可以是REDIS_STRING  REDIS_LIST   REDIS_HASH  REDIS_SET REDIS_ZSET 這五個常量

可以使用命令type來查看一個鍵屬於什麼類型,如下:

<span style="font-size:14px;">127.0.0.1:6379> set name "hell world"OK127.0.0.1:6379> get name"hell world"127.0.0.1:6379> type namestring127.0.0.1:6379> sadd sname "zhangsan" "lisi" "wangwu"(integer) 3127.0.0.1:6379> smembers sname1) "wangwu"2) "zhangsan"3) "lisi"127.0.0.1:6379> type snameset127.0.0.1:6379> lpush lname "zhang" "wang" "zhao" "li"(integer) 4127.0.0.1:6379> lrange lname 0 -11) "li"2) "zhao"3) "wang"4) "zhang"127.0.0.1:6379> type lnamelist127.0.0.1:6379></span>

另外encoding屬性記錄了對象使用什麼編碼,這個需要說明一點,redis可以針對不同的使用情境,為對象設定多種不同的資料結構實現,比如,都是hash類型對象,針對不同的資料,可以使用不同的底層實現,如果是hash中的鍵比較少,並且儲存的元素也都是比較短的字串的時候,使用的底層實現是壓縮列表,反之,使用字典作為底層實現,可以使用object encoding命令查看使用的什麼底層實現。

127.0.0.1:6379> object encoding name"embstr"127.0.0.1:6379> object encoding sname"hashtable"127.0.0.1:6379> object encoding lname"ziplist"127.0.0.1:6379>
這樣做的好處是什嗎?可以提高靈活性和效率,根據不同的使用情境來為對象設定不同的編碼,最佳化對象在某一情境下的效率。

接下來的refcount屬性是做什麼用的呢?設計到兩個內容,一是記憶體回收,一個是對象共用

這個計數器就是當一個對象被建立出來之後,refcount+1,當對象被一個新程式引用,那麼計數器+1,反之-1,但這個計數器為0的時候,表示資源可以被釋放了

至於對象共用,【redis值對包含整數型的字串對象進行共用】

127.0.0.1:6379> set aa 100OK127.0.0.1:6379> object refcount aa(integer) 2127.0.0.1:6379> set bb 100OK127.0.0.1:6379> object refcount aa(integer) 3127.0.0.1:6379> object refcount bb(integer) 3127.0.0.1:6379> set cc 100OK127.0.0.1:6379> object refcount aa(integer) 4127.0.0.1:6379>
redisObject資料結構中還有兩個屬性沒有介紹,一個是ptr 一個是lru

ptr是一個對象指標,指向的就是該對象的底層實現資料結構,這個資料結構是由encoding屬性決定的。

lru屬性設計到一個對象空轉時間長度的概念 object idletime命令可以得到某個鍵的空轉時間長度,也就是這個命令多長時間沒有被訪問了,lru裡記錄的是最後一個被訪問的時間

127.0.0.1:6379> object idletime aa(integer) 1775127.0.0.1:6379> object idletime bb(integer) 1781127.0.0.1:6379> object idletime cc(integer) 1787127.0.0.1:6379> set cc "zhangsan"OK127.0.0.1:6379> set cc "zhangsan"OK127.0.0.1:6379> object idletime cc(integer) 3127.0.0.1:6379> object idletime cc(integer) 5127.0.0.1:6379> object idletime cc(integer) 6127.0.0.1:6379> object idletime cc(integer) 7127.0.0.1:6379>

======================================================================================================


著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

關於Redis五種類型對象的學習筆記

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.