mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-29 00:05:29 -04: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
							
								
									4a9c30a8a1
								
							
						
					
					
						commit
						80e373c3a8
					
				| @ -1132,7 +1132,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 | ||||
| @ -1147,7 +1148,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