Commit 3d39244e authored by Magnus Hagander's avatar Magnus Hagander

Retry opening new segments in pg_xlogdump --folllow

There is a small window between when the server closes out the existing
segment and the new one is created. Put a loop around the open call in
this case to make sure we wait for the new file to actually appear.
parent fd321a1d
...@@ -249,6 +249,7 @@ XLogDumpXLogRead(const char *directory, TimeLineID timeline_id, ...@@ -249,6 +249,7 @@ XLogDumpXLogRead(const char *directory, TimeLineID timeline_id,
if (sendFile < 0 || !XLByteInSeg(recptr, sendSegNo)) if (sendFile < 0 || !XLByteInSeg(recptr, sendSegNo))
{ {
char fname[MAXFNAMELEN]; char fname[MAXFNAMELEN];
int tries;
/* Switch to another logfile segment */ /* Switch to another logfile segment */
if (sendFile >= 0) if (sendFile >= 0)
...@@ -258,7 +259,30 @@ XLogDumpXLogRead(const char *directory, TimeLineID timeline_id, ...@@ -258,7 +259,30 @@ XLogDumpXLogRead(const char *directory, TimeLineID timeline_id,
XLogFileName(fname, timeline_id, sendSegNo); XLogFileName(fname, timeline_id, sendSegNo);
sendFile = fuzzy_open_file(directory, fname); /*
* In follow mode there is a short period of time after the
* server has written the end of the previous file before the
* new file is available. So we loop for 5 seconds looking
* for the file to appear before giving up.
*/
for (tries = 0; tries < 10; tries++)
{
sendFile = fuzzy_open_file(directory, fname);
if (sendFile >= 0)
break;
if (errno == ENOENT)
{
int save_errno = errno;
/* File not there yet, try again */
pg_usleep(500 * 1000);
errno = save_errno;
continue;
}
/* Any other error, fall through and fail */
break;
}
if (sendFile < 0) if (sendFile < 0)
fatal_error("could not find file \"%s\": %s", fatal_error("could not find file \"%s\": %s",
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment