亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > PostgreSQL > 正文

PostgreSQL實(shí)戰(zhàn)之啟動(dòng)恢復(fù)讀取checkpoint記錄失敗的條件詳解

2020-03-12 23:45:33
字體:
供稿:網(wǎng)友

1、首先讀取ControlFile->checkPoint指向的checkpoint

2、如果讀取失敗,slave直接abort退出,master再次讀取ControlFile->prevCheckPoint指向的checkpoint

StartupXLOG-> |--checkPointLoc = ControlFile->checkPoint; |--record = ReadCheckpointRecord(xlogreader, checkPointLoc, 1, true): |-- if (record != NULL){   ...  }else if (StandbyMode){   ereport(PANIC,(errmsg("could not locate a valid checkpoint record")));  }else{   checkPointLoc = ControlFile->prevCheckPoint;   record = ReadCheckpointRecord(xlogreader, checkPointLoc, 2, true);   if (record != NULL){    InRecovery = true;//標(biāo)記下面進(jìn)入recovery   }else{    ereport(PANIC,(errmsg("could not locate a valid checkpoint record")));   }  }

一、那么什么條件下讀取的checkpoint記錄record==NULL?

1、ControlFile->checkPoint % XLOG_BLCKSZ < SizeOfXLogShortPHD
2、ReadRecord(xlogreader, ControlFile->checkPoint, LOG, true)返回NULL
3、ReadRecord讀到的record!=NULL && record->xl_rmid != RM_XLOG_ID
4、ReadRecord讀到的record!=NULL && info != XLOG_CHECKPOINT_SHUTDOWN && info != XLOG_CHECKPOINT_ONLINE
5、ReadRecord讀到的record!=NULL && record->xl_tot_len != SizeOfXLogRecord + SizeOfXLogRecordDataHeaderShort + sizeof(CheckPoint)

二、ReadRecord函數(shù)返回NULL的條件

ReadRecord(xlogreader, ControlFile->checkPoint, LOG, true) |--record = XLogReadRecord(xlogreader, ControlFile->checkPoint, &errormsg); |-- 2.1 record==NULL && !StandbyMode |-- 2.2 record!=NULL && !tliInHistory(xlogreader->latestPageTLI, expectedTLEs) /*----- note:只要讀取了一頁xlog,就會(huì)賦值為該頁第一個(gè)記錄的時(shí)間線 XLogReaderValidatePageHeader  -->xlogreader->latestPageTLI=hdr->xlp_tli; ------*/

三、XlogReadRecord讀取checkpoint返回NULL的條件?

XLogReadRecord(xlogreader, ControlFile->checkPoint, &errormsg)
    targetPagePtr = ControlFile->checkPoint - (ControlFile->checkPoint % XLOG_BLCKSZ);
    targetRecOff = ControlFile->checkPoint % XLOG_BLCKSZ;
    readOff = ReadPageInternal(state,targetPagePtr, Min(targetRecOff + SizeOfXLogRecord, XLOG_BLCKSZ));
    pageHeaderSize = XLogPageHeaderSize((XLogPageHeader) state->readBuf);
    record = (XLogRecord *) (state->readBuf + RecPtr % XLOG_BLCKSZ);
    total_len = record->xl_tot_len;
    -------------
    1、readOff < 0
    2、0< targetRecOff < pageHeaderSize
    3、(((XLogPageHeader) state->readBuf)->xlp_info & XLP_FIRST_IS_CONTRECORD) && targetRecOff == pageHeaderSize
       page頭有跨頁的record并且checkpoint定位的偏移正好在頁頭尾部
    4、targetRecOff <= XLOG_BLCKSZ - SizeOfXLogRecord && 
       !ValidXLogRecordHeader(state, ControlFile->checkPoint, state->ReadRecPtr, record,randAccess)
       ---(record->xl_tot_len < SizeOfXLogRecord || record->xl_rmid > RM_MAX_ID || record->xl_prev != state->ReadRecPtr)
    5、targetRecOff > XLOG_BLCKSZ - SizeOfXLogRecord && total_len < SizeOfXLogRecord
    6、total_len > state->readRecordBufSize && !allocate_recordbuf(state, total_len)
       一旦該記錄損壞,total_len的長度非常大的話,就需要allocate_recordbuf擴(kuò)展state->readbuf,可能因此分配失敗abort
       記錄的checksum需要等待全部讀取完整記錄后才校驗(yàn)
    -------------

三、ReadPageInternal返回的readOff返回小于0的條件

ReadPageInternal(state,targetPagePtr, Min(targetRecOff + SizeOfXLogRecord, XLOG_BLCKSZ))

    1、第一次read wal文件,readLen = state->read_page:讀取第一頁。readLen < 0

    2、readLen>0 && !XLogReaderValidatePageHeader(state, targetSegmentPtr, state->readBuf)
    --

    3、讀取checkpoint所在頁readLen = state->read_page: readLen < 0

    4、readLen > 0 && readLen <= SizeOfXLogShortPHD

    5、!XLogReaderValidatePageHeader(state, pageptr, (char *) hdr)

四、XLogPageRead何時(shí)返回值<0 ?

/* 1、WaitForWALToBecomeAvailable open失敗 2、lseek 失敗 && !StandbyMode 3、read失敗 && !StandbyMode 4、校驗(yàn)page頭失敗 && !StandbyMode 如果是StandbyMode,則會(huì)重新retry->WaitForWALToBecomeAvailable,切換日志源進(jìn)行open */ !WaitForWALToBecomeAvailable(targetPagePtr + reqLen,private->randAccess,1,targetRecPtr)//open |-- return -1 readOff = targetPageOff; if (lseek(readFile, (off_t) readOff, SEEK_SET) < 0){  !StandbyMode:: return -1 } if (read(readFile, readBuf, XLOG_BLCKSZ) != XLOG_BLCKSZ){  !StandbyMode:: return -1 } XLogReaderValidatePageHeader(xlogreader, targetPagePtr, readBuf) !StandbyMode:: return -1

五、WaitForWALToBecomeAvailable何時(shí)返回false?

--XLOG_FROM_ARCHIVE | XLOG_FROM_PG_WAL
    1、先XLogFileReadAnyTLI open日志:
        1、遍歷時(shí)間線列表里的每一個(gè)時(shí)間線,從最新的開始
        2、當(dāng)讀取checkpoint的時(shí)候,source是XLOG_FROM_ANY
        3、先找歸檔的日志進(jìn)行open;如果open失敗再找WAL日志進(jìn)行open
        4、如果都沒有open成功,則向前找時(shí)間線,open前一個(gè)時(shí)間線segno和文件號(hào)相同的文件進(jìn)行open
        5、open成功后expectedTLEs被賦值為當(dāng)前時(shí)間線列表的所有值
    2、如果open失敗,則切換日志源:XLOG_FROM_ARCHIVE | XLOG_FROM_PG_WAL -> XLOG_FROM_STREAM
    3、切換日志源后,XLOG_FROM_ARCHIVE | XLOG_FROM_PG_WAL 則:
       slave && promote :return false
       !StandbyMode:return false
    --XLOG_FROM_STREAM
    1、!WalRcvStreaming()即receiver進(jìn)程掛了,切換日志源
    2、CheckForStandbyTrigger()切換日志源
    3、XLOG_FROM_STREAM->XLOG_FROM_ARCHIVE

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)VEVB武林網(wǎng)的支持。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到PostgreSQL頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
日韩欧美成人一区二区| 国产国产国产国产国产国产| 奇米四色…亚洲| 精品久久久精品| 久久久久毛片免费观看| 春暖花开亚洲一区二区三区| 2021久久国产精品不只是精品| 亚洲黄色av网址| 97免费视频观看| 800av在线免费观看| 国产白丝一区二区三区| 亚洲第一二三区| 国产精品伦理一区二区| 综合网日日天干夜夜久久| 在线观看欧美日韩国产| 一本一本久久a久久| 神马电影在线观看| 37pao成人国产永久免费视频| www.亚洲色图.com| 九九**精品视频免费播放| 日韩欧美久久| 亚洲欧美日本视频在线观看| 国模精品一区二区| 亚洲精品午夜久久久久久久| 羞羞色国产精品| 26uuu亚洲婷婷狠狠天堂| 欧美极品少妇xxxxⅹ裸体艺术| 国产一区二区片| 国产成人h网站| 五月婷婷六月激情| 九色在线视频蝌蚪| 国产精品自拍网站| 中国女人内谢69xxxx视频| 亚洲色图欧洲色图| 国产亚洲va综合人人澡精品| 玩弄中年熟妇正在播放| 好看的黄色网址| 国产在线一区二区三区播放| 国内精品免费午夜毛片| 女教师淫辱の教室蜜臀av软件| 日本一区精品久久久久影院| eeuss影院18www免费| 成人在线观看网址| 日韩视频123| 亚洲男人第一网站| 国产99在线|亚洲| 欧美一区二区三区公司| 天堂tv亚洲tv日本tv欧美人tv| 欧美日韩在线播放三区| 成人污污www网站免费丝瓜| 国产精品激情自拍| 一级全黄少妇性色生活片| 白丝校花扒腿让我c| 99re热精品| 久久久一区二区三区| 日韩在线视频一区二区三区| 国产精品日韩欧美一区二区| 小早川怜子一区二区三区| 久蕉在线视频| 男人操女人视频网站| 女人18毛片水真多免费播放| av免费在线播放网站| 欧美日韩视频在线观看一区二区三区| gogogo高清免费观看在线视频| 在线看的你懂得| 婷婷五月综合缴情在线视频| 国产大屁股喷水视频在线观看| 最近中文字幕2019免费| 欧美三级黄美女| 久久一二三四区| 茄子视频成人免费观看| 日韩欧美亚洲一区二区| 久久久久综合一区二区三区| 国产日韩第一页| 精品人妻aV中文字幕乱码色欲| 亚洲mm色国产网站| 国产在线观看黄色| 一边摸一边做爽的视频17国产| aaaaaaa大片免费看| 国产又粗又猛大又黄又爽| 久久久一区二区三区四区| a视频在线观看免费| 日韩欧美伦理电影院| 国模套图日韩精品一区二区| 亚州精品视频| 国产在线不卡一区二区三区| 亚洲精品一区二区三区新线路| jizzjizz日本护士免费| 亚洲一区二区黄| 午夜影院一区| 国产精品久久波多野结衣| 国产免费一区二区三区在线能观看| 亚洲av无码一区东京热久久| 2024国产精品| 天堂a√在线| 精品午夜久久福利影院| 亚洲国产综合人成综合网站| 欧美日韩成人精品| 毛片在线免费| 国产一二三区精品| 中文字幕日韩精品在线观看| 加勒比中文字幕精品| 成人短视频在线| 久久天天久久| 亚洲欧美日韩另类精品一区二区三区| 精品国产乱码久久久久久郑州公司| 99精品一级欧美片免费播放| 欧美精品三级在线观看| 欧美性猛交xx| 中文字幕在线免费专区| 野花社区视频在线观看| www中文字幕| 久精品在线观看| 国产999精品久久久影片官网| 日韩免费高清在线观看| 日本在线观看天堂男亚洲| 亚洲欧洲精品一区二区三区不卡| 欧美本精品男人aⅴ天堂| 鬼打鬼之黄金道士1992林正英| 日本在线免费看| 黄页大全在线免费观看| 97人人做人人爱| 久久久久无码精品国产sm果冻| 国产一区二区三区四| 一级片免费在线观看| 国产精品第二页| 天堂网视频在线观看| 日韩精品在线网站| 91网站免费入口| 国产aⅴ激情无码久久久无码| 欧美精品七区| 成人在线免费公开观看视频| 欧美一级黄色网| 国产精品成人av| 福利成人在线观看| 亚洲国产精彩视频| 少妇又紧又色又爽又刺激视频| 国产精品三区在线| 免费视频一区二区| 第84页国产精品| 好男人官网在线| 欧美被狂躁喷白浆精品| 国产一区二区不卡| 最近免费中文字幕在线第一页| 无遮挡的视频在线观看| 黄色一级免费视频| 免费黄色地址| 黑人巨大狂躁日本妞在线观看| 免费观看又色又爽又黄的网站| 日韩精品免费观看| 欧美成人国产精品一区二区| 114美女做爰视频在线| 国产suv精品一区二区四区视频| 91成人在线视频观看| 尤蜜粉嫩av国产一区二区三区| 国偷自产视频一区二区久| 免费无码一区二区三区| 亚洲私人影院在线观看| 国产系列精品av| 国产又爽又黄免费视频| www.国产二区| 中国美女乱淫免费看视频| 国产传媒免费在线观看| 国产青青视频| 一区二区三区中文字幕电影| 欧美午夜精品一区二区蜜桃| 黄色三级网站在线观看| 久久久久欧美| 亚洲va久久| 一本一本大道香蕉久在线精品| 日本激情五月| 精品国产精品一区二区夜夜嗨| 国产黄人亚洲片| 欧美图区在线视频| 中文字幕乱码人妻无码久久| 亚洲成人偷拍| 加勒比视频一区| 亚洲免费一级视频| 亚洲国产欧美日韩在线观看第一区| 亚洲不卡一卡2卡三卡4卡5卡精品| 欧美片第1页综合| av观看成片免费网站| 91日韩在线视频| 国产精品你懂的在线欣赏| 国产午夜精品理论片| 亚洲免费中文字幕| 婷婷综合社区| 4438全国亚洲精品在线观看视频| 免费看的黄色欧美网站| 亚洲自拍偷拍网址| 日韩熟女一区二区| 久久久精品视频在线观看| 国产亚洲一本大道中文在线| 综合自拍亚洲综合图不卡区| 亚洲一区二区三区在线免费观看| 91文字幕巨乱亚洲香蕉| 91网在线看| 亚洲精品二区三区| 欧美大片aaaa| 麻豆一二三区精品蜜桃| 水蜜桃一区二区三区| 精品视频站长推荐| 老色鬼久久亚洲一区二区| 8848hh四虎| 欧美三级电影一区二区三区| 日韩视频免费观看高清完整版在线观看| 黄色网址免费看| 久久久福利影院| 91精品办公室少妇高潮对白| 国产精品一区hongkong| 亚洲人成绝费网站色ww| 免费日韩视频| 草莓视频一区二区三区| 亚洲色图狂野欧美| 国产女女做受ⅹxx高潮| 蜜桃a∨噜噜一区二区三区| 欧美一区二区三区在| 无码日韩精品一区二区免费| 91超碰在线播放| 成人在线高清| 91麻豆精品国产91久久久更新时间| 中文成人av在线| 久久九九国产| 一本色道婷婷久久欧美| 一区二区激情| 无国产精品白浆免费视| 中文字幕亚洲色图| 天天射天天爱天天射干| www黄色网址| 成人国产精品视频| 免费一级特黄3大片视频| 熟妇人妻中文av无码| 3d精品h动漫啪啪一区二区| 五月天中文字幕一区二区| 丁香5月婷婷久久| 亚洲精品久久久久久久久久久久久久| 国产精品呻吟久久| 国产av一区二区三区精品| 台湾佬成人中文网222vvv| 国产99re66在线视频| 手机看片一区二区| 中文字幕在线国产| 人妻一区二区三区| 性欧美xxxx免费岛国不卡电影| 国产精品中文字幕制服诱惑| 欧美一区二区三区视频| 日韩高清第一页| 国产亚洲成av人片在线观黄桃| 亚洲国产高清在线观看| 欧美xxxx黑人| 国一区二区在线观看| 久久视频在线观看中文字幕| 欧美伊久线香蕉线新在线| 黄网址在线播放免费| 国产在线你懂得| 国产又大又硬又粗| 8x8x国产| 精品成人久久| 婷婷精品国产一区二区三区日韩| 国产一区二区小视频| 国产精品久久久一区| 一区二区三区高清国产| 色猫咪免费人成网站在线观看| 国产福利一区二区在线精品| 亚洲国产成人av好男人在线观看| 中文字幕精品—区二区| 国产免费观看久久| 国产精品国产三级国产a| 午夜免费在线观看精品视频| 国产一区二区精品久久91| 韩国欧美国产1区| 福利在线一区二区三区| 综合久久99| 亚洲精品无人区| 久久久精品视频成人| 99国产精品久久久久久久成人| 日韩欧美a级成人黄色| 国产精品h视频| 亚洲精品国产精品自产a区红杏吧| 日本成本人片免费观看| 亚洲人成毛片在线播放| 最新国产在线精品91尤物| 亚洲日本护士毛茸茸| 十九岁完整版在线观看好看云免费| 中文字幕中文在线不卡住| 亚洲区自拍偷拍| 欧美激情一区二区三区不卡| 蜜臀av一区二区| 久久精品日韩欧美| 婷婷色一区二区三区| 日本精品久久久久中文| 91国内精品视频| 男人j桶女人的网站| 国产精品都在这里| xxx性欧美在线| 久久久成人网| 国产欧美一区二区三区沐欲| 欧美性猛交xxx乱大交3蜜桃| 亚洲一区二区毛片| 国精品一区二区| 日韩一区二区三区免费视频| 成人午夜精品视频| 国产精品美女视频免费观看软件| 久久深夜福利| 国产精品乱码一区二区三区视频| aa片在线观看视频在线播放| 黄色精品视频网站| 折磨小男生性器羞耻的故事| 天堂综合网久久| 伊人婷婷久久| 日韩精品电影| 91久久精品一区二区| 欧美日韩一区高清| 麻豆亚洲av成人无码久久精品| 欧美黄色免费在线观看| 国产精品麻豆99久久久久久| 日韩在线 中文字幕| 亚洲精品伊人| 青青精品视频播放| 香蕉久久免费电影| xxxx18国产| 不卡的av在线| 国产超碰精品在线观看| 精品人妻伦一二三区久久| av免费在线不卡| 国产成人啪午夜精品网站男同| 多人欧美交性姿势| 中文字幕在线观看成人|