成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Redis 的過期數據會被立馬刪除么?

數據庫 Redis
EXPIRE key seconds [ NX | XX | GT | LT] 指令可以將指定的 key 設置過期時間,如果沒有設置過期時間, key 將一直存在,除非我們明確將其刪除,比如執(zhí)行 DEL 指令。

先說結論:并不會立馬刪除。Redis 有兩種刪除過期數據的策略:

  • 定期選取部分數據刪除。
  • 惰性刪除。

該命令在 Redis 2.4 版本,過期時間并不是很精確,它可能在零到一秒之間。

從 Redis 2.6 開始,過期錯誤為 0 到 1 毫秒。

EXPIRE key seconds [ NX | XX | GT | LT] 指令可以將指定的 key 設置過期時間,如果沒有設置過期時間, key 將一直存在,除非我們明確將其刪除,比如執(zhí)行 DEL 指令。

所謂”狡兔死,走狗烹“,沒用了就干掉,跟 35 歲就“畢業(yè)”是一個道理。

好慌……

從 Redis 版本 7.0.0 開始:EXPIRE 添加了選項:NX、XX和GT、LT 選項。

  • NX:當 key 沒有過期時才設置過期時間。
  • XX:只有 key 已過期的時候才設置過期時間。
  • GT:僅當新的到期時間大于當前到期時間時才設置過期時間。
  • LT:僅在新到期時間小于當前到期時間才設置到過期時間。

過期與持久化

主從或者集群架構中,兩臺機器的時鐘嚴重不同步,會有什么問題么?

key 過期信息是用 Unix 絕對時間戳表示的。

為了讓過期操作正常運行,機器之間的時間必須保證穩(wěn)定同步,否則就會出現過期時間不準的情況。

比如兩臺時鐘嚴重不同步的機器發(fā)生 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 是否過期才執(zhí)行刪除肯定不夠,因為有的 key 過期了,但未來再也沒人訪問,這些數據要怎么刪除呢?

不能讓這些數據「占著茅坑不拉屎」。

所謂定期刪除,也就是 Redis 默認每 1 秒運行 10 次(每 100 ms 執(zhí)行一次),每次隨機抽取一些設置了過期時間的 key,檢查是否過期,如果發(fā)現過期了就直接刪除。

注意:并不是一次運行就檢查所有的庫,所有的鍵,而是隨機檢查一定數量的鍵。

具體步驟如下:

定時刪除

  1. 從所有設置了過期時間的 key 集合中隨機選擇 20 個 key。
  2. 刪除「步驟 1」發(fā)現的所有過期 key 數據。
  3. 「步驟 2 」結束,過期的 key 超過 25%,則繼續(xù)執(zhí)行「步驟 1」。

刪除的源碼 expire.c 的 activeExpireCycle 函數實現。

這也就意味著在任何時候,過期 key 的最大數量等于每秒最大寫入操作量除以 4。

為啥不檢查所有設置過期時間的 key?

你想呀,假設 Redis 里存放了 100 w 個 key,都設置了過期時間,每隔 100 毫秒就檢查 100 w 個 key,CPU 全浪費在檢查過期 key 上了,Redis 也就廢了。

注意了:不管是定時刪除,還是惰性刪除。當數據刪除后,master 會生成刪除的指令記錄到 AOF 和 slave 節(jié)點。

碼哥,如果過期的數據太多,定時刪除無法刪除完全(每次刪除完過期的 key 還是超過 25%),同時這些 key 也再也不會被客戶端請求,也就是無法走惰性刪除,會怎樣?

會不會導致 Redis 內存耗盡,怎么破?

這個問題問得好,答案是走內存淘汰機制。

今天就到這里,說太多的話,大家容易在知識的海量里嗆死,保命要緊,至于內存淘汰機制詳情,請看下回分解。

責任編輯:姜華 來源: 碼哥字節(jié)
相關推薦

2022-08-24 08:17:14

RedisRDBAOF

2023-10-26 07:13:14

Redis內存淘汰

2020-06-11 19:00:24

Redis數據庫

2018-05-28 22:17:40

GDPR數據隱私云計算

2022-07-01 14:20:49

Redis策略函數

2021-09-10 18:47:22

Redis淘汰策略

2023-03-14 11:00:05

過期策略Redis

2023-05-08 15:59:17

Redis數據刪除

2017-03-09 18:51:53

2022-01-02 08:38:22

Redis數據單線程

2022-09-05 08:39:55

Redis存儲數據

2020-08-18 19:15:44

Redis內存管理

2024-09-26 06:30:36

2024-12-25 10:24:31

2021-05-17 12:12:49

數據庫架構分離

2024-04-18 00:20:56

Redis策略數據

2024-08-19 09:13:02

2015-09-22 11:23:37

ChromeChrome崩潰

2021-06-03 14:21:25

數據安全信息安全網絡安全

2014-04-14 13:05:41

RedisDBA服務器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线亚洲免费视频 | 黄网站在线观看 | 九九在线 | 91观看| 天天操天天射综合网 | 99精品免费在线观看 | 亚洲天堂一区二区 | 国产大学生情侣呻吟视频 | 日韩精品一区中文字幕 | 成年男女免费视频网站 | 中文字幕在线精品 | 日一区二区 | 日本高清视频网站 | 亚洲精品日韩一区二区电影 | 国产日韩精品一区 | 在线看片福利 | 日本一区二区高清不卡 | 男女爱爱网站 | 亚洲一区 | 日日夜夜狠狠操 | 欧美aaa级 | 美女操网站| 蜜桃传媒一区二区 | 一区二区在线免费观看 | 一区二区三区四区在线视频 | 狠狠亚洲 | 亚洲精品高清视频 | 久久精品国产免费一区二区三区 | 97成人免费 | 国产精品久久久久久久久久免费看 | 日韩精品在线播放 | 性做久久久久久免费观看欧美 | 欧美无乱码久久久免费午夜一区 | 欧美老少妇一级特黄一片 | 噜噜噜噜狠狠狠7777视频 | 国产福利在线播放麻豆 | 欧美v日韩v| 国产三级网站 | 国产一区二区三区四区五区加勒比 | 欧美寡妇偷汉性猛交 | 国产精品欧美一区二区 |