mirror of
https://github.com/postgres/postgres.git
synced 2025-06-29 10:41:53 +03:00
Fsync directory after creating or unlinking file.
If file was created/deleted just before powerloss it's possible that file system will miss that. To prevent it, call fsync() where creating/ unlinkg file is critical. Author: Michael Paquier Reviewed-by: Ashutosh Bapat, Takayuki Tsunakawa, me
This commit is contained in:
@ -3475,7 +3475,7 @@ InstallXLogFileSegment(XLogSegNo *segno, char *tmppath,
|
||||
if (!find_free)
|
||||
{
|
||||
/* Force installation: get rid of any pre-existing segment file */
|
||||
unlink(path);
|
||||
durable_unlink(path, DEBUG1);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -4026,16 +4026,13 @@ RemoveXlogFile(const char *segname, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr)
|
||||
path)));
|
||||
return;
|
||||
}
|
||||
rc = unlink(newpath);
|
||||
rc = durable_unlink(newpath, LOG);
|
||||
#else
|
||||
rc = unlink(path);
|
||||
rc = durable_unlink(path, LOG);
|
||||
#endif
|
||||
if (rc != 0)
|
||||
{
|
||||
ereport(LOG,
|
||||
(errcode_for_file_access(),
|
||||
errmsg("could not remove old transaction log file \"%s\": %m",
|
||||
path)));
|
||||
/* Message already logged by durable_unlink() */
|
||||
return;
|
||||
}
|
||||
CheckpointStats.ckpt_segs_removed++;
|
||||
@ -10771,17 +10768,13 @@ do_pg_stop_backup(char *labelfile, bool waitforarchive, TimeLineID *stoptli_p)
|
||||
(errcode_for_file_access(),
|
||||
errmsg("could not read file \"%s\": %m",
|
||||
BACKUP_LABEL_FILE)));
|
||||
if (unlink(BACKUP_LABEL_FILE) != 0)
|
||||
ereport(ERROR,
|
||||
(errcode_for_file_access(),
|
||||
errmsg("could not remove file \"%s\": %m",
|
||||
BACKUP_LABEL_FILE)));
|
||||
durable_unlink(BACKUP_LABEL_FILE, ERROR);
|
||||
|
||||
/*
|
||||
* Remove tablespace_map file if present, it is created only if there
|
||||
* are tablespaces.
|
||||
*/
|
||||
unlink(TABLESPACE_MAP);
|
||||
durable_unlink(TABLESPACE_MAP, DEBUG1);
|
||||
}
|
||||
PG_END_ENSURE_ERROR_CLEANUP(pg_stop_backup_callback, (Datum) BoolGetDatum(exclusive));
|
||||
}
|
||||
|
Reference in New Issue
Block a user