標籤:
在叢集部署時,為了高可用性的目的,往往把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每次只能刪除單個域,如果你需要在一個原子時間內刪除多個域,請將命令包含在MULTI/ EXEC塊內。
# 測試資料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中的應用