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

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

内容简介:日志源会在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启动恢复过程中日志源的切换》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

C专家编程

C专家编程

Peter Van Der Linden / 徐波 / 人民邮电出版社 / 2008-2 / 45.00元

《C专家编程》展示了最优秀的C程序员所使用的编码技巧,并专门开辟了一章对C++的基础知识进行了介绍。 书中C的历史、语言特性、声明、数组、指针、链接、运行时、内存以及如何进一步学习C++等问题进行了细致的讲解和深入的分析。全书撷取几十个实例进行讲解,对C程序员具有非常高的实用价值。 本书可以帮助有一定经验的C程序员成为C编程方面的专家,对于具备相当的C语言基础的程序员,本书可以帮助他们......一起来看看 《C专家编程》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

URL 编码/解码
URL 编码/解码

URL 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具