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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

redis查看key的过期时间_面试官:你在Redis中设置过带过期时间的Key吗?

發布時間:2023/12/4 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 redis查看key的过期时间_面试官:你在Redis中设置过带过期时间的Key吗? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊上方小偉后端筆記關注公眾號

每天閱讀Java干貨文章

熟悉Redis的同學應該知道,Redis的每個Key都可以設置一個過期時間,當達到過期時間的時候,這個key就會被自動刪除。

在為key設置過期時間需要注意的事項

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

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

//設置mykey的過期時間為300s127.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的過期時間為300s127.0.0.1:6379>?set?incr_key?1?ex?300
OK127.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
OK127.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的過期時間為300s127.0.0.1:6379>?set?key_a?value_a?ex?300
OK//設置key_b的過期時間為600s127.0.0.1:6379>?set?key_b?value_b?ex?600
OK127.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
OK127.0.0.1:6379>?get?key_1"value_1"//設置過期時間為-1127.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
OK127.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的過期時間為100s127.0.0.1:6379>?set?key_1?value_1?ex?100
OK127.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次過期掃描:

  • 從過期字典中隨機20個key

  • 刪除這20個key中已過期的

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

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

    作者:千山qianshan

    來源:juejin.im/post/5d6bda096fb9a06acc009dc8—END—

    推薦閱讀:

    面試官:為什么 HashMap 的加載因子是0.75?

    面試官: 為什么 SQL 語句不要過多的 join?
    你還在被 Java NIO 虐?該試試 Netty 了!

    新手也能看懂的源碼閱讀技巧試

    如果文章對您有幫助,請您分享、點贊、在看,一波三連支持一下作者,非常感謝!

    總結

    以上是生活随笔為你收集整理的redis查看key的过期时间_面试官:你在Redis中设置过带过期时间的Key吗?的全部內容,希望文章能夠幫你解決所遇到的問題。

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