1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-19 15:49:24 +03:00

Fix integer overflow in debug message of walreceiver

The message tries to tell the replication apply delay which fails if
the first WAL record is not applied yet. Fix is, instead of telling
overflowed minus numeric, showing "N/A" which indicates that the delay
data is not yet available. Problem reported by me and patch by
Fabrízio de Royes Mello.

Back patched to 9.4, 9.3 and 9.2 stable branches (9.1 and 9.0 do not
have the debug message).
This commit is contained in:
Tatsuo Ishii
2015-03-14 08:16:50 +09:00
parent 590fc5d96f
commit 4909cb59df
2 changed files with 26 additions and 7 deletions

View File

@@ -793,15 +793,26 @@ ProcessWalSndrMessage(XLogRecPtr walEnd, TimestampTz sendTime)
{ {
char *sendtime; char *sendtime;
char *receipttime; char *receipttime;
int applyDelay;
/* Copy because timestamptz_to_str returns a static buffer */ /* Copy because timestamptz_to_str returns a static buffer */
sendtime = pstrdup(timestamptz_to_str(sendTime)); sendtime = pstrdup(timestamptz_to_str(sendTime));
receipttime = pstrdup(timestamptz_to_str(lastMsgReceiptTime)); receipttime = pstrdup(timestamptz_to_str(lastMsgReceiptTime));
elog(DEBUG2, "sendtime %s receipttime %s replication apply delay %d ms transfer latency %d ms", applyDelay = GetReplicationApplyDelay();
sendtime,
receipttime, /* apply delay is not available */
GetReplicationApplyDelay(), if (applyDelay == -1)
GetReplicationTransferLatency()); elog(DEBUG2, "sendtime %s receipttime %s replication apply delay (N/A) transfer latency %d ms",
sendtime,
receipttime,
GetReplicationTransferLatency());
else
elog(DEBUG2, "sendtime %s receipttime %s replication apply delay %d ms transfer latency %d ms",
sendtime,
receipttime,
applyDelay,
GetReplicationTransferLatency());
pfree(sendtime); pfree(sendtime);
pfree(receipttime); pfree(receipttime);
} }

View File

@@ -241,7 +241,8 @@ GetWalRcvWriteRecPtr(XLogRecPtr *latestChunkStart)
} }
/* /*
* Returns the replication apply delay in ms * Returns the replication apply delay in ms or -1
* if the apply delay info is not available
*/ */
int int
GetReplicationApplyDelay(void) GetReplicationApplyDelay(void)
@@ -255,6 +256,8 @@ GetReplicationApplyDelay(void)
long secs; long secs;
int usecs; int usecs;
TimestampTz chunckReplayStartTime;
SpinLockAcquire(&walrcv->mutex); SpinLockAcquire(&walrcv->mutex);
receivePtr = walrcv->receivedUpto; receivePtr = walrcv->receivedUpto;
SpinLockRelease(&walrcv->mutex); SpinLockRelease(&walrcv->mutex);
@@ -264,7 +267,12 @@ GetReplicationApplyDelay(void)
if (XLByteEQ(receivePtr, replayPtr)) if (XLByteEQ(receivePtr, replayPtr))
return 0; return 0;
TimestampDifference(GetCurrentChunkReplayStartTime(), chunckReplayStartTime = GetCurrentChunkReplayStartTime();
if (chunckReplayStartTime == 0)
return -1;
TimestampDifference(chunckReplayStartTime,
GetCurrentTimestamp(), GetCurrentTimestamp(),
&secs, &usecs); &secs, &usecs);