mirror of
https://github.com/postgres/postgres.git
synced 2025-05-05 09:19:17 +03:00
Fix statistics breakage from bgwriter/checkpointer process split.
ForwardFsyncRequest() supposed that it could only be called in regular backends, which used to be true; but since the splitup of bgwriter and checkpointer, it is also called in the bgwriter. We do not want to count such calls in pg_stat_bgwriter.buffers_backend statistics, so fix things so that they aren't. (It's worth noting here that this implies an alarmingly large increase in the expected amount of cross-process fsync request traffic, which may well mean that the process splitup was not such a hot idea.)
This commit is contained in:
parent
d843589e5a
commit
1e9326d6a3
@ -1135,7 +1135,8 @@ ForwardFsyncRequest(RelFileNode rnode, ForkNumber forknum, BlockNumber segno)
|
||||
LWLockAcquire(CheckpointerCommLock, LW_EXCLUSIVE);
|
||||
|
||||
/* Count all backend writes regardless of if they fit in the queue */
|
||||
CheckpointerShmem->num_backend_writes++;
|
||||
if (!AmBackgroundWriterProcess())
|
||||
CheckpointerShmem->num_backend_writes++;
|
||||
|
||||
/*
|
||||
* If the checkpointer isn't running or the request queue is full, the
|
||||
@ -1150,7 +1151,8 @@ ForwardFsyncRequest(RelFileNode rnode, ForkNumber forknum, BlockNumber segno)
|
||||
* Count the subset of writes where backends have to do their own
|
||||
* fsync
|
||||
*/
|
||||
CheckpointerShmem->num_backend_fsync++;
|
||||
if (!AmBackgroundWriterProcess())
|
||||
CheckpointerShmem->num_backend_fsync++;
|
||||
LWLockRelease(CheckpointerCommLock);
|
||||
return false;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user