中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Redis中怎么設置過期時間的Key

發布時間:2021-07-23 10:51:50 來源:億速云 閱讀:392 作者:Leah 欄目:數據庫

Redis中怎么設置過期時間的Key,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

1、 DEL/SET/GETSET等命令會清除過期時間

在使用DEL、SET、GETSET等會覆蓋key對應value的命令操作一個設置了過期時間的key的時候,會導致對應的key的過期時間被清除。

//設置mykey的過期時間為300s 127.0.0.1:6379> set mykey hello ex 300 OK //查看過期時間 127.0.0.1:6379> ttl mykey (integer) 294 //使用set命令覆蓋mykey的內容 127.0.0.1:6379> set mykey olleh OK //過期時間被清除 127.0.0.1:6379> ttl mykey (integer) -1

2、INCR/LPUSH/HSET等命令則不會清除過期時間

而在使用INCR/LPUSH/HSET這種只是修改一個key的value,而不是覆蓋整個value的命令,則不會清除key的過期時間。

INCR:

//設置incr_key的過期時間為300s 127.0.0.1:6379> set incr_key 1 ex 300 OK 127.0.0.1:6379> ttl incr_key (integer) 291 //進行自增操作 127.0.0.1:6379> incr incr_key (integer) 2 127.0.0.1:6379> get incr_key "2" //查詢過期時間,發現過期時間沒有被清除 127.0.0.1:6379> ttl incr_key (integer) 277

LPUSH:

//新增一個list類型的key,并添加一個為1的值 127.0.0.1:6379> LPUSH list 1 (integer) 1 //為list設置300s的過期時間 127.0.0.1:6379> expire list 300 (integer) 1 //查看過期時間 127.0.0.1:6379> ttl list (integer) 292 //往list里面添加值2 127.0.0.1:6379> lpush list 2 (integer) 2 //查看list的所有值 127.0.0.1:6379> lrange list 0 1 1) "2" 2) "1" //能看到往list里面添加值并沒有使過期時間清除 127.0.0.1:6379> ttl list (integer) 252

3、PERSIST命令會清除過期時間

當使用PERSIST命令將一個設置了過期時間的key轉變成一個持久化的key的時候,也會清除過期時間。

127.0.0.1:6379> set persist_key haha ex 300 OK 127.0.0.1:6379> ttl persist_key (integer) 296 //將key變為持久化的 127.0.0.1:6379> persist persist_key (integer) 1 //過期時間被清除 127.0.0.1:6379> ttl persist_key (integer) -1

4、使用RENAME命令,老key的過期時間將會轉到新key上

在使用例如:RENAME KEY_A KEY_B命令將KEY_A重命名為KEY_B,不管KEY_B有沒有設置過期時間,新的key  KEY_B將會繼承KEY_A的所有特性。

//設置key_a的過期時間為300s 127.0.0.1:6379> set key_a value_a ex 300 OK //設置key_b的過期時間為600s 127.0.0.1:6379> set key_b value_b ex 600 OK 127.0.0.1:6379> ttl key_a (integer) 279 127.0.0.1:6379> ttl key_b (integer) 591 //將key_a重命名為key_b 127.0.0.1:6379> rename key_a key_b OK //新的key_b繼承了key_a的過期時間 127.0.0.1:6379> ttl key_b (integer) 248

這里篇幅有限,我就不一一將key_a重命名到key_b的各個情況列出來,大家可以在自己電腦上試一下key_a設置了過期時間,key_b沒設置過期時間這種情況。

5、使用EXPIRE/PEXPIRE設置的過期時間為負數或者使用EXPIREAT/PEXPIREAT設置過期時間戳為過去的時間會導致key被刪除

EXPIRE:

127.0.0.1:6379> set key_1 value_1 OK 127.0.0.1:6379> get key_1 "value_1" //設置過期時間為-1 127.0.0.1:6379> expire key_1 -1 (integer) 1 //發現key被刪除 127.0.0.1:6379> get key_1 (nil)

EXPIREAT:

127.0.0.1:6379> set key_2 value_2 OK 127.0.0.1:6379> get key_2 "value_2" //設置的時間戳為過去的時間 127.0.0.1:6379> expireat key_2 10000 (integer) 1 //key被刪除 127.0.0.1:6379> get key_2 (nil)

6、EXPIRE命令可以更新過期時間

對一個已經設置了過期時間的key使用expire命令,可以更新其過期時間。

//設置key_1的過期時間為100s 127.0.0.1:6379> set key_1 value_1 ex 100 OK 127.0.0.1:6379> ttl key_1 (integer) 95 //更新key_1的過期時間為300s 127.0.0.1:6379> expire key_1 300 (integer) 1 127.0.0.1:6379> ttl key_1 (integer) 295

在Redis2.1.3以下的版本中,使用expire命令更新一個已經設置了過期時間的key的過期時間會失敗。并且對一個設置了過期時間的key使用LPUSH/HSET等命令修改其value的時候,會導致Redis刪除該key。

Redis的過期策略

那你有沒有想過一個問題,Redis里面如果有大量的key,怎樣才能高效的找出過期的key并將其刪除呢,難道是遍歷每一個key嗎?假如同一時期過期的key非常多,Redis會不會因為一直處理過期事件,而導致讀寫指令的卡頓。

這里說明一下,Redis是單線程的,所以一些耗時的操作會導致Redis卡頓,比如當Redis數據量特別大的時候,使用keys *  命令列出所有的key。

實際上Redis使用懶惰刪除+定期刪除相結合的方式處理過期的key。

懶惰刪除

所謂懶惰刪除就是在客戶端訪問該key的時候,redis會對key的過期時間進行檢查,如果過期了就立即刪除。

這種方式看似很完美,在訪問的時候檢查key的過期時間,不會占用太多的額外CPU資源。但是如果一個key已經過期了,如果長時間沒有被訪問,那么這個key就會一直存留在內存之中,嚴重消耗了內存資源。

定期刪除

定期刪除的原理是,Redis會將所有設置了過期時間的key放入一個字典中,然后每隔一段時間從字典中隨機一些key檢查過期時間并刪除已過期的key。

Redis默認每秒進行10次過期掃描:

  1. 鴻蒙官方戰略合作共建——HarmonyOS技術社區

  2. 從過期字典中隨機20個key

  3. 刪除這20個key中已過期的

  4. 如果超過25%的key過期,則重復第一步

同時,為了保證不出現循環過度的情況,Redis還設置了掃描的時間上限,默認不會超過25ms。

看完上述內容,你們掌握Redis中怎么設置過期時間的Key的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

娱乐| 开封县| 赣州市| 濉溪县| 洪湖市| 鄱阳县| 汤原县| 太保市| 宝兴县| 大渡口区| 绥化市| 台东市| 宁陵县| 靖西县| 股票| 乐山市| 共和县| 呼伦贝尔市| 稷山县| 云霄县| 上林县| 剑河县| 叶城县| 通州市| 平阳县| 肥城市| 丰顺县| 清河县| 吉林市| 保亭| 秦安县| 祁连县| 铜川市| 遂溪县| 思茅市| 岑溪市| 辉南县| 阿拉善左旗| 常宁市| 沁水县| 辰溪县|