PostgreSQL启动恢复过程中日志源的切换

栏目: 数据库 · 发布时间: 5年前

内容简介:日志源会在XLOG_FROM_ARCHIVE->XLOG_FROM_STREAM->XLOG_FROM_ARCHIVE直接切换,只有读取过程中出错,就会切换到另外一个日志源。但实际执行过程中,XLOG_FROM_ARCHIVE出错后会到XLOG_FROM_PG_WAL读取,但是日志源的变量并不会改变。这个需要注意。static int

日志源会在XLOG_FROM_ARCHIVE->XLOG_FROM_STREAM->XLOG_FROM_ARCHIVE直接切换,只有读取过程中出错,就会切换到另外一个日志源。但实际执行过程中,XLOG_FROM_ARCHIVE出错后会到XLOG_FROM_PG_WAL读取,但是日志源的变量并不会改变。这个需要注意。

PostgreSQL启动恢复过程中日志源的切换

static int

XLogFileReadAnyTLI(XLogSegNo segno, int emode, int source)

{

if (expectedTLEs)

tles = expectedTLEs;

else

tles = readTimeLineHistory(recoveryTargetTLI);

/*

1、WaitForWALToBecomeAvailable调用时,source是XLOG_FROM_ARCHIVE时,会使用XLOG_FROM_ANY

2、使用XLOG_FROM_ANY,会首先从归档中读取xlog,如果open失败,则会使用XLOG_FROM_PG_WAL

3、外部日志源变量并没有切换

*/

foreach(cell, tles){

TimeLineID tli = ((TimeLineHistoryEntry *) lfirst(cell))->tli;

if (tli < curFileTLI)

break;    /* don't bother looking at too-old TLIs */

if (source == XLOG_FROM_ANY || source == XLOG_FROM_ARCHIVE){

fd = XLogFileRead(segno, emode, tli,XLOG_FROM_ARCHIVE, true);

if (fd != -1){

if (!expectedTLEs)

expectedTLEs = tles;

return fd;

}

}

if (source == XLOG_FROM_ANY || source == XLOG_FROM_PG_WAL){

fd = XLogFileRead(segno, emode, tli, XLOG_FROM_PG_WAL, true);

if (fd != -1){

if (!expectedTLEs)

expectedTLEs = tles;

return fd;

}

}

}

return -1;

}

Linux公社的RSS地址https://www.linuxidc.com/rssFeed.aspx

本文永久更新链接地址: https://www.linuxidc.com/Linux/2019-02/157095.htm


以上所述就是小编给大家介绍的《PostgreSQL启动恢复过程中日志源的切换》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

艾伦•图灵传

艾伦•图灵传

(英)安德鲁·霍奇斯 / 孙天齐 / 湖南科学技术出版社 / 2012-8-1 / 68.00元

《艾伦·图灵传:如谜的解谜者》是图灵诞辰100周年纪念版,印制工艺更为精美。本书是世界共认的最权威的图灵传记。艾伦?图灵是现代人工智能的鼻祖,在24岁时奠定了计算机的理论基础。二战期间,他为盟军破译密码,为结束战争做出巨大贡献。战后,他开创性地提出人工智能的概念,并做了大量的前期工作。因同性恋问题事发,被迫注射激素,后来吃毒苹果而死。作者是一名数学家,也是一名同性恋者。他对图灵的生平有切身的体会,......一起来看看 《艾伦•图灵传》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具