日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發布時間:2025/4/5 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 redis的hash操作在集中式session中的应用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在集群部署時,為了高可用性的目的,往往把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),Nfield?-?value對的數量。
返回值:
如果命令執行成功,返回OK。 當key不是哈希表(hash)類型時,返回一個錯誤。
# 情況1: 哈希表redis> HMSET website google www.google.com yahoo www.yahoo.com OKredis> 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_name 1) "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 abbr 1) "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 abbr 1) "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.com OKredis> HKEYS website 1) "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.com OKredis> HVALS website 1) "www.google.com" 2) "www.yahoo.com"# 情況2:空哈希表/不存在的keyredis> EXISTS not_exists (integer) 0redis> HVALS not_exists (empty list or set)

?

轉載于:https://www.cnblogs.com/davidwang456/p/4302646.html

總結

以上是生活随笔為你收集整理的redis的hash操作在集中式session中的应用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。