好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 大家都應該知道的Redis過期鍵與過期策略

大家都應該知道的Redis過期鍵與過期策略

熱門標簽:廊坊外呼系統在哪買 高碑店市地圖標注app 地圖標注工廠入駐 臺灣電銷 南京手機外呼系統廠家 400電話辦理的口碑 四川穩定外呼系統軟件 一個地圖標注多少錢 b2b外呼系統

今天,我和大家分享一篇關于 Redis 有關過期鍵的內容,主要有四個內容:

  • 如何設置過期鍵
  • 如何取消設置的過期時間
  • 過期鍵的過期策略是怎樣的
  • RDB、AOF 和復制對過期鍵的處理又是怎樣的

設置鍵的生存時間或過期時間

redis 一共有 4 個命令來設置鍵的生存時間(可以存活多久)或過期時間(什么時候被刪除)

  • expire key> ttl>:將 key 的生存時間設置為 ttl 秒
  • pexpire key> ttl>:將 key 的生存時間設置為 ttl 毫秒
  • expireat key> timestamp>:將 key 的過期時間設置為 timestamp 所指定的秒數時間戳
  • pexpireat key> ttl>:將 key 的過期時間設置為 timestamp 所指定的毫秒數時間戳

上述四種命令本質上都是通過 pexpireat 命令來實現的。

例子:
127.0.0.1:6379> set a test
OK
127.0.0.1:6379> EXPIRE a 5
(integer) 1
127.0.0.1:6379> get a // 距離設置生存時間命令的 5 秒內執行
"test"
127.0.0.1:6379> get a // 距離設置生存時間命令的 5 秒后執行
(nil)

127.0.0.1:6379> set b 12
OK
127.0.0.1:6379> EXPIREAT b 1545569500
(integer) 1
127.0.0.1:6379> time
1) "1545569486"
2) "108616"
127.0.0.1:6379> get b // 距離設置 1545569500 所指定的秒數時間戳內執行
"12"
127.0.0.1:6379> time
1) "1545569506"
2) "208567"
127.0.0.1:6379> get b // 距離設置 1545569500 所指定的秒數時間戳后執行
(nil)

如果自己不小心設置錯了過期時間,那么我們可以刪除先前的過期時間

移除過期時間

persist key> 命令可以移除一個鍵的過期時間,舉個栗子:

127.0.0.1:6379> EXPIRE c 1000
(integer) 1
127.0.0.1:6379> ttl c // 有過期時間
(integer) 9996
127.0.0.1:6379> PERSIST c
(integer) 1
127.0.0.1:6379> ttl c // 無過期時間
(integer) -1

PS:ttl 是以秒為單位,返回鍵的剩余生存時間;同理還有 pttl 命令是以毫秒為單位,返回鍵的剩余生存時間

此時,如果我們沒有移除過期時間,那么如果一個鍵過期了,那它什么時候會被刪除呢?

這個問題就會有以下三種答案了,它們分別代表三種不同的刪除策略

過期鍵的刪除策略

定時刪除

在設置鍵的過期時間的同時,創建一個定時器,讓定時器在鍵的過期時間來臨時,立即執行對鍵的刪除操作。

優點:對內存最友好的。可以及時釋放鍵所占用的內存。

缺點:對 CPU 不友好。特別在過期鍵比較多的情況下,刪除過期鍵會占用相當一部分 CPU 時間。同時在內存不緊張,CPU 緊張的情況下,將 CPU 用在刪除和當前任務不想關的過期鍵上,無疑會對服務器響應時間和吞吐量造成影響。

惰性刪除

放任鍵過期不管,但是每次從鍵空間中讀寫鍵時,都會檢查取得的鍵是否過期。如果過期就刪除該刪,否則就返回該鍵。(PS:鍵空間是一個保存了數據庫所有鍵值對的數據結構)

優點:對 CPU 最友好。只有在操作的時候進行過期檢查,刪除的目標僅限于當前需要處理的鍵,不會在刪除其他無關本次操作的過期鍵上花費任何 CPU 時間。

缺點:對內存不友好。這個十分容易理解了,鍵過期了,但因為一直沒有被訪問到,所以一直保留著(除非手動執行 flushdb 操來于清空當前數據庫中的所有 key。),相當于內存泄漏。

定期刪除

每隔一段時間,程序就對數據庫進行檢查,刪除里面的過期鍵。至于要刪除多少過期鍵,以及檢查多少數據庫,則有算法決定。

該策略是上述兩種策略的折中方案,需要通過實際情況,來設置刪除操作的執行時長和頻率。

明白了過期鍵的刪除策略后,那 redis 服務器又是采用什么策略來刪除過期鍵的呢?

實際上,Redis 服務器使用的是惰性刪除和定期刪除兩種策略,通過配合使用,服務器可以很好的平衡 CPU 和內存。

其中惰性刪除為 redis 服務器內置策略。而定期刪除可以通過以下兩種方式設置:

  • 配置 redis.conf 的 hz 選項,默認為10 (即 1 秒執行 10 次,值越大說明刷新頻率越快,對 Redis 性能損耗也越大)
  • 配置 redis.conf 的 maxmemory 最大值,當已用內存超過 maxmemory 限定時,就會觸發主動清理策略

RDB 對過期鍵的處理

生成 RDB 文件

程序會被數據庫中的鍵進行檢查,過期的鍵不會被保存到新創建的 RDB 文件中。因此數據庫中的過期鍵不會對生成新的 RDB 文件造成影響

載入 RDB 文件

這里需要分情況說明:

  • 如果服務器以主服務器模式運行,則在載入 RDB 文件時,程序會對文件中保存的鍵進行檢查,過期鍵不會被載入到數據庫中。所以過期鍵不會對載入 RDB 文件的主服務器造成影響。
  • 如果服務器以從服務器模式運行,則在載入 RDB 文件時,不論鍵是否過期都會被載入到數據庫中。但由于主從服務器在進行數據同步時,從服務器的數據會被清空。所以一般來說,過期鍵對載入 RDB 文件的從服務器也不會造成影響。

AOF 對過期鍵的處理

AOF 文件寫入

當服務器以 AOF 持久化模式運行時,如果數據庫某個過期鍵還沒被刪除,那么 AOF 文件不會因為這個過期鍵而產生任何影響,依舊保留。

而當過期鍵被刪除后,那么程序會向 AOF 文件追加一條 DEL 命令來顯式地記錄該鍵被刪除。

AOF 重寫

執行 AOF 重寫過程中,也會被數據庫的鍵進行檢查,已過期的鍵不會被保存到重寫后的 AOF 文件中。因此不會對 AOF 重寫造成影響

復制對過期鍵的處理

當服務器運行在復制模式下,由主服務器來控制從服務器的刪除過期鍵動作,目的是保證主從服務器數據的一致性。

那到底是怎么控制的呢?

  • 主服務器刪除一個過期鍵后,會向所有從服務器發送一個 DEL 命令,告訴從服務器刪除這個過期鍵
  • 從服務器接受到命令后,刪除過期鍵

PS:從服務器在接收到客戶端對過期鍵的讀命令時,依舊會返回該鍵對應的值給客戶端,而不會將其刪除。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 淺談Redis的幾個過期策略
  • Redis中的數據過期策略詳解
  • Redis數據過期策略的實現詳解

標簽:拉薩 河源 伊春 泰州 南寧 畢節 定州 甘南

巨人網絡通訊聲明:本文標題《大家都應該知道的Redis過期鍵與過期策略》,本文關鍵詞  大家,都,應該,知道,的,Redis,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《大家都應該知道的Redis過期鍵與過期策略》相關的同類信息!
  • 本頁收集關于大家都應該知道的Redis過期鍵與過期策略的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 欧美日韩亚洲国产精品一区二区| 交换妻子| 和老师在办公室做好硬好紧| metart欧美撒尿人体欣赏精品| 中文字幕人妻一区二区在线视频| 美女任你躁免费视频| 中国女人18xnxx| 国产精品日本一区二区在线播放| 酒吧大姐大| pitbull的妻子| 久久99热狠狠色AV蜜桃| 日本人妻巨大乳喷奶水电影| 欧美黄动漫| 国产成人综合网| jiZZJIZZ学生老师视频| 和亲戚老太的性经历| 直亲刮伦好| 久久久国产精品免费视频 | 韩漫免费漫画在线观看方法| 色男人视频| 182tv午夜精品视频在线播放| 男j进女p动态图片| 亚州日本人成网站在线观看| 白丝美女被狂躁视频免费网站| 男肌肌桶女肌肌桶出水视频| 西西4444www无码精品| 中文日产幕无线码一区2023| 国产精品白丝喷水在线观看 | 无码亚洲AV日韩美AⅤ最新| 男人添女人下面视频视频| 门源| 亚洲精品一级毛片| 亚洲码专区| 免费国产视频| 综合一和综合二图片区别在哪| 深夜爽爽爽福利动态图| 久久国产精品| 日韩美女AAAAA片片免费| 美女视频黄频女a大全| 久久精品www| 成人精品网站永久在线观看免费|