亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > redis學習之RDB、AOF與復制時對過期鍵的處理教程

redis學習之RDB、AOF與復制時對過期鍵的處理教程

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

生成RDB文件

在執(zhí)行SAVE命令或者BGSAVE命令創(chuàng)建一個新的RDB文件時,程序會對數(shù)據(jù)庫中的鍵進行檢查,已過期的鍵不會被保存到新創(chuàng)建的RDB文件中。

舉個例子,如果數(shù)據(jù)庫中包含三個鍵k1、k2、k3,并且k2已經過期,那么當執(zhí)行SAVE命令或者BGSAVE命令時,程序只會將k1和k3的數(shù)據(jù)保存到RDB文件中,而k2則會被忽略。

因此,數(shù)據(jù)庫中包含過期鍵不會對生成新的RDB文件造成影響。

可參考rdb.c中函數(shù)rdbSave()函數(shù)源碼:

/* Iterate this DB writing every entry 
   *
   * 遍歷數(shù)據(jù)庫,并寫入每個鍵值對的數(shù)據(jù)
   */
  while((de = dictNext(di)) != NULL) {
   sds keystr = dictGetKey(de);
   robj key, *o = dictGetVal(de);
   long long expire;
   
   // 根據(jù) keystr ,在棧中創(chuàng)建一個 key 對象
   initStaticStringObject(key,keystr);

   // 獲取鍵的過期時間
   expire = getExpire(db,key);

   // 保存鍵值對數(shù)據(jù)
   if (rdbSaveKeyValuePair(rdb,key,o,expire,now) == -1) goto werr;
  }

rdbSaveKeyValuePair函數(shù)實現(xiàn)如下:

/* Save a key-value pair, with expire time, type, key, value.
 *
 * 將鍵值對的鍵、值、過期時間和類型寫入到 RDB 中。
 *
 * On error -1 is returned.
 *
 * 出錯返回 -1 。
 *
 * On success if the key was actually saved 1 is returned, otherwise 0
 * is returned (the key was already expired). 
 *
 * 成功保存返回 1 ,當鍵已經過期時,返回 0 。
 */
int rdbSaveKeyValuePair(rio *rdb, robj *key, robj *val,
      long long expiretime, long long now)
{
 /* Save the expire time 
  *
  * 保存鍵的過期時間
  */
 if (expiretime != -1) {
  /* If this key is already expired skip it 
   *
   * 不寫入已經過期的鍵
   */
  if (expiretime  now) return 0;

  if (rdbSaveType(rdb,REDIS_RDB_OPCODE_EXPIRETIME_MS) == -1) return -1;
  if (rdbSaveMillisecondTime(rdb,expiretime) == -1) return -1;
 }
 /* Save type, key, value 
  *
  * 保存類型,鍵,值
  */
 if (rdbSaveObjectType(rdb,val) == -1) return -1;
 if (rdbSaveStringObject(rdb,key) == -1) return -1;
 if (rdbSaveObject(rdb,val) == -1) return -1;
 return 1;
}

載入RDB文件

在啟動Redis服務器時,如果服務器開啟了RDB功能,那么服務器將對RDB文件進行載入:

  • 如果服務器以主服務器模式運行,那么在載入RDB文件時,程序會對文件中保存的鍵進行檢查,未過期的鍵會被載入到數(shù)據(jù)庫中,而過期鍵則會被忽略,所以過期鍵對載入RDB文件的主服務器不會造成影響;
  • 如果服務器以從服務器模式運行,那么在載入RDB文件時,文件中保存的所有鍵,不論是否過期,都會被載入到數(shù)據(jù)庫中。不過,因為主從服務器在進行數(shù)據(jù)同步的時候,從服務器的數(shù)據(jù)庫就會被清空,所以一般來講,過期鍵對載入RDB文件的從服務器也不會造成影響;

這部分代碼可以查看rdb.c中rdbLoad()函數(shù)源碼:

/* Check if the key already expired. This function is used when loading
   * an RDB file from disk, either at startup, or when an RDB was
   * received from the master. In the latter case, the master is
   * responsible for key expiry. If we would expire keys here, the
   * snapshot taken by the master may not be reflected on the slave. 
   *
   * 如果服務器為主節(jié)點的話,
   * 那么在鍵已經過期的時候,不再將它們關聯(lián)到數(shù)據(jù)庫中去
   */
  if (server.masterhost == NULL  expiretime != -1  expiretime  now) {
   decrRefCount(key);
   decrRefCount(val);
   // 跳過
   continue;
  }

AOF文件寫入

當服務器以AOF持久化模式運行時,如果數(shù)據(jù)庫中的某個鍵已經過期,但它還沒有被惰性刪除或者定期刪除,那么AOF文件不會因為這個過期鍵而產生任何影響。

當過期鍵被惰性刪除或者定期刪除之后,程序會向AOF文件追加(append)一條DEL命令,來顯式地記錄該鍵已被刪除。
舉個例子,如果客戶端使用GET message命令,試圖訪問過期的message鍵,那么服務器將執(zhí)行以下三個動作:

1)從數(shù)據(jù)庫中刪除message鍵。

2)追加一條DEL message命令到AOF文件。(根據(jù)AOF文件增加的特點,AOF只有在客戶端進行請求的時候才會有這個DEL操作)

3)向執(zhí)行GET命令的客戶端返回空回復。

這部分就是Redis中的惰性刪除策略中expireIfNeeded函數(shù)的使用。關于惰性刪除策略這一部分在Redis惰性刪除策略一篇中有講。所以這里就不贅述了。

需要提示一下的是:expireIfNeeded函數(shù)是在db.c/lookupKeyRead()函數(shù)中被調用,lookupKeyRead函數(shù)用于在執(zhí)行讀取操作時取出鍵key在數(shù)據(jù)庫db中的值。

 AOF重寫

和生成RDB文件時類似,在執(zhí)行AOF重寫的過程中,程序會對數(shù)據(jù)庫中的鍵進行檢查,已過期的鍵不會被保存到重寫后的AOF文件中。

舉個例子,如果數(shù)據(jù)庫中包含三個鍵k1、k2、k3,并且k2已經過期,那么在進行重寫工作時,程序只會對k1和k3進行重寫,而k2則會被忽略。

這一部分如果掌握了AOF重寫的方法的話,那就自然理解了。

復制

當服務器運行在復制模式下時,從服務器的過期鍵刪除動作由主服務器控制:

  • 主服務器在刪除一個過期鍵之后,會顯式地向所有從服務器發(fā)送一個DEL命令,告知從服務器刪除這個過期鍵;
  • 從服務器在執(zhí)行客戶端發(fā)送的讀命令時,即使碰到過期鍵也不會將過期鍵刪除,而是繼續(xù)像處理未過期的鍵一樣來處理過期鍵;
  • 從服務器只有在接到主服務器發(fā)來的DEL命令之后,才會刪除過期鍵。

舉個例子,有一對主從服務器,它們的數(shù)據(jù)庫中都保存著同樣的三個鍵message、xxx和yyy,其中message為過期鍵,如圖所示

如果這時有客戶端向從服務器發(fā)送命令GET message,那么從服務器將發(fā)現(xiàn)message鍵已經過期,但從服務器并不會刪除message鍵,而是繼續(xù)將message鍵的值返回給客戶端,就好像message鍵并沒有過期一樣。

假設在此之后,有客戶端向主服務器發(fā)送命令GET message,那么主服務器將發(fā)現(xiàn)鍵message已經過期:主服務器會刪除message鍵,向客戶端返回空回復,并向從服務器發(fā)送DEL message命令,如圖所示:

從服務器在接收到主服務器發(fā)來的DEL message命令之后,也會從數(shù)據(jù)庫中刪除message鍵,在這之后,主從服務器都不再保存過期鍵message了,如圖所示:

總結

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

您可能感興趣的文章:
  • Redis 徹底禁用RDB持久化操作
  • 淺談Redis中的RDB快照
  • Redis 通過 RDB 方式進行數(shù)據(jù)備份與還原的方法
  • Redis持久化RDB和AOF區(qū)別詳解
  • Redis打開rdb文件常用方法詳解
  • Redis兩種持久化方案RDB和AOF詳解
  • 了解redis中RDB結構_動力節(jié)點Java學院整理
  • Redis RDB技術底層原理詳解

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

巨人網絡通訊聲明:本文標題《redis學習之RDB、AOF與復制時對過期鍵的處理教程》,本文關鍵詞  redis,學,習之,RDB,AOF,與,復制,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《redis學習之RDB、AOF與復制時對過期鍵的處理教程》相關的同類信息!
  • 本頁收集關于redis學習之RDB、AOF與復制時對過期鍵的處理教程的相關信息資訊供網民參考!
  • 推薦文章
    色综合久久天天综合| 国产一区二区精品| 黄色福利片| 台湾毛片| 国产91精品露脸国语对白| 成人在激情在线视频| 黄视频网站免费观看| 国产国产人免费视频成69堂| 日本伦理片网站| 日韩一级黄色| 天天做日日爱| 日本特黄特黄aaaaa大片 | 久久成人综合网| 黄视频网站在线看| 91麻豆精品国产自产在线 | 精品国产亚洲人成在线| 日韩一级黄色| 欧美国产日韩一区二区三区| 一本高清在线| 一a一级片| 久久国产一区二区| 久久国产影院| 精品国产一区二区三区免费 | 成人a大片在线观看| 99久久精品国产免费| 国产高清在线精品一区a| 国产麻豆精品免费视频| 亚洲 激情| 精品国产一区二区三区久| 精品视频免费在线| 欧美激情伊人| 国产网站免费| 国产不卡在线观看| 久久久久久久久综合影视网| 免费国产在线观看不卡| 国产福利免费观看| 国产精品免费久久| 成人免费观看视频| 成人免费观看的视频黄页| 日本在线不卡视频| 亚洲wwwwww| 你懂的日韩| 韩国三级香港三级日本三级la | 国产麻豆精品| 午夜在线亚洲| 91麻豆国产| 成人免费观看的视频黄页| 国产成人精品综合久久久| 精品久久久久久中文| 欧美α片无限看在线观看免费| 久久国产一久久高清| 成人免费观看视频| 日韩专区一区| 欧美一级视频免费观看| 四虎影视久久久免费| 色综合久久久久综合体桃花网| 青青久久精品国产免费看| 99色播| 日本免费区| 精品视频一区二区三区免费| 欧美激情一区二区三区视频| 国产一区免费观看| 久久99中文字幕| 成人高清视频免费观看| 香蕉视频亚洲一级| 99久久精品国产高清一区二区| 可以免费在线看黄的网站| 深夜做爰性大片中文| 午夜在线亚洲男人午在线| 亚洲 国产精品 日韩| 国产美女在线观看| 成人av在线播放| 国产伦久视频免费观看 视频| 欧美大片一区| 亚欧成人乱码一区二区| 精品国产亚洲人成在线| 韩国毛片| 香蕉视频一级| 一级女性全黄生活片免费| 日本伦理片网站| 日韩中文字幕在线播放| 国产一区二区福利久久| 国产a毛片| 亚洲精品中文一区不卡| 国产视频在线免费观看| 二级片在线观看| 日本特黄特黄aaaaa大片| 国产一区免费在线观看| 91麻豆精品国产自产在线 | 午夜精品国产自在现线拍| 成人影视在线观看| 日韩一级黄色| 国产国语在线播放视频| 欧美一级视频免费观看| 成人影院一区二区三区| 一 级 黄 中国色 片| 黄视频网站在线看| 午夜家庭影院| 麻豆系列 在线视频| 九九干| 亚洲www美色| 亚洲第一色在线| 亚欧成人乱码一区二区 | 亚飞与亚基在线观看| 国产一区二区精品| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品视频在线看| 日韩欧美一二三区| 国产一区二区精品| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 久久精品道一区二区三区| 免费的黄视频| 亚洲第一页色| 国产综合成人观看在线| 青青久久精品| 色综合久久天天综线观看| 美女免费毛片| 亚洲精品永久一区| 日本伦理黄色大片在线观看网站| 国产一区二区精品久久| 国产网站免费视频| 久久成人性色生活片| 精品视频在线观看视频免费视频| 欧美日本免费| 久久99这里只有精品国产| 日本免费区| a级精品九九九大片免费看| 国产91丝袜高跟系列| 久久99中文字幕久久| 日韩专区一区| 91麻豆精品国产自产在线| 色综合久久天天综合绕观看| 成人a级高清视频在线观看| 青青久久国产成人免费网站| 欧美一区二区三区在线观看| 欧美国产日韩久久久| 黄色免费三级| 国产综合成人观看在线| 99久久精品费精品国产一区二区| 韩国三级一区| 免费毛片播放| 久久99这里只有精品国产| 天天做人人爱夜夜爽2020毛片| 国产伦理精品| 青草国产在线观看| 久久精品人人做人人爽97| 午夜家庭影院| 日韩av片免费播放| 国产精品免费久久| 日韩中文字幕一区| 日韩在线观看免费| 国产高清在线精品一区a| 日本在线不卡视频| 欧美激情一区二区三区视频| 欧美a级v片不卡在线观看| 一本伊大人香蕉高清在线观看| 国产麻豆精品高清在线播放| 欧美另类videosbestsex视频| 四虎久久影院| 成人a级高清视频在线观看| 精品国产一区二区三区免费 | 中文字幕一区二区三区 精品| 日本特黄特黄aaaaa大片 | 日韩在线观看视频免费| 精品视频免费观看| 精品视频在线看| 精品视频免费在线| 国产欧美精品| 亚洲wwwwww| 午夜在线观看视频免费 成人| 日韩在线观看免费| 欧美大片一区| 色综合久久久久综合体桃花网| 久久国产一区二区| 久久国产影院| 成人免费观看视频| 尤物视频网站在线| 97视频免费在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品久久久久久免费影院| 亚洲wwwwww| 免费国产在线视频| 午夜欧美成人久久久久久| 欧美国产日韩久久久| 99热视热频这里只有精品| 色综合久久天天综合| 一级女性全黄生活片免费| 一级片免费在线观看视频| 国产成人精品影视| 日韩在线观看免费| 色综合久久久久综合体桃花网| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 沈樵在线观看福利| 国产一区二区福利久久| 国产麻豆精品免费密入口| 国产视频久久久| 亚洲天堂在线播放| 国产欧美精品午夜在线播放| 91麻豆精品国产综合久久久| 精品视频一区二区三区免费|