redis的hash操作在集中式session中的應用

來源:互聯網
上載者:User

標籤:

在叢集部署時,為了高可用性的目的,往往把session進行共用,共用分為兩種:session複製和集中式管理。

redis在session集中式管理中可以起到比較大的作用。

制約session集中式共用的兩大因素:

1. session必須有ha機制,叢集中部分伺服器發生故障時,保證session不丟失。

2. session的生命週期管理。

3. session的大小未知,整體的序列化和還原序列化成本比較高。

redis的解決方式

1. redis具有持久化功能,且sentiment具有ha功效(redis叢集目前處於beta階段)。

2. redis提供了存留時間管理EXPIRE

3.redis提供hash操作來進行局部的序列化和還原序列化,保證效率。

下面直接參考hashtable相關命令(來自:https://redis.readthedocs.org/en/2.4/hash.html)

雜湊表(Hash)HSET
HSET key field value

將雜湊表key中的域field的值設為value。

如果key不存在,一個新的雜湊表被建立並進行HSET操作。

如果域field已經存在於雜湊表中,舊值將被覆蓋。

時間複雜度:
O(1)
傳回值:
如果field是雜湊表中的一個建立域,並且值設定成功,返回1。如果雜湊表中域field已經存在且舊值已被新值覆蓋,返回0。
redis> HSET website google "www.g.cn"   # 一個新域(integer) 1redis> HSET website google "www.google.com" # 覆蓋一箇舊域(integer) 0
HSETNX
HSETNX key field value

將雜湊表key中的域field的值設定為value,若且唯若域field不存在。

若域field已經存在,該操作無效。

如果key不存在,一個新雜湊表被建立並執行HSETNX命令。

時間複雜度:
O(1)
傳回值:
設定成功,返回1。如果給定域已經存在且沒有操作被執行,返回0。
redis> HSETNX nosql key-value-store redis(integer) 1redis> HSETNX nosql key-value-store redis  # 操作無效,域key-value-store已存在(integer) 0
HMSET
HMSET key field value [field value ...]

同時將多個field - value(域-值)對設定到雜湊表key中。

此命令會覆蓋雜湊表中已存在的域。

如果key不存在,一個空雜湊表被建立並執行HMSET操作。

時間複雜度:
O(N),N為field - value對的數量。
傳回值:
如果命令執行成功,返回OK。當key不是雜湊表(hash)類型時,返回一個錯誤。
# 情況1: 雜湊表redis> HMSET website google www.google.com yahoo www.yahoo.comOKredis> HGET website google"www.google.com"redis> HGET website yahoo"www.yahoo.com"# 情況2:類型錯誤時redis> SET G 10  # 出錯情況OKredis> HMSET G name huangz age 20(error) ERR Operation against a key holding the wrong kind of value
HGET
HGET key field

返回雜湊表key中給定域field的值。

時間複雜度:
O(1)
傳回值:
給定域的值。當給定域不存在或是給定key不存在時,返回nil。
redis> HSET huangz blog huangz.iteye.com(integer) 1redis> HGET huangz blog"huangz.iteye.com"
HMGET
HMGET key field [field ...]

返回雜湊表key中,一個或多個給定域的值。

如果給定的域不存在於雜湊表,那麼返回一個nil值。

因為不存在的key被當作一個空雜湊表來處理,所以對一個不存在的key進行HMGET操作將返回一個只帶有nil值的表。

時間複雜度:
O(N),N為給定域的數量。
傳回值:
一個包含多個給定域的關聯值的表,表值的排列順序和給定域參數的請求順序一樣。
redis> HMSET pet dog "doudou" cat "nounou"  # 一次儲存多個值OKredis> HMGET pet dog cat fake_pet  # 傳回值的順序和傳入參數的順序一樣。1) "doudou"2) "nounou"3) (nil)  # 不存在的域返回nil值
HGETALL
HGETALL key

返回雜湊表key中,所有的域和值。

在傳回值裡,緊跟每個網域名稱(field name)之後是域的值(value),所以傳回值的長度是雜湊表大小的兩倍。

時間複雜度:
O(N),N為雜湊表的大小。
傳回值:
以列表形式返回雜湊表的域和域的值。 若key不存在,返回空列表。
redis> HSET hash_name jack "Jack Sparrow"(integer) 1redis> HSET hash_name gump "Forrest Gump"(integer) 1redis> HGETALL hash_name1) "jack"          # 域2) "Jack Sparrow"  # 值3) "gump"4) "Forrest Gump"
HDEL
HDEL key field [field ...]

刪除雜湊表key中的一個或多個指定域,不存在的域將被忽略。

時間複雜度:
O(N),N為要刪除的域的數量。
傳回值:
被成功移除的域的數量,不包括被忽略的域。

Note

 

在Redis2.4以下的版本裡,HDEL每次只能刪除單個域,如果你需要在一個原子時間內刪除多個域,請將命令包含在MULTIEXEC塊內。

# 測試資料redis> HGETALL abbr1) "a"2) "apple"3) "b"4) "banana"5) "c"6) "cat"7) "d"8) "dog"# 刪除單個域redis> HDEL abbr a(integer) 1# 刪除不存在的域redis> HDEL abbr not-exists-field(integer) 0# 刪除多個域redis> HDEL abbr b c(integer) 2redis> HGETALL abbr1) "d"2) "dog"
HLEN
HLEN key

返回雜湊表key中域的數量。

時間複雜度:
O(1)
傳回值:
雜湊表中域的數量。當key不存在時,返回0。
redis> HSET hash_name jack "Jack Sparrow"(integer) 1redis> HSET hash_name gump "Forrest Gump"(integer) 1redis> HLEN hash_name(integer) 2
HEXISTS
HEXISTS key field

查看雜湊表key中,給定域field是否存在。

時間複雜度:
O(1)
傳回值:
如果雜湊表含有給定域,返回1。如果雜湊表不含有給定域,或key不存在,返回0。
redis> HEXISTS phone myphone(integer) 0redis> HSET phone myphone nokia-1110(integer) 1redis> HEXISTS phone myphone(integer) 1
HINCRBY
HINCRBY key field increment

為雜湊表key中的域field的值加上增量increment。

增量也可以為負數,相當於對給定域進行減法操作。

如果key不存在,一個新的雜湊表被建立並執行HINCRBY命令。

如果域field不存在,那麼在執行命令前,域的值被初始化為0。

對一個儲存字串值的域field執行HINCRBY命令將造成一個錯誤。

本操作的值限制在64位(bit)有符號數字表示之內。

時間複雜度:
O(1)
傳回值:
執行HINCRBY命令之後,雜湊表key中域field的值。
# 情況1:increment為正數redis> HEXISTS counter page_view # 對空域進行設定(integer) 0redis> HINCRBY counter page_view 200(integer) 200redis> HGET counter page_view"200"# 情況2:increment為負數redis> HGET counter page_view"200"redis> HINCRBY counter page_view -50(integer) 150redis> HGET counter page_view"150"# 情況3:嘗試對字串值的域執行HINCRBY命令redis> HSET myhash string hello,world    # 設定一個字串值(integer) 1redis> HGET myhash string"hello,world"redis> HINCRBY myhash string 1   # 命令執行失敗,錯誤。(error) ERR hash value is not an integerredis> HGET myhash string    # 原值不變"hello,world"
HKEYS
HKEYS key

返回雜湊表key中的所有域。

時間複雜度:
O(N),N為雜湊表的大小。
傳回值:
一個包含雜湊表中所有域的表。當key不存在時,返回一個空表。
# 情況1:雜湊表非空redis> HMSET website google www.google.com yahoo www.yahoo.comOKredis> HKEYS website1) "google"2) "yahoo"# 情況2:空雜湊表/key不存在redis> EXISTS fake_key(integer) 0redis> HKEYS fake_key(empty list or set)
HVALS
HVALS key

返回雜湊表key中的所有值。

時間複雜度:
O(N),N為雜湊表的大小。
傳回值:
一個包含雜湊表中所有值的表。當key不存在時,返回一個空表。
# 情況1:非空雜湊表redis> HMSET website google www.google.com yahoo www.yahoo.comOKredis> HVALS website1) "www.google.com"2) "www.yahoo.com"# 情況2:空雜湊表/不存在的keyredis> EXISTS not_exists(integer) 0redis> HVALS not_exists(empty list or set)

 

redis的hash操作在集中式session中的應用

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.