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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時(shí)間:2025/4/5 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 redis的hash操作在集中式session中的应用 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

在集群部署時(shí),為了高可用性的目的,往往把session進(jìn)行共享,共享分為兩種:session復(fù)制和集中式管理。

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

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

1. session必須有ha機(jī)制,集群中部分服務(wù)器發(fā)生故障時(shí),保證session不丟失。

2. session的生命周期管理。

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

redis的解決方式

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

2. redis提供了生存時(shí)間管理EXPIRE。

3.redis提供hash操作來(lái)進(jìn)行局部的序列化和反序列化,保證效率。

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

哈希表(Hash)

HSET

HSET key field value

將哈希表key中的域field的值設(shè)為value。

如果key不存在,一個(gè)新的哈希表被創(chuàng)建并進(jìn)行HSET操作。

如果域field已經(jīng)存在于哈希表中,舊值將被覆蓋。

時(shí)間復(fù)雜度:
O(1)
返回值:
如果field是哈希表中的一個(gè)新建域,并且值設(shè)置成功,返回1。 如果哈希表中域field已經(jīng)存在且舊值已被新值覆蓋,返回0。
redis> HSET website google "www.g.cn" # 一個(gè)新域 (integer) 1redis> HSET website google "www.google.com" # 覆蓋一個(gè)舊域 (integer) 0

HSETNX

HSETNX key field value

將哈希表key中的域field的值設(shè)置為value,當(dāng)且僅當(dāng)域field不存在。

若域field已經(jīng)存在,該操作無(wú)效。

如果key不存在,一個(gè)新哈希表被創(chuàng)建并執(zhí)行HSETNX命令。

時(shí)間復(fù)雜度:
O(1)
返回值:
設(shè)置成功,返回1。 如果給定域已經(jīng)存在且沒(méi)有操作被執(zhí)行,返回0
redis> HSETNX nosql key-value-store redis (integer) 1redis> HSETNX nosql key-value-store redis # 操作無(wú)效,域key-value-store已存在 (integer) 0

HMSET

HMSET key field value [field value ...]

同時(shí)將多個(gè)field?-?value(域-值)對(duì)設(shè)置到哈希表key中。

此命令會(huì)覆蓋哈希表中已存在的域。

如果key不存在,一個(gè)空哈希表被創(chuàng)建并執(zhí)行HMSET操作。

時(shí)間復(fù)雜度:
O(N),Nfield?-?value對(duì)的數(shù)量。
返回值:
如果命令執(zhí)行成功,返回OK。 當(dāng)key不是哈希表(hash)類型時(shí),返回一個(gè)錯(cuò)誤。
# 情況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:類型錯(cuò)誤時(shí)redis> SET G 10 # 出錯(cuò)情況 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的值。

時(shí)間復(fù)雜度:
O(1)
返回值:
給定域的值。 當(dāng)給定域不存在或是給定key不存在時(shí),返回nil。
redis> HSET huangz blog huangz.iteye.com (integer) 1redis> HGET huangz blog "huangz.iteye.com"

HMGET

HMGET key field [field ...]

返回哈希表key中,一個(gè)或多個(gè)給定域的值。

如果給定的域不存在于哈希表,那么返回一個(gè)nil值。

因?yàn)椴淮嬖诘?span id="ozvdkddzhkzd" class="pre">key被當(dāng)作一個(gè)空哈希表來(lái)處理,所以對(duì)一個(gè)不存在的key進(jìn)行HMGET操作將返回一個(gè)只帶有nil值的表。

時(shí)間復(fù)雜度:
O(N),N為給定域的數(shù)量。
返回值:
一個(gè)包含多個(gè)給定域的關(guān)聯(lián)值的表,表值的排列順序和給定域參數(shù)的請(qǐng)求順序一樣。
redis> HMSET pet dog "doudou" cat "nounou" # 一次保存多個(gè)值 OKredis> HMGET pet dog cat fake_pet # 返回值的順序和傳入?yún)?shù)的順序一樣。 1) "doudou" 2) "nounou" 3) (nil) # 不存在的域返回nil值

HGETALL

HGETALL key

返回哈希表key中,所有的域和值。

在返回值里,緊跟每個(gè)域名(field name)之后是域的值(value),所以返回值的長(zhǎng)度是哈希表大小的兩倍。

時(shí)間復(fù)雜度:
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中的一個(gè)或多個(gè)指定域,不存在的域?qū)⒈缓雎浴?/p> 時(shí)間復(fù)雜度:

O(N),N為要?jiǎng)h除的域的數(shù)量。
返回值:
被成功移除的域的數(shù)量,不包括被忽略的域。

Note

?

在Redis2.4以下的版本里,HDEL每次只能刪除單個(gè)域,如果你需要在一個(gè)原子時(shí)間內(nèi)刪除多個(gè)域,請(qǐng)將命令包含在MULTI/?EXEC塊內(nèi)。

# 測(cè)試數(shù)據(jù)redis> HGETALL abbr 1) "a" 2) "apple" 3) "b" 4) "banana" 5) "c" 6) "cat" 7) "d" 8) "dog"# 刪除單個(gè)域redis> HDEL abbr a (integer) 1# 刪除不存在的域redis> HDEL abbr not-exists-field (integer) 0# 刪除多個(gè)域redis> HDEL abbr b c (integer) 2redis> HGETALL abbr 1) "d" 2) "dog"

HLEN

HLEN key

返回哈希表key中域的數(shù)量。

時(shí)間復(fù)雜度:
O(1)
返回值:
哈希表中域的數(shù)量。 當(dāng)key不存在時(shí),返回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是否存在。

時(shí)間復(fù)雜度:
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。

增量也可以為負(fù)數(shù),相當(dāng)于對(duì)給定域進(jìn)行減法操作。

如果key不存在,一個(gè)新的哈希表被創(chuàng)建并執(zhí)行HINCRBY命令。

如果域field不存在,那么在執(zhí)行命令前,域的值被初始化為0

對(duì)一個(gè)儲(chǔ)存字符串值的域field執(zhí)行HINCRBY命令將造成一個(gè)錯(cuò)誤。

本操作的值限制在64位(bit)有符號(hào)數(shù)字表示之內(nèi)。

時(shí)間復(fù)雜度:
O(1)
返回值:
執(zhí)行HINCRBY命令之后,哈希表key中域field的值。
# 情況1:increment為正數(shù)redis> HEXISTS counter page_view # 對(duì)空域進(jìn)行設(shè)置 (integer) 0redis> HINCRBY counter page_view 200 (integer) 200redis> HGET counter page_view "200"# 情況2:increment為負(fù)數(shù)redis> HGET counter page_view "200"redis> HINCRBY counter page_view -50 (integer) 150redis> HGET counter page_view "150"# 情況3:嘗試對(duì)字符串值的域執(zhí)行HINCRBY命令redis> HSET myhash string hello,world # 設(shè)定一個(gè)字符串值 (integer) 1redis> HGET myhash string "hello,world"redis> HINCRBY myhash string 1 # 命令執(zhí)行失敗,錯(cuò)誤。 (error) ERR hash value is not an integerredis> HGET myhash string # 原值不變 "hello,world"

HKEYS

HKEYS key

返回哈希表key中的所有域。

時(shí)間復(fù)雜度:
O(N),N為哈希表的大小。
返回值:
一個(gè)包含哈希表中所有域的表。 當(dāng)key不存在時(shí),返回一個(gè)空表。
# 情況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中的所有值。

時(shí)間復(fù)雜度:
O(N),N為哈希表的大小。
返回值:
一個(gè)包含哈希表中所有值的表。 當(dāng)key不存在時(shí),返回一個(gè)空表。
# 情況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)

?

轉(zhuǎn)載于:https://www.cnblogs.com/davidwang456/p/4302646.html

總結(jié)

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

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。