mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-24 01:29:19 +03:00 
			
		
		
		
	Clarify some errors in pg_receivewal when closing WAL segments
A WAL segment closed during a WAL stream for pg_receivewal would
generate incorrect error messages depending on the context, as the file
name used when referring to a WAL segment ignored partial files or the
compression method used.  In such cases, the error message generated
(failure on close, seek or rename) would not match a physical file
name.  The same code paths are used by pg_basebackup, but it uses no
partial suffix so it is not impacted.
7fbe0c8 has introduced in walmethods.c a callback to get the exact
physical file name used for a given context, this commit makes use of it
to improve those error messages.  This could be extended to more code
paths of pg_basebackup/ in the future, if necessary.
Extracted from a larger patch by the same author.
Author: Georgios Kokolatos
Discussion: https://postgr.es/m/ZCm1J5vfyQ2E6dYvXz8si39HQ2gwxSZ3IpYaVgYa3lUwY88SLapx9EEnOf5uEwrddhx2twG7zYKjVeuP5MwZXCNPybtsGouDsAD1o2L_I5E=@pm.me
			
			
This commit is contained in:
		| @@ -185,20 +185,27 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint) | |||||||
| static bool | static bool | ||||||
| close_walfile(StreamCtl *stream, XLogRecPtr pos) | close_walfile(StreamCtl *stream, XLogRecPtr pos) | ||||||
| { | { | ||||||
|  | 	char	   *fn; | ||||||
| 	off_t		currpos; | 	off_t		currpos; | ||||||
| 	int			r; | 	int			r; | ||||||
|  |  | ||||||
| 	if (walfile == NULL) | 	if (walfile == NULL) | ||||||
| 		return true; | 		return true; | ||||||
|  |  | ||||||
|  | 	/* Note that this considers the compression used if necessary */ | ||||||
|  | 	fn = stream->walmethod->get_file_name(current_walfile_name, | ||||||
|  | 										  stream->partial_suffix); | ||||||
|  |  | ||||||
| 	currpos = stream->walmethod->get_current_pos(walfile); | 	currpos = stream->walmethod->get_current_pos(walfile); | ||||||
|  |  | ||||||
| 	if (currpos == -1) | 	if (currpos == -1) | ||||||
| 	{ | 	{ | ||||||
| 		pg_log_error("could not determine seek position in file \"%s\": %s", | 		pg_log_error("could not determine seek position in file \"%s\": %s", | ||||||
| 					 current_walfile_name, stream->walmethod->getlasterror()); | 					 fn, stream->walmethod->getlasterror()); | ||||||
| 		stream->walmethod->close(walfile, CLOSE_UNLINK); | 		stream->walmethod->close(walfile, CLOSE_UNLINK); | ||||||
| 		walfile = NULL; | 		walfile = NULL; | ||||||
|  |  | ||||||
|  | 		pg_free(fn); | ||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -208,8 +215,7 @@ close_walfile(StreamCtl *stream, XLogRecPtr pos) | |||||||
| 			r = stream->walmethod->close(walfile, CLOSE_NORMAL); | 			r = stream->walmethod->close(walfile, CLOSE_NORMAL); | ||||||
| 		else | 		else | ||||||
| 		{ | 		{ | ||||||
| 			pg_log_info("not renaming \"%s%s\", segment is not complete", | 			pg_log_info("not renaming \"%s\", segment is not complete", fn); | ||||||
| 						current_walfile_name, stream->partial_suffix); |  | ||||||
| 			r = stream->walmethod->close(walfile, CLOSE_NO_RENAME); | 			r = stream->walmethod->close(walfile, CLOSE_NO_RENAME); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @@ -221,10 +227,14 @@ close_walfile(StreamCtl *stream, XLogRecPtr pos) | |||||||
| 	if (r != 0) | 	if (r != 0) | ||||||
| 	{ | 	{ | ||||||
| 		pg_log_error("could not close file \"%s\": %s", | 		pg_log_error("could not close file \"%s\": %s", | ||||||
| 					 current_walfile_name, stream->walmethod->getlasterror()); | 					 fn, stream->walmethod->getlasterror()); | ||||||
|  |  | ||||||
|  | 		pg_free(fn); | ||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	pg_free(fn); | ||||||
|  |  | ||||||
| 	/* | 	/* | ||||||
| 	 * Mark file as archived if requested by the caller - pg_basebackup needs | 	 * Mark file as archived if requested by the caller - pg_basebackup needs | ||||||
| 	 * to do so as files can otherwise get archived again after promotion of a | 	 * to do so as files can otherwise get archived again after promotion of a | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user