<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
當 key 達到過期時間,Redis 就會馬上刪除麼?
先說結論:並不會立馬刪除。
Redis 有兩種刪除過期資料的策略:
該命令在 Redis 2.4 版本,過期時間並不是很精確,它可能在零到一秒之間。
從 Redis 2.6 開始,過期錯誤為 0 到 1 毫秒。
EXPIRE key seconds [ NX | XX | GT | LT]
指令可以將指定的 key 設定過期時間,如果沒有設定過期時間, key 將一直存在,除非我們明確將其刪除,比如執行 DEL
指令。
所謂”狡兔死,走狗烹“,沒用了就幹掉,跟 35 歲就“畢業”是一個道理。
好慌……
從 Redis 版本 7.0.0 開始:EXPIRE
新增了選項:NX
、XX
和GT
、LT
選項。
❝主從或者叢集架構中,兩臺機器的時鐘嚴重不同步,會有什麼問題麼?
key 過期資訊是用 Unix 絕對時間戳表示的。
為了讓過期操作正常執行,機器之間的時間必須保證穩定同步,否則就會出現過期時間不準的情況。
比如兩臺時鐘嚴重不同步的機器發生 RDB 傳輸, slave 的時間設定為未來的 2000 秒,假如在 master 的一個 key 設定 1000 秒存活,當 Slave 載入 RDB 的時候 key 就會認為該 key 過期(因為 slave 機器時間設定為未來的 2000 s),並不會等待 1000 s 才過期。
機器時鐘不同步導致過期混亂
惰性刪除很簡單,就是當有使用者端的請求查詢該 key
的時候,檢查下 key
是否過期,如果過期,則刪除該 key
。
比如當 Redis 收到使用者端的GET movie:小澤#瑪……利亞.rmvb
請求,就會先檢查 key = movie:小澤#瑪……利亞.rmvb
是否已經過期,如果過期那就刪除。
刪除過期資料的主動權交給了每次存取請求。
該實現通過 expireIfNeeded
函數實現,原始碼路徑:src/db.c
。
int expireIfNeeded(redisDb *db, robj *key, int force_delete_expired) { // key 沒有過期,return 0 if (!keyIsExpired(db,key)) return 0; if (server.masterhost != NULL) { if (server.current_client == server.master) return 0; if (!force_delete_expired) return 1; } if (checkClientPauseTimeoutAndReturnIfPaused()) return 1; /* Delete the key */ deleteExpiredKeyAndPropagate(db,key); return 1; }
僅僅靠使用者端存取來判斷 key 是否過期才執行刪除肯定不夠,因為有的 key 過期了,但未來再也沒人存取,這些資料要怎麼刪除呢?
不能讓這些資料「佔著茅坑不拉屎」。
所謂定期刪除,也就是 Redis 預設每 1 秒執行 10 次(每 100 ms 執行一次),每次隨機抽取一些設定了過期時間的 key,檢查是否過期,如果發現過期了就直接刪除。
注意:並不是一次執行就檢查所有的庫,所有的鍵,而是隨機檢查一定數量的鍵。
具體步驟如下:
定時刪除
刪除的原始碼 expire.c 的 activeExpireCycle 函數實現。
這也就意味著在任何時候,過期 key 的最大數量等於每秒最大寫入操作量除以 4。
❝為啥不檢查所有設定過期時間的 key?
你想呀,假設 Redis 裡存放了 100 w 個 key,都設定了過期時間,每隔 100 毫秒就檢查 100 w 個 key,CPU 全浪費在檢查過期 key 上了,Redis 也就廢了。
注意了:不管是定時刪除,還是惰性刪除。當資料刪除後,master
會生成刪除的指令記錄到 AOF
和 slave
節點。
碼哥,如果過期的資料太多,定時刪除無法刪除完全(每次刪除完過期的 key 還是超過 25%),同時這些 key 也再也不會被使用者端請求,也就是無法走惰性刪除,會怎樣?
會不會導致 Redis 記憶體耗盡,怎麼破?
這個問題問得好,答案是走記憶體淘汰機制。
以上就是Redis過期資料是否會被立馬刪除的詳細內容,更多關於Redis過期資料的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45