亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Redis生存時間應該如何設置

發布時間:2020-03-26 10:51:31 來源:億速云 閱讀:357 作者:小新 欄目:關系型數據庫

Redis生存時間應該如何設置?這篇文章主要為大家詳細介紹了Redis生存時間應該如何設置,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下。

Redis生存時間應該如何設置

Redis對鍵提供生存時間,在不指定生存時間時,生存時間是永久。時間到期后Redis會自動刪除這個鍵。可以用EXPIRE命令,時間單位時秒,如果一個鍵是被設為有限的生存時間,那么在SET key進行重新賦值的時候會被再次設為永久:

SET session:captcha sd2a
EXPIRE session:captcha 600

取消生存時間,將鍵的生存時間設為永久,是PERSIST:

PERSIST session:captcha

查看一個鍵的生存時間用TTL命令,-1表示永久或者以及到期被刪除。

TTL session:captcha

在Redis的INCR,LPUSH,HSET,ZREM等命令時不會改變生存時間的。

想要精確到毫米來控制時間,就需要PEXPIRE即可,使用PTTL查看剩余時間。

如果想要給定一個到期的時間而不是多少秒后到期呢?就需要EXPIREAT和PEXPIREAT。EXPIREAT的參數是到期時的時間戳(秒),PEXPIREAT的參數是到期時間是時間戳(毫秒)

SET session:captcha sd2a
EXPIREAT session:captcha 1399902009
PEXPIREAT session:captcha 1399902009000

應用場景一:訪問頻率限制:我們限定每個用戶1分鐘只能瀏覽10個頁面。偽代碼如下:

$isExists = EXISTS limit:user1:192.168.1.2
if($isExists){
    $num = INCR limit:user1:192.168.1.2
    if($num > 10){
        print '超過限制'
        exit
    }
}else{
    MULTI
    INCR limit:user1:192.168.1.2
    EXPIRE limit:user1:192.168.1.2 60
    EXEC
}

我們用了事務的原因是因為,加入在執行了INCR limit:user1:192.168.1.2之后,在執行EXPIRE limit:user1:192.168.1.2 60之前,客戶端被關閉了。那么這個鍵和值就會被持久化保存。且該ID終身只能訪問10次了。這就太糟糕了。

應用場景二:實現緩存。計算一萬名用戶的排行榜,是很耗費資源的,那么我們把數據在第一次計算后存進一個key,然后對這個key設置生存時間。在1個小時后生存時間到期,key被刪除,再次進行計算新排名并保存的一個臨時key。我們用偽代碼實現:

//戰斗排行榜
$rank = GET cache:rank:fight
if not $rank
    $rank = 計算排名()
    MULTI
    SET cache:rank:fight $rank
    EXPIRE cache:rank:fight 3600
    EXEC

Redis是內存存儲的數據庫,假如內存被緩存占滿了,Redis會根據配置文件來刪除一定的緩存。配置項是Redis的配置文件中的maxmemory參數,單位是字節。超過這個限制之后,會根據配置文件的maxmemory-policy參數來刪除不需要的鍵。maxmemory-policy的可選規則是如下四種:

1、volatile-lru:使用LRU算法刪除一個鍵(設置了生存時間的鍵)。

2、allkey-lru:使用LRU算法刪除一個鍵。

3、volatile-random:隨即刪除一個鍵(設置了生存時間的鍵)。

4、allkey-random:隨即刪除一個鍵。

5、volatile-ttl:刪除生存時間即將過期的一個鍵。是隨即取出來N個鍵,然后刪除N個鍵中即將過期的鍵,而不是遍歷所有的鍵刪除即將過期的。N是幾?配置文件配的。

6、nevication:不刪除,返回錯誤。

Redis設置Key的過期時間 – EXPIRE命令

EXPIRE key seconds

為給定 key 設置生存時間,當 key 過期時(生存時間為 0 ),它會被自動刪除。

在 Redis 中,帶有生存時間的 key 被稱為『易失的』(volatile)。

生存時間可以通過使用 DEL 命令來刪除整個 key 來移除,或者被 SET 和 GETSET 命令覆寫(overwrite),這意味著,如果一個命令只是修改(alter)一個帶生存時間的 key 的值而不是用一個新的 key 值來代替(replace)它的話,那么生存時間不會被改變。

比如說,對一個 key 執行 INCR 命令,對一個列表進行 LPUSH 命令,或者對一個哈希表執行 HSET 命令,這類操作都不會修改 key 本身的生存時間。

另一方面,如果使用 RENAME 對一個 key 進行改名,那么改名后的 key 的生存時間和改名前一樣。

RENAME 命令的另一種可能是,嘗試將一個帶生存時間的 key 改名成另一個帶生存時間的another_key ,這時舊的 another_key (以及它的生存時間)會被刪除,然后舊的 key 會改名為 another_key ,因此,新的 another_key 的生存時間也和原本的 key 一樣。

使用 PERSIST 命令可以在不刪除 key 的情況下,移除 key 的生存時間,讓 key 重新成為一個『持久的』(persistent) key 。

更新生存時間

可以對一個已經帶有生存時間的 key 執行 EXPIRE 命令,新指定的生存時間會取代舊的生存時間。

過期時間的精確度

在 Redis 2.4 版本中,過期時間的延遲在 1 秒鐘之內 —— 也即是,就算 key 已經過期,但它還是可能在過期之后一秒鐘之內被訪問到,而在新的 Redis 2.6 版本中,延遲被降低到 1 毫秒之內。

Redis 2.1.3 之前的不同之處

在 Redis 2.1.3 之前的版本中,修改一個帶有生存時間的 key 會導致整個 key 被刪除,這一行為是受當時復制(replication)層的限制而作出的,現在這一限制已經被修復。可用版本:

>= 1.0.0

時間復雜度:

O(1)

返回值:

設置成功返回 1 。

當 key 不存在或者不能為 key 設置生存時間時(比如在低于 2.1.3 版本的 Redis 中你嘗試更新 key 的生存時間),返回 0 。

redis> SET cache_page "www.google.com"
OK

redis> EXPIRE cache_page 30  # 設置過期時間為 30 秒
(integer) 1

redis> TTL cache_page    # 查看剩余生存時間
(integer) 23

redis> EXPIRE cache_page 30000   # 更新過期時間
(integer) 1

redis> TTL cache_page
(integer) 29996

1、在小于2.1.3的redis版本里,只能對key設置一次expire。redis2.1.3和之后的版本里,可以多次對key使用expire命令,更新key的expire time。

2、redis術語里面,把設置了expire time的key 叫做:volatile keys。 意思就是不穩定的key。

3、如果對key使用set或del命令,那么也會移除expire time。尤其是set命令,這個在編寫程序的時候需要注意一下。

4、redis2.1.3之前的老版本里,如果對volatile keys 做相關寫入操作(LPUSH,LSET),和其他一些觸發修改value的操作時,redis會刪除 該key。

也就是說 :

redis.expire(key,expiration);

redis.lpush(key,field,value);

redis.get(key) //return null

redis2.1.3之后的版本里面沒有這個約束,可以任意修改。

redis.set(key,100);
redis.expire(key,expiration);
redis.incr(key)
redis.get(key)
//redis2.2.2 return 101; redis<2.1.3 return 1;

5、redis對過期鍵采用了lazy expiration:在訪問key的時候判定key是否過期,如果過期,則進行過期處理。其次,每秒對volatile keys 進行抽樣測試,如果有過期鍵,那么對所有過期key進行處理。

以上就是Redis生存時間應該如何設置做了簡略的介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

工布江达县| 林西县| 福贡县| 松桃| 武功县| 滨州市| 尚义县| 文登市| 库车县| 阳城县| 泗水县| 中江县| 甘孜县| 绥德县| 集安市| 奉贤区| 桦南县| 和硕县| 普格县| 衢州市| 陈巴尔虎旗| 浮山县| 乌海市| 宕昌县| 安远县| 北川| 仙桃市| 定州市| 余庆县| 康保县| 许昌县| 灵台县| 宝兴县| 厦门市| 吐鲁番市| 齐齐哈尔市| 屏东县| 宜春市| 莱州市| 祥云县| 什邡市|