Commit f2ff2035 authored by Fujii Masao's avatar Fujii Masao

Report missing wait event for timeline history file.

TimelineHistoryRead and TimelineHistoryWrite wait events are reported
during waiting for a read and write of a timeline history file, respectively.
However, previously, TimelineHistoryRead wait event was not reported
while readTimeLineHistory() was reading a timeline history file. Also
TimelineHistoryWrite was not reported while writeTimeLineHistory() was
writing one line with the details of the timeline split, at the end.
This commit fixes these issues.

Back-patch to v10 where wait events for a timeline history file was added.

Author: Masahiro Ikeda
Reviewed-by: Michael Paquier, Fujii Masao
Discussion: https://postgr.es/m/d11b0c910b63684424e06772eb844ab5@oss.nttdata.com
parent cd8c73a3
...@@ -78,7 +78,6 @@ readTimeLineHistory(TimeLineID targetTLI) ...@@ -78,7 +78,6 @@ readTimeLineHistory(TimeLineID targetTLI)
List *result; List *result;
char path[MAXPGPATH]; char path[MAXPGPATH];
char histfname[MAXFNAMELEN]; char histfname[MAXFNAMELEN];
char fline[MAXPGPATH];
FILE *fd; FILE *fd;
TimeLineHistoryEntry *entry; TimeLineHistoryEntry *entry;
TimeLineID lasttli = 0; TimeLineID lasttli = 0;
...@@ -123,15 +122,30 @@ readTimeLineHistory(TimeLineID targetTLI) ...@@ -123,15 +122,30 @@ readTimeLineHistory(TimeLineID targetTLI)
* Parse the file... * Parse the file...
*/ */
prevend = InvalidXLogRecPtr; prevend = InvalidXLogRecPtr;
while (fgets(fline, sizeof(fline), fd) != NULL) for (;;)
{ {
/* skip leading whitespace and check for # comment */ char fline[MAXPGPATH];
char *res;
char *ptr; char *ptr;
TimeLineID tli; TimeLineID tli;
uint32 switchpoint_hi; uint32 switchpoint_hi;
uint32 switchpoint_lo; uint32 switchpoint_lo;
int nfields; int nfields;
pgstat_report_wait_start(WAIT_EVENT_TIMELINE_HISTORY_READ);
res = fgets(fline, sizeof(fline), fd);
pgstat_report_wait_end();
if (res == NULL)
{
if (ferror(fd))
ereport(ERROR,
(errcode_for_file_access(),
errmsg("could not read file \"%s\": %m", path)));
break;
}
/* skip leading whitespace and check for # comment */
for (ptr = fline; *ptr; ptr++) for (ptr = fline; *ptr; ptr++)
{ {
if (!isspace((unsigned char) *ptr)) if (!isspace((unsigned char) *ptr))
...@@ -393,6 +407,7 @@ writeTimeLineHistory(TimeLineID newTLI, TimeLineID parentTLI, ...@@ -393,6 +407,7 @@ writeTimeLineHistory(TimeLineID newTLI, TimeLineID parentTLI,
nbytes = strlen(buffer); nbytes = strlen(buffer);
errno = 0; errno = 0;
pgstat_report_wait_start(WAIT_EVENT_TIMELINE_HISTORY_WRITE);
if ((int) write(fd, buffer, nbytes) != nbytes) if ((int) write(fd, buffer, nbytes) != nbytes)
{ {
int save_errno = errno; int save_errno = errno;
...@@ -408,6 +423,7 @@ writeTimeLineHistory(TimeLineID newTLI, TimeLineID parentTLI, ...@@ -408,6 +423,7 @@ writeTimeLineHistory(TimeLineID newTLI, TimeLineID parentTLI,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not write to file \"%s\": %m", tmppath))); errmsg("could not write to file \"%s\": %m", tmppath)));
} }
pgstat_report_wait_end();
pgstat_report_wait_start(WAIT_EVENT_TIMELINE_HISTORY_SYNC); pgstat_report_wait_start(WAIT_EVENT_TIMELINE_HISTORY_SYNC);
if (pg_fsync(fd) != 0) if (pg_fsync(fd) != 0)
......
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