五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

淺談Redis對于過期鍵的三種清除策略

發(fā)布日期:2022-02-02 17:54 | 文章來源:源碼中國

對于過期鍵一般有三種刪除策略

  • 定時刪除:在設(shè)置鍵的過期時間的同時,創(chuàng)建一個定時器(timer),讓定時器在鍵的過期時間來臨時,立即執(zhí)行對鍵的刪除操作;
  • 惰性刪除:放任鍵過期不管,但是每次從鍵空間中獲取鍵時,都檢查取得的鍵是否過期,如果過期的話,就刪除該鍵;如果沒有過期,那就返回該鍵;
  • 定期刪除:每隔一段時間,程序就對數(shù)據(jù)庫進(jìn)行一次檢查,刪除里面的過期鍵。至于刪除多少過期鍵,以及要檢查多少個數(shù)據(jù)庫,則由算法決定。

?下面我們來看看三種策略的優(yōu)缺比較:

  • 定時刪除策略對內(nèi)存是最友好的:通過使用定時器,定時刪除策略可以保證過期鍵會盡可能快地被刪除,并釋放過期鍵所占用的內(nèi)存;但另一方面,定時刪除策略的缺點(diǎn)是,他對CPU是最不友好的:在過期鍵比較多的情況下,刪除過期鍵這一行為可能會占用相當(dāng)一部分CPU時間,在內(nèi)存不緊張但是CPU時間非常緊張的情況下,將CPU時間用在刪除和當(dāng)前任務(wù)無關(guān)的過期鍵上,無疑會對服務(wù)器的響應(yīng)時間和吞吐量造成影響;
  • 惰性刪除策略對CPU時間來說是最友好的:程序只會在取出鍵時才對鍵進(jìn)行過期檢查,這可以保證刪除過期鍵的操作只會在非做不可的情況下進(jìn)行;惰性刪除策略的缺點(diǎn)是,它對內(nèi)存是最不友好的:如果一個鍵已經(jīng)過期,而這個鍵又仍然保留在數(shù)據(jù)庫中,那么只要這個過期鍵不被刪除,它所占用的內(nèi)存就不會釋放;
  • 定時刪除占用太多CPU時間,影響服務(wù)器的響應(yīng)時間和吞吐量;惰性刪除浪費(fèi)太多內(nèi)存,有內(nèi)存泄漏的危險。定期刪除策略是前兩種策略的一種整合和折中:
    • 定期刪除策略每隔一段時間執(zhí)行一次刪除過期鍵操作,并通過限制刪除操作執(zhí)行的時長和頻率來減少刪除操作對CPU時間的影響;
    • 通過定期刪除過期鍵,定期刪除策略有效地減少了因?yàn)檫^期鍵而帶來的內(nèi)存浪費(fèi);
    • 定期刪除策略的難點(diǎn)是確定刪除操作執(zhí)行的時長和頻率。

Pre

Redis-17Redis內(nèi)存回收策略

Redis Key的超時設(shè)置處理

expire key seconds

單位是秒。返回1成功,0表示key已經(jīng)設(shè)置過過期時間或者不存在。 如果想消除超時則使用persist key。如果希望采用絕對超時,則使用expireat命令。

ttl key 

返回設(shè)置過過期時間的key的剩余過期秒數(shù) -1表示沒有設(shè)置過過期時間,對于不存在的key,返回-2。

pexpire key 毫秒數(shù)

設(shè)置生命周期。

pttl  key

以毫秒返回生命周期。

被動刪除

當(dāng)讀/寫一個已經(jīng)過期的key時,會觸發(fā)惰性刪除策略,直接刪除掉這個過期key.

舉個例子, set 一個 過期時間為 600s的 key , 當(dāng) 到了 600s后,redis 并不會執(zhí)行刪除, 為了性能,redis 會在你下次訪問的時候 去刪除 。

這樣的話,我如果永遠(yuǎn)不訪問,那不歇菜了么? 不要著急,Redis還有主動刪除 。

主動刪除

由于惰性刪除策略無法保證冷數(shù)據(jù)被及時刪掉,所以Redis會定期主動淘汰一批已過期的key。

說白了,這就是定時任務(wù)干的活,防止有些key 一直占用內(nèi)存。

當(dāng)REDIS運(yùn)行在主從模式時,只有主結(jié)點(diǎn)才會執(zhí)行被動和主動這兩種過期刪除策略,然后把刪除操作”del key”同步到從結(jié)點(diǎn).

當(dāng)前已用內(nèi)存超過maxmemory限定時,觸發(fā)主動清理策略

第三種策略的情況: 當(dāng)前已用內(nèi)存超過maxmemory限定時,會觸發(fā)主動清理策略.

我們需要根據(jù)自身業(yè)務(wù)類型,選好maxmemory-policy(最大內(nèi)存淘汰策略),設(shè)置好過期時間。如果不設(shè)置最大內(nèi)存,當(dāng) Redis 內(nèi)存超出物理內(nèi)存限制時,內(nèi)存的數(shù)據(jù)會開始和磁盤產(chǎn)生頻繁的交換 (swap)會讓 Redis 的性能急劇下降。

默認(rèn)策略是volatile-lru,即超過最大內(nèi)存后,在過期鍵中使用lru算法進(jìn)行key的剔除,保證不過期數(shù)據(jù)不被刪除,但是可能會出現(xiàn)OOM問題。

其他策略如下:

  • allkeys-lru:根據(jù)LRU算法刪除鍵,不管數(shù)據(jù)有沒有設(shè)置超時屬性,直到騰出足夠空間 為止
  • allkeys-random:隨機(jī)刪除所有鍵,直到騰出足夠空間為止。
  • allkeys-random:隨機(jī)刪除所有鍵,直到騰出足夠空間為止。
  • volatile-ttl:根據(jù)鍵值對象的ttl屬性,刪除最近將要過期數(shù)據(jù)。如果沒有,回退到noeviction策略。
  • noeviction:不會剔除任何數(shù)據(jù),拒絕所有寫入操作并返回客戶端錯誤信息"(error)。OOM command not allowed when used memory",此時Redis只響應(yīng)讀操作

記?。?volatile 開頭的策略,只清理過期的key , 而all開頭的策略則不管你過不過期,都會清理。

總結(jié)

  • 當(dāng)client主動訪問key會先對key進(jìn)行超時判斷,過時的key會立刻刪除。
  • 從節(jié)點(diǎn)不會過期掃描,從節(jié)點(diǎn)對過期的處理是被動的。 在主從復(fù)制環(huán)境中,由于上述原因存在已經(jīng)過期但是沒有刪除的key,在主snapshot時并不包含這些key,因此在slave環(huán)境中我們往往看到dbsize較master是更小的。

如果clien永遠(yuǎn)都不再get那條key呢?

redis會在Master的后臺,每秒10次的執(zhí)行如下操作:

隨機(jī)選取100個key校驗(yàn)是否過期,如果有25個以上的key過期了,立刻額外隨機(jī)選取下100個key(不計算在10次之內(nèi))??梢姡绻^期的key不多,它最多每秒回收200條左右,如果有超過25%的key過期了,它就會做得更多。

到此這篇關(guān)于淺談Redis對于過期鍵的三種清除策略的文章就介紹到這了,更多相關(guān)Redis 過期鍵清除內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!?

國外服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實(shí)時開通

自選配置、實(shí)時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部