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

查看所有标签

猜你喜欢:

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

浪潮之巅(第2版)(套装上下册)

浪潮之巅(第2版)(套装上下册)

吴军 / 人民邮电出版社 / 2013-7 / 80.00元

一个企业的发展与崛起,绝非只是空有领导强人即可达成。任何的决策、同期的商业环境,都在都影响着企业的兴衰。《浪潮之巅》不只是一本历史书,除了讲述科技顶尖企业的发展规律,对于华尔街如何左右科技公司,以及金融风暴对科技产业的冲击,也多有着墨。此外,这本书也着力讲述很多尚在普及或将要发生的,比如微博和云计算,以及对下一代互联网科技产业浪潮的判断和预测。因为在极度商业化的今天,科技的进步和商机是分不开的。 ......一起来看看 《浪潮之巅(第2版)(套装上下册)》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

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

URL 编码/解码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试