Thread: More time spending with "delete pending"
Hello hackers, After fixing bug #16161 (pg_ctl inability to open just deleted postmaster.pid) there are still some errors related to the same Windows-only issue. Namely, pg_upgradeCheck failures seen on https://buildfarm.postgresql.org/cgi-bin/show_history.pl?nm=fairywren&br=REL_13_STABLE Here pg_ls_dir_files couldn't handle the "delete pending" state too. I've made a simple test to reproduce this behavior with pg_ls_waldir, that fails with: error running SQL: 'psql:<stdin>:1: ERROR: could not stat file "pg_wal/dummy": Permission denied' As noted in [1], a sensible solution would be putting the same "retry on ERROR_ACCESS_DENIED" action in a wrapper for stat(). And bed90759f brought in master the _pgstat64() function, where such error handling should be placed. So please look at the patch (based on the previous one made to fix bug#16161), that makes the attached test pass. And I have a few questions. For now genfile.c needs to include "port.h" explicitly to override definitions in "sys/stat.h", that override "stat" redefinition for Windows included implicitly above via "postgres.h". Without it the pg_ls_dir_files() function just uses system' stat(). So I wonder, is there a way to make all stat-calling code use the improved stat()? And if so, maybe the stat() call in pgwin32_open should be replaced with microsoft_native_stat(). And regarding released versions, are there any reasons to not backport bed90759f (with the proposed fix or alike)? [1] https://www.postgresql.org/message-id/396837.1605298573%40sss.pgh.pa.us Best regards, Alexander
Attachment
On Sat, Nov 14, 2020 at 01:00:00PM +0300, Alexander Lakhin wrote: > As noted in [1], a sensible solution would be putting the same "retry on > ERROR_ACCESS_DENIED" action in a wrapper for stat(). > And bed90759f brought in master the _pgstat64() function, where such > error handling should be placed. > So please look at the patch (based on the previous one made to fix > bug#16161), that makes the attached test pass. Your patch introduces a "loops", but doesn't use it to escape the loop. > diff --git a/src/backend/utils/adt/genfile.c b/src/backend/utils/adt/genfile.c > index d34182a7b0..922df49125 100644 > --- a/src/backend/utils/adt/genfile.c > +++ b/src/backend/utils/adt/genfile.c > @@ -28,6 +28,7 @@ > #include "funcapi.h" > #include "mb/pg_wchar.h" > #include "miscadmin.h" > +#include "port.h" > #include "postmaster/syslogger.h" > #include "storage/fd.h" > #include "utils/acl.h" > diff --git a/src/port/win32stat.c b/src/port/win32stat.c > index 4351aa4d08..c2b55c7fa6 100644 > --- a/src/port/win32stat.c > +++ b/src/port/win32stat.c > @@ -170,6 +170,7 @@ _pgstat64(const char *name, struct stat *buf) > SECURITY_ATTRIBUTES sa; > HANDLE hFile; > int ret; > + int loops = 0; > #if _WIN32_WINNT < 0x0600 > IO_STATUS_BLOCK ioStatus; > FILE_STANDARD_INFORMATION standardInfo; > @@ -182,31 +183,60 @@ _pgstat64(const char *name, struct stat *buf) > errno = EINVAL; > return -1; > } > - > /* fast not-exists check */ > if (GetFileAttributes(name) == INVALID_FILE_ATTRIBUTES) > { > - _dosmaperr(GetLastError()); > - return -1; > + DWORD err = GetLastError(); > + > + if (err != ERROR_ACCESS_DENIED) { > + _dosmaperr(err); > + return -1; > + } > } > > /* get a file handle as lightweight as we can */ > sa.nLength = sizeof(SECURITY_ATTRIBUTES); > sa.bInheritHandle = TRUE; > sa.lpSecurityDescriptor = NULL; > - hFile = CreateFile(name, > - GENERIC_READ, > - (FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE), > - &sa, > - OPEN_EXISTING, > - (FILE_FLAG_NO_BUFFERING | FILE_FLAG_BACKUP_SEMANTICS | > - FILE_FLAG_OVERLAPPED), > - NULL); > - if (hFile == INVALID_HANDLE_VALUE) > + while ((hFile = CreateFile(name, > + GENERIC_READ, > + (FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE), > + &sa, > + OPEN_EXISTING, > + (FILE_FLAG_NO_BUFFERING | FILE_FLAG_BACKUP_SEMANTICS | > + FILE_FLAG_OVERLAPPED), > + NULL)) == INVALID_HANDLE_VALUE) > { > DWORD err = GetLastError(); > > - CloseHandle(hFile); > + /* > + * ERROR_ACCESS_DENIED is returned if the file is deleted but not yet > + * gone (Windows NT status code is STATUS_DELETE_PENDING). In that > + * case we want to wait a bit and try again, giving up after 1 second > + * (since this condition should never persist very long). However, > + * there are other commonly-hit cases that return ERROR_ACCESS_DENIED, > + * so care is needed. In particular that happens if we try to open a > + * directory, or of course if there's an actual file-permissions > + * problem. To distinguish these cases, try a stat(). In the > + * delete-pending case, it will either also get STATUS_DELETE_PENDING, > + * or it will see the file as gone and fail with ENOENT. In other > + * cases it will usually succeed. The only somewhat-likely case where > + * this coding will uselessly wait is if there's a permissions problem > + * with a containing directory, which we hope will never happen in any > + * performance-critical code paths. > + */ > + if (err == ERROR_ACCESS_DENIED) > + { > + struct microsoft_native_stat st; > + > + if (microsoft_native_stat(name, &st) != 0) > + { > + pg_usleep(100000); > + loops++; > + continue; > + } > + } > + > _dosmaperr(err); > return -1; > }
15.11.2020 04:11, Justin Pryzby wrote: > On Sat, Nov 14, 2020 at 01:00:00PM +0300, Alexander Lakhin wrote: >> As noted in [1], a sensible solution would be putting the same "retry on >> ERROR_ACCESS_DENIED" action in a wrapper for stat(). >> And bed90759f brought in master the _pgstat64() function, where such >> error handling should be placed. >> So please look at the patch (based on the previous one made to fix >> bug#16161), that makes the attached test pass. > Your patch introduces a "loops", but doesn't use it to escape the loop. Indeed, this is my mistake. Please look at the corrected patch (now that code corresponds to the pgwin32_open() as intended). And it rises another question, what if pg_ls_dir_files() is called for a directory where hundreds or thousands of files are really inaccessible due to restrictions? I mean that using CreateFile() in the modified stat() implementation can be rather expensive for an arbitrary file (and worse yet, for many files). On the positive side, for now pg_ls_dir_files() is called only from pg_ls_logdir, pg_ls_waldir, pg_ls_tmpdir, pg_ls_archive_statusdir, where having a bunch of files that are inaccessible for the postgres user is not expected anyway. But probably getting directory contents with correct file sizes (>4GB) in pg_ls_dir_files() can be implemented without calling CreateFile()/stat() at all (as ProcMon shows, the "dir" command doesn't call CreateFile() (or any other system function) for each file in the target directory). Best regards, Alexander
Attachment
15.11.2020 08:00, Alexander Lakhin wrote: > And it rises another question, what if pg_ls_dir_files() is called for a > directory where hundreds or thousands of files are really inaccessible > due to restrictions? > I mean that using CreateFile() in the modified stat() implementation can > be rather expensive for an arbitrary file (and worse yet, for many files). > On the positive side, for now pg_ls_dir_files() is called only from > pg_ls_logdir, pg_ls_waldir, pg_ls_tmpdir, pg_ls_archive_statusdir, where > having a bunch of files that are inaccessible for the postgres user is > not expected anyway. I've missed the fact that pg_ls_dir_files() just fails on first error, so the existing coding would not cause performance issues. But such behavior is somewhat dubious, because having an inaccessible file in a directory of interest would make any of those calls fail > But probably getting directory contents with correct file sizes (>4GB) > in pg_ls_dir_files() can be implemented without calling > CreateFile()/stat() at all (as ProcMon shows, the "dir" command doesn't > call CreateFile() (or any other system function) for each file in the > target directory). As I've found out, readdir() replacement for Windows in fact gets all the needed information (correct file size, attributes...) in WIN32_FIND_DATA, but it just leaves it inside and returns only fields of the dirent structure. So pg_ls_dir_files() (that calls ReadDir()/readdir()) needs to get this information again, that leads to opening a file on Windows. I think it can be done more effectively by adding a new function ReadDirExtendedInfo(), that will additionally accept a pointer to "struct dirent_extra" with fields {valid (indicating that the structure is filled), attributes, file size, mtime}. Maybe the advanced function could also invoke stat() inside (not on Windows). As to patch I proposed before, I think it's still needed to fully support the following usage pattern: stat(); if (no_error) { do_something(); } else if (file_not_found) { do_something_else(); } else { error(); } Best regards, Alexander
On Sun, Nov 15, 2020 at 4:00 PM Alexander Lakhin <exclusion@gmail.com> wrote:
As I've found out, readdir() replacement for Windows in fact gets all
the needed information (correct file size, attributes...) in
WIN32_FIND_DATA, but it just leaves it inside and returns only fields of
the dirent structure. So pg_ls_dir_files() (that calls
ReadDir()/readdir()) needs to get this information again, that leads to
opening a file on Windows.
I think it can be done more effectively by adding a new function
ReadDirExtendedInfo(), that will additionally accept a pointer to
"struct dirent_extra" with fields {valid (indicating that the structure
is filled), attributes, file size, mtime}. Maybe the advanced function
could also invoke stat() inside (not on Windows).
As to patch I proposed before, I think it's still needed to fully
support the following usage pattern:
stat();
if (no_error) {
do_something();
} else if (file_not_found) {
do_something_else();
} else {
error();
}
We are currently missing a WIN32 lstat() port. I was thinking about proposing a patch to implement it using GetFileAttributesEx(). That might work as fall back to the CreateFile() if the file attribute is not a FILE_ATTRIBUTE_REPARSE_POINT.
Anyhow, I do not think any retry logic should be in the stat() function, but in the caller.
Regards,
Juan José Santamaría Flecha
Alexander Lakhin <exclusion@gmail.com> writes: > 15.11.2020 04:11, Justin Pryzby wrote: >> Your patch introduces a "loops", but doesn't use it to escape the loop. > Indeed, this is my mistake. Please look at the corrected patch (now that > code corresponds to the pgwin32_open() as intended). So what you're saying (and what the buildfarm seems to confirm, since we are still seeing "Permission denied" failures from time to time, eg [1]) is that all that code that bed90759f added to deal with delete-pending is just junk, because we never get that far if the file is delete-pending. So shouldn't we remove all of it? (That's lines 214-276 in win32stat.c, plus some earlier declarations that would now be unneeded.) I'd be kind of inclined to change pgwin32_open() to use microsoft_native_stat, as well, because these two functions really ought to be handling this exactly alike. regards, tom lane [1] https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=fairywren&dt=2020-11-18%2018%3A02%3A04
BTW ... scraping the buildfarm logs for "could not open ... Permission denied" failures suggests that pgwin32_open() isn't the pinnacle of perfection either. In the last three months I found these instances: dory | REL_11_STABLE | 2020-08-21 22:15:14 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/REL_11_STABLE/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r fairywren | REL_11_STABLE | 2020-09-01 01:04:55 | Check | pg_ctl: could not open PID file "C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permissiondenied\r dory | HEAD | 2020-09-16 02:40:17 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r walleye | HEAD | 2020-09-29 18:35:46 | pg_upgradeCheck | 2020-09-29 15:20:04.298 EDT [896:31] pg_regress/gistWARNING: could not open statistics file "pg_stat_tmp/global.stat": Permission denied frogmouth | REL_10_STABLE | 2020-10-01 00:30:15 | StopDb-C:5 | waiting for server to shut down....pg_ctl: couldnot open PID file "data-C/postmaster.pid": Permission denied\r dory | REL_11_STABLE | 2020-10-05 02:15:06 | pg_upgradeCheck | waiting for server to shut down..............pg_ctl:could not open PID file "C:/pgbuildfarm/pgbuildroot/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid":Permission denied\r bowerbird | REL_10_STABLE | 2020-10-21 23:19:22 | scriptsCheck | waiting for server to shut down....pg_ctl: couldnot open PID file "H:/prog/bf/root/REL_10_STABLE/pgsql.build/src/bin/scripts/tmp_check/data_main_cH68/pgdata/postmaster.pid":Permission denied\r jacana | REL_10_STABLE | 2020-10-22 12:42:51 | pg_upgradeCheck | Oct 22 09:08:20 waiting for server to shut down....pg_ctl:could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_10_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid": Permissiondenied\r dory | HEAD | 2020-10-22 23:30:16 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r dory | REL_11_STABLE | 2020-10-27 18:15:08 | StopDb-C:2 | waiting for server to shut down....pg_ctl: couldnot open PID file "data-C/postmaster.pid": Permission denied\r fairywren | REL_11_STABLE | 2020-10-28 04:01:17 | recoveryCheck | waiting for server to shut down....pg_ctl: couldnot open PID file "C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/recovery/tmp_check/t_004_timeline_switch_standby_2_data/pgdata/postmaster.pid": Permissiondenied\r hamerkop | REL_11_STABLE | 2020-11-01 11:31:54 | pg_upgradeCheck | waiting for server to shut down....pg_ctl: couldnot open PID file "c:/build-farm-local/buildroot/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data/postmaster.pid":Permission denied\r dory | HEAD | 2020-11-04 05:50:17 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r walleye | HEAD | 2020-11-09 09:45:41 | Check | 2020-11-09 05:06:19.672 EST [4408:31] pg_regress/gistWARNING: could not open statistics file "pg_stat_tmp/global.stat": Permission denied dory | HEAD | 2020-11-10 23:35:18 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r Now, the ones on the 10 and 11 branches are all from pg_ctl, which does not use pgwin32_open() in those branches, only native open(). So those aren't fair to count against it. But we have nearly as many similar failures in HEAD, which surely is going through pgwin32_open(). So either we don't really have adequate protection against delete-pending files, or there is some other effect we haven't explained yet. A simple theory about that is that the 1-second wait is not always enough on heavily loaded buildfarm machines. Is it sensible to increase the timeout? regards, tom lane
Hello Tom, 18.11.2020 23:39, Tom Lane wrote: > BTW ... scraping the buildfarm logs for "could not open ... Permission > denied" failures suggests that pgwin32_open() isn't the pinnacle of > perfection either. In the last three months I found these instances: > > dory | REL_11_STABLE | 2020-08-21 22:15:14 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/REL_11_STABLE/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r > fairywren | REL_11_STABLE | 2020-09-01 01:04:55 | Check | pg_ctl: could not open PID file "C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permissiondenied\r > dory | HEAD | 2020-09-16 02:40:17 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r > walleye | HEAD | 2020-09-29 18:35:46 | pg_upgradeCheck | 2020-09-29 15:20:04.298 EDT [896:31] pg_regress/gistWARNING: could not open statistics file "pg_stat_tmp/global.stat": Permission denied > frogmouth | REL_10_STABLE | 2020-10-01 00:30:15 | StopDb-C:5 | waiting for server to shut down....pg_ctl: couldnot open PID file "data-C/postmaster.pid": Permission denied\r > dory | REL_11_STABLE | 2020-10-05 02:15:06 | pg_upgradeCheck | waiting for server to shut down..............pg_ctl:could not open PID file "C:/pgbuildfarm/pgbuildroot/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid":Permission denied\r > bowerbird | REL_10_STABLE | 2020-10-21 23:19:22 | scriptsCheck | waiting for server to shut down....pg_ctl: couldnot open PID file "H:/prog/bf/root/REL_10_STABLE/pgsql.build/src/bin/scripts/tmp_check/data_main_cH68/pgdata/postmaster.pid":Permission denied\r > jacana | REL_10_STABLE | 2020-10-22 12:42:51 | pg_upgradeCheck | Oct 22 09:08:20 waiting for server to shut down....pg_ctl:could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_10_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid": Permissiondenied\r > dory | HEAD | 2020-10-22 23:30:16 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r > dory | REL_11_STABLE | 2020-10-27 18:15:08 | StopDb-C:2 | waiting for server to shut down....pg_ctl: couldnot open PID file "data-C/postmaster.pid": Permission denied\r > fairywren | REL_11_STABLE | 2020-10-28 04:01:17 | recoveryCheck | waiting for server to shut down....pg_ctl: couldnot open PID file "C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/recovery/tmp_check/t_004_timeline_switch_standby_2_data/pgdata/postmaster.pid": Permissiondenied\r > hamerkop | REL_11_STABLE | 2020-11-01 11:31:54 | pg_upgradeCheck | waiting for server to shut down....pg_ctl: couldnot open PID file "c:/build-farm-local/buildroot/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data/postmaster.pid":Permission denied\r > dory | HEAD | 2020-11-04 05:50:17 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r > walleye | HEAD | 2020-11-09 09:45:41 | Check | 2020-11-09 05:06:19.672 EST [4408:31] pg_regress/gistWARNING: could not open statistics file "pg_stat_tmp/global.stat": Permission denied > dory | HEAD | 2020-11-10 23:35:18 | Check | pg_ctl: could not open PID file "C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid":Permission denied\r > > Now, the ones on the 10 and 11 branches are all from pg_ctl, which > does not use pgwin32_open() in those branches, only native open(). > So those aren't fair to count against it. But we have nearly as > many similar failures in HEAD, which surely is going through > pgwin32_open(). So either we don't really have adequate protection > against delete-pending files, or there is some other effect we haven't > explained yet. Can you confirm that there are no such failures on REL_12_STABLE and REL_13_STABLE for last three (or maybe six) months? Maybe something changed in HEAD then? > A simple theory about that is that the 1-second wait is not always > enough on heavily loaded buildfarm machines. Is it sensible to > increase the timeout? I'm going to explore the issue this weekend, and probably comparing duration of the tests before failures can say something about load of the machines... It's very doubtful that that state could last for so 1 second... Best regards, Alexander
Alexander Lakhin <exclusion@gmail.com> writes: > 18.11.2020 23:39, Tom Lane wrote: >> Now, the ones on the 10 and 11 branches are all from pg_ctl, which >> does not use pgwin32_open() in those branches, only native open(). >> So those aren't fair to count against it. But we have nearly as >> many similar failures in HEAD, which surely is going through >> pgwin32_open(). So either we don't really have adequate protection >> against delete-pending files, or there is some other effect we haven't >> explained yet. > Can you confirm that there are no such failures on REL_12_STABLE and > REL_13_STABLE for last three (or maybe six) months? Maybe something > changed in HEAD then? Hmm, that is an interesting question isn't it. Here's a search going back a full year. There are a few in v12 --- interestingly, all on the statistics file, none from pg_ctl --- and none in v13. Of course, v13 has only existed as a separate branch since 2020-06-07. There's also a buildfarm test-coverage artifact involved. The bulk of the HEAD reports are from dory and walleye, neither of which are building v13 as yet, because of unclear problems [1]. I think those two animals build much more frequently than our other Windows animals, too, so the fact that they have more may be just because of that and not because they're somehow more susceptible. Because of that, I'm not sure that we have enough evidence to say that v13 is better than HEAD. If there is some new bug, it's post-v12, but maybe not post-v13. But v12 is evidently not perfect either. regards, tom lane [1] https://www.postgresql.org/message-id/flat/CA%2BBEBhvHhM-Bn628pf-LsjqRh3Ang7qCSBG0Ga%2B7KwhGqrNUPw%40mail.gmail.com dory | HEAD | 2019-11-20 19:40:33 | Check | pg_ctl: could not open PID file"c:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r dory | HEAD | 2019-11-21 01:25:40 | Check | pg_ctl: could not open PID file"c:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r fairywren | REL_11_STABLE | 2019-11-24 01:34:33 | recoveryCheck | waiting for server to shut down....pg_ctl:could not open PID file "C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/recovery/tmp_check/t_007_sync_rep_standby2_data/pgdata/postmaster.pid": Permissiondenied\r fairywren | REL_11_STABLE | 2019-12-04 13:14:03 | StopDb-C:4 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r fairywren | REL_11_STABLE | 2019-12-06 15:03:10 | recoveryCheck | waiting for server to shut down....pg_ctl:could not open PID file "C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/recovery/tmp_check/t_003_recovery_targets_standby_9_data/pgdata/postmaster.pid": Permissiondenied\r dory | HEAD | 2019-12-09 03:50:32 | pg_upgradeCheck | waiting for server to shut down..............pg_ctl:could not open PID file "c:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid":Permission denied\r dory | HEAD | 2019-12-11 07:45:33 | Check | pg_ctl: could not open PID file"c:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r woodlouse | HEAD | 2019-12-14 07:42:41 | StopDb-C:1 | waiting for server to shut down......pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r lorikeet | REL_12_STABLE | 2019-12-27 11:50:56 | Check | 2019-12-27 06:57:31.645 EST [5e05f1a9.5904:277]pg_regress/vacuum WARNING: could not open statistics file "/cygdrive/w/lorikeet/REL_12_STABLE/global.stat":Permission denied bowerbird | REL_11_STABLE | 2019-12-27 22:23:56 | StopDb-C:1 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r drongo | REL_11_STABLE | 2019-12-28 08:30:21 | pg_upgradeCheck | waiting for server to shut down....pg_ctl:could not open PID file "C:/prog/bf/root/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data/postmaster.pid":Permission denied\r hamerkop | REL_11_STABLE | 2020-01-22 11:49:18 | StopDb-C:3 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r jacana | REL_11_STABLE | 2020-02-10 04:59:45 | module-test_pg_dumpCheck | Feb 10 01:01:11 pg_ctl: couldnot open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/modules/test_pg_dump/./tmp_check/data/postmaster.pid": Permissiondenied\r fairywren | REL_11_STABLE | 2020-02-10 12:59:57 | StopDb-C:2 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r fairywren | REL_11_STABLE | 2020-02-19 09:59:59 | Check | pg_ctl: could not open PID file"C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permissiondenied\r hamerkop | REL_11_STABLE | 2020-03-10 11:52:00 | StopDb-C:3 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r dory | HEAD | 2020-03-13 13:30:34 | Check | pg_ctl: could not open PID file"c:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r whelk | REL_11_STABLE | 2020-03-13 14:41:30 | pg_upgradeCheck | waiting for server to shut down....pg_ctl:could not open PID file "C:/buildfarm/buildenv/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data/postmaster.pid":Permission denied\r currawong | REL_10_STABLE | 2020-03-17 04:30:09 | StopDb-C:4 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r jacana | REL_10_STABLE | 2020-03-18 15:58:46 | recoveryCheck | waiting for server to shut down....pg_ctl:could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_10_STABLE/pgsql.build/src/test/recovery/tmp_check/data_standby_1_xeWT/pgdata/postmaster.pid": Permissiondenied\r lorikeet | HEAD | 2020-03-20 00:20:47 | Check | 2020-03-19 20:46:11.115 EDT [5e741250.3320:287]pg_regress/create_index WARNING: could not open statistics file "/cygdrive/w/lorikeet/HEAD/global.stat":Permission denied jacana | REL_11_STABLE | 2020-03-21 04:14:53 | recoveryCheck | waiting for server to shut down....pg_ctl:could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/recovery/tmp_check/t_004_timeline_switch_standby_1_data/pgdata/postmaster.pid": Permissiondenied\r currawong | REL_10_STABLE | 2020-03-26 16:30:09 | StopDb-C:5 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r jacana | REL_10_STABLE | 2020-04-06 18:56:17 | recoveryCheck | waiting for server to shut down....pg_ctl:could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_10_STABLE/pgsql.build/src/test/recovery/tmp_check/data_master_yKQT/pgdata/postmaster.pid": Permissiondenied\r bowerbird | REL_11_STABLE | 2020-04-08 12:04:10 | StopDb-C:2 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r hamerkop | REL_10_STABLE | 2020-04-20 12:16:39 | StopDb-C:1 | waiting for server to shut down.....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r jacana | REL_11_STABLE | 2020-05-08 12:01:21 | pgbenchCheck | waiting for server to shut down....pg_ctl:could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/bin/pgbench/tmp_check/t_001_pgbench_with_server_main_data/pgdata/postmaster.pid": Permissiondenied\r whelk | REL_11_STABLE | 2020-05-18 05:41:33 | pg_upgradeCheck | waiting for server to shut down....pg_ctl:could not open PID file "C:/buildfarm/buildenv/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid":Permission denied\r jacana | REL_11_STABLE | 2020-05-18 13:01:01 | pg_dumpCheck | waiting for server to shut down....pg_ctl:could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/bin/pg_dump/tmp_check/t_002_pg_dump_main_data/pgdata/postmaster.pid": Permissiondenied\r whelk | REL_11_STABLE | 2020-06-01 07:41:32 | pg_upgradeCheck | waiting for server to shut down....pg_ctl:could not open PID file "C:/buildfarm/buildenv/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data/postmaster.pid":Permission denied\r lorikeet | REL_12_STABLE | 2020-06-04 03:51:45 | Check | 2020-06-03 23:57:52.099 EDT [5ed8713f.40c:280]pg_regress/vacuum WARNING: could not open statistics file "/cygdrive/w/lorikeet/REL_12_STABLE/global.stat":Permission denied lorikeet | HEAD | 2020-06-10 09:53:57 | Check | 2020-06-10 06:02:01.254 EDT [5ee0af98.3bd0:78]pg_regress/vacuum WARNING: could not open statistics file "/cygdrive/w/lorikeet/HEAD/global.stat": Permissiondenied dory | REL_10_STABLE | 2020-06-12 01:30:03 | StopDb-C:2 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r hamerkop | REL_10_STABLE | 2020-06-12 12:11:19 | pg_upgradeCheck | waiting for server to shut down....pg_ctl:could not open PID file "c:/build-farm-local/buildroot/REL_10_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data/postmaster.pid":Permission denied\r hamerkop | REL_10_STABLE | 2020-06-16 12:07:27 | StopDb-C:3 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r dory | REL_11_STABLE | 2020-07-16 10:15:06 | StopDb-C:1 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r dory | HEAD | 2020-07-25 20:35:06 | StopDb-C:1 | waiting for server to shut down.....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r bowerbird | REL_10_STABLE | 2020-08-11 11:27:11 | recoveryCheck | waiting for server to shut down....pg_ctl:could not open PID file "H:/prog/bf/root/REL_10_STABLE/pgsql.build/src/test/recovery/tmp_check/data_paris_2TSi/pgdata/postmaster.pid": Permissiondenied\r lorikeet | REL_12_STABLE | 2020-08-17 08:28:25 | InstallCheck-C | 2020-08-17 04:38:51.519 EDT [5f3a4218.1e74:643]pg_regress/create_index WARNING: could not open statistics file "/cygdrive/w/lorikeet/REL_12_STABLE/global.stat":Permission denied jacana | REL_10_STABLE | 2020-08-18 00:44:51 | pg_upgradeCheck | Aug 17 21:13:05 waiting for serverto shut down....pg_ctl: could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_10_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid": Permissiondenied\r dory | REL_11_STABLE | 2020-08-21 22:15:14 | Check | pg_ctl: could not open PID file"C:/pgbuildfarm/pgbuildroot/REL_11_STABLE/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r fairywren | REL_11_STABLE | 2020-09-01 01:04:55 | Check | pg_ctl: could not open PID file"C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permissiondenied\r dory | HEAD | 2020-09-16 02:40:17 | Check | pg_ctl: could not open PID file"C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r walleye | HEAD | 2020-09-29 18:35:46 | pg_upgradeCheck | 2020-09-29 15:20:04.298 EDT [896:31]pg_regress/gist WARNING: could not open statistics file "pg_stat_tmp/global.stat": Permission denied frogmouth | REL_10_STABLE | 2020-10-01 00:30:15 | StopDb-C:5 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r dory | REL_11_STABLE | 2020-10-05 02:15:06 | pg_upgradeCheck | waiting for server to shut down..............pg_ctl:could not open PID file "C:/pgbuildfarm/pgbuildroot/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid":Permission denied\r bowerbird | REL_10_STABLE | 2020-10-21 23:19:22 | scriptsCheck | waiting for server to shut down....pg_ctl:could not open PID file "H:/prog/bf/root/REL_10_STABLE/pgsql.build/src/bin/scripts/tmp_check/data_main_cH68/pgdata/postmaster.pid":Permission denied\r jacana | REL_10_STABLE | 2020-10-22 12:42:51 | pg_upgradeCheck | Oct 22 09:08:20 waiting for serverto shut down....pg_ctl: could not open PID file "c:/mingw/msys/1.0/home/pgrunner/bf/root/REL_10_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data.old/postmaster.pid": Permissiondenied\r dory | HEAD | 2020-10-22 23:30:16 | Check | pg_ctl: could not open PID file"C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r dory | REL_11_STABLE | 2020-10-27 18:15:08 | StopDb-C:2 | waiting for server to shut down....pg_ctl:could not open PID file "data-C/postmaster.pid": Permission denied\r fairywren | REL_11_STABLE | 2020-10-28 04:01:17 | recoveryCheck | waiting for server to shut down....pg_ctl:could not open PID file "C:/tools/msys64/home/pgrunner/bf/root/REL_11_STABLE/pgsql.build/src/test/recovery/tmp_check/t_004_timeline_switch_standby_2_data/pgdata/postmaster.pid": Permissiondenied\r hamerkop | REL_11_STABLE | 2020-11-01 11:31:54 | pg_upgradeCheck | waiting for server to shut down....pg_ctl:could not open PID file "c:/build-farm-local/buildroot/REL_11_STABLE/pgsql.build/src/bin/pg_upgrade/tmp_check/data/postmaster.pid":Permission denied\r dory | HEAD | 2020-11-04 05:50:17 | Check | pg_ctl: could not open PID file"C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r walleye | HEAD | 2020-11-09 09:45:41 | Check | 2020-11-09 05:06:19.672 EST [4408:31]pg_regress/gist WARNING: could not open statistics file "pg_stat_tmp/global.stat": Permission denied dory | HEAD | 2020-11-10 23:35:18 | Check | pg_ctl: could not open PID file"C:/pgbuildfarm/pgbuildroot/HEAD/pgsql.build/src/test/regress/./tmp_check/data/postmaster.pid": Permission denied\r
19.11.2020 01:28, Tom Lane wrote: > Alexander Lakhin <exclusion@gmail.com> writes: >> 18.11.2020 23:39, Tom Lane wrote: >>> Now, the ones on the 10 and 11 branches are all from pg_ctl, which >>> does not use pgwin32_open() in those branches, only native open(). >>> So those aren't fair to count against it. But we have nearly as >>> many similar failures in HEAD, which surely is going through >>> pgwin32_open(). So either we don't really have adequate protection >>> against delete-pending files, or there is some other effect we haven't >>> explained yet. >> Can you confirm that there are no such failures on REL_12_STABLE and >> REL_13_STABLE for last three (or maybe six) months? Maybe something >> changed in HEAD then? > Hmm, that is an interesting question isn't it. Here's a search going > back a full year. There are a few in v12 --- interestingly, all on > the statistics file, none from pg_ctl --- and none in v13. Of course, > v13 has only existed as a separate branch since 2020-06-07. > > There's also a buildfarm test-coverage artifact involved. The bulk > of the HEAD reports are from dory and walleye, neither of which are > building v13 as yet, because of unclear problems [1]. I think those > two animals build much more frequently than our other Windows animals, > too, so the fact that they have more may be just because of that and > not because they're somehow more susceptible. Because of that, I'm not > sure that we have enough evidence to say that v13 is better than HEAD. > If there is some new bug, it's post-v12, but maybe not post-v13. But > v12 is evidently not perfect either. Thanks for the complete list! As I can see from it, only lorikeet fails on REL_12_STABLE. And it has a simple explanation. lorikeet uses cygwin, not win32, but improved open() and fopen() functions are not defined on cygwin: #if defined(WIN32) && !defined(__CYGWIN__) /* * open() and fopen() replacements to allow deletion of open files and * passing of other special options. */ #define O_DIRECT 0x80000000 extern int pgwin32_open(const char *, int,...); extern FILE *pgwin32_fopen(const char *, const char *); #define open(a,b,c) pgwin32_open(a,b,c) #define fopen(a,b) pgwin32_fopen(a,b) ... And aside from the "Permission denied" failures (not necessarily related to the "delete pending" state), we can see the "Device or resource busy" failures on the same global.stat file (e. g., [1], [2], [3]). All these failures occur when VACUUM (or REINDEX [3]) tries to access statistics simultaneously with the statistics collector. I've tried to make open()/fopen() replacements for cygwin, but haven't succeeded yet (I need more time to find out how to get original GetLastError() [4], as knowing errno is not sufficient to implement pgwin32_open()' logic). (And I'm inclined to file a separate bug related to this cygwin behavior when I'll get more info.) The failures on HEAD (on dory and walleye) need another investigation (maybe they are caused by modified stat()...). [1] https://buildfarm.postgresql.org/cgi-bin/show_stage_log.pl?nm=lorikeet&dt=2020-09-07%2020%3A31%3A16&stg=install-check-C [2] https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=lorikeet&dt=2019-10-27%2009%3A36%3A07 [3] https://buildfarm.postgresql.org/cgi-bin/show_stage_log.pl?nm=lorikeet&dt=2020-09-02%2008%3A28%3A53&stg=install-check-C [4] https://github.com/openunix/cygwin/blob/master/winsup/cygwin/errno.cc Best regards, Alexander
On Sun, Mar 14, 2021 at 06:00:00PM +0300, Alexander Lakhin wrote: > I believe that the patch attached to [1] should fix this issue. The > patch still applies to master and makes the demotest (attached to [2]) > pass. Also I've prepared a trivial patch that makes pgwin32_open() use > the original stat() function (as in the proposed change for _pgstat64()). Hmm. Knowing that _pgfstat64() has some special handling related to files pending for deletion, do we really need that on HEAD? > - struct stat st; > + struct microsoft_native_stat st; > > - if (stat(fileName, &st) != 0) > + if (microsoft_native_stat(fileName, &st) != 0) > { > pg_usleep(100000); > loops++; This change looks like a good idea for the WIN32 emulation of open(), taken independently. -- Michael
Attachment
Hello Michael, 06.07.2021 11:33, Michael Paquier wrote: > On Sun, Mar 14, 2021 at 06:00:00PM +0300, Alexander Lakhin wrote: >> I believe that the patch attached to [1] should fix this issue. The >> patch still applies to master and makes the demotest (attached to [2]) >> pass. Also I've prepared a trivial patch that makes pgwin32_open() use >> the original stat() function (as in the proposed change for _pgstat64()). > Hmm. Knowing that _pgfstat64() has some special handling related to > files pending for deletion, do we really need that on HEAD? Yes, this fix is needed for HEAD (b9734c13) as the simple test attached to [1] shows: (You can put that script in src\test\modules\test_misc\t and perform `vcregress taptest src\test\modules\test_misc`.) t/001_delete_pending.pl ......... # Looks like your test exited with 2 before it could output anything. and src\test\modules\test_misc\tmp_check\log\regress_log_001_delete_pending contains: # Postmaster PID for node "node" is 1616 error running SQL: 'psql:<stdin>:1: ERROR: could not stat file "pg_wal/dummy": Permission denied' while running 'psql -XAtq -d port=64889 host=127.0.0.1 dbname='postgres' -f - -v ON_ERROR_STOP=1' with sql 'select count(*) > 0 as ok from pg_ls_waldir();' at C:/src/postgresql/src/test/perl/PostgresNode.pm line 1771. As Tom Lane noted above, the code added with bed90759f is dubious (_NtQueryInformationFile() can not be used to handle the "delete pending" state as CreateFile() returns INVALID_HANDLE_VALUE in this case.) Probably that change should be reverted. Should I do it along with the proposed fix? [1] https://www.postgresql.org/message-id/c3427edf-d7c0-ff57-90f6-b5de3bb62709%40gmail.com Best regards, Alexander
On Thu, Jul 08, 2021 at 07:00:01AM +0300, Alexander Lakhin wrote: > As Tom Lane noted above, the code added with bed90759f is dubious > (_NtQueryInformationFile() can not be used to handle the "delete > pending" state as CreateFile() returns INVALID_HANDLE_VALUE in this case.) > Probably that change should be reverted. Should I do it along with the > proposed fix? Ah, I see. I have managed to miss your point. If _NtQueryInformationFile() cannot be used, then we'd actually miss the contents for standardInfo and the pending deletion. If you could send everything you have, that would be helpful! I'd like to test that stuff by myself, with all the contents discussed at disposal for a proper evaluation. -- Michael
Attachment
08.07.2021 10:47, Michael Paquier wrote: > On Thu, Jul 08, 2021 at 07:00:01AM +0300, Alexander Lakhin wrote: >> As Tom Lane noted above, the code added with bed90759f is dubious >> (_NtQueryInformationFile() can not be used to handle the "delete >> pending" state as CreateFile() returns INVALID_HANDLE_VALUE in this case.) >> Probably that change should be reverted. Should I do it along with the >> proposed fix? > Ah, I see. I have managed to miss your point. If > _NtQueryInformationFile() cannot be used, then we'd actually miss the > contents for standardInfo and the pending deletion. If you could send > everything you have, that would be helpful! I'd like to test that > stuff by myself, with all the contents discussed at disposal for a > proper evaluation. > -- Beside the aforementioned test I can only propose the extended patch, that incorporates the undo of the changes brought by bed90759f. With this patch that test is passed. Best regards, Alexander
Attachment
On Thu, Jul 08, 2021 at 11:00:00PM +0300, Alexander Lakhin wrote: > Beside the aforementioned test I can only propose the extended patch, > that incorporates the undo of the changes brought by bed90759f. > With this patch that test is passed. Checked and confirmed. It is a nice test with IPC::Run you have here. Making things in win32stat.c more consistent with open.c surely is appealing. One thing that I'd like to introduce in this patch, and also mentioned upthread, is to change the stat() call in open.c to use microsoft_native_stat(). I have let pgbench run for a couple of hours with some concurrent activity using genfile.c, without noticing problems. My environment is not representative of everything we can find out there on Windows, but it brings some confidence. -- Michael
Attachment
Hello Michael, 09.07.2021 08:52, Michael Paquier wrote: > On Thu, Jul 08, 2021 at 11:00:00PM +0300, Alexander Lakhin wrote: >> Beside the aforementioned test I can only propose the extended patch, >> that incorporates the undo of the changes brought by bed90759f. >> With this patch that test is passed. > Checked and confirmed. It is a nice test with IPC::Run you have here. > Making things in win32stat.c more consistent with open.c surely is > appealing. One thing that I'd like to introduce in this patch, and > also mentioned upthread, is to change the stat() call in open.c to use > microsoft_native_stat(). > > I have let pgbench run for a couple of hours with some concurrent > activity using genfile.c, without noticing problems. My environment > is not representative of everything we can find out there on Windows, > but it brings some confidence. Thank you! I agree with your improvement. I can't remember why did I inject 'include "port.h"' in genfile.c. Today I've rechecked all the chain of includes and I see that stat() is redefined as _pgstat64() in win32_port.h, that includes <sys/stat.h>. genfile.c includes "postgres.h" (that includes win32_port.h indirectly) and then includes <sys/stat.h> again, but the later include should be ignored due "#pragma once" in stat.h. So I have no objection to the removal of that include. Best regards, Alexander
On Fri, Jul 09, 2021 at 09:00:00PM +0300, Alexander Lakhin wrote: > Thank you! I agree with your improvement. I can't remember why did I > inject 'include "port.h"' in genfile.c. > Today I've rechecked all the chain of includes and I see that stat() is > redefined as _pgstat64() in win32_port.h, that includes <sys/stat.h>. > genfile.c includes "postgres.h" (that includes win32_port.h indirectly) > and then includes <sys/stat.h> again, but the later include should be > ignored due "#pragma once" in stat.h. > So I have no objection to the removal of that include. Thanks, that matches my impression. There was one comment at the top of _pgstat64() that was still incorrect. I have spent more time checking and tested this stuff today, and that looks fine. One question pending is if we should increase the timeout used by WIN32's stat() and open(), but the buildfarm should be able to tell us more here. -- Michael
Attachment
On Mon, Jul 12, 2021 at 01:07:17PM +0900, Michael Paquier wrote: > Thanks, that matches my impression. There was one comment at the top > of _pgstat64() that was still incorrect. I have spent more time > checking and tested this stuff today, and that looks fine. One > question pending is if we should increase the timeout used by WIN32's > stat() and open(), but the buildfarm should be able to tell us more > here. And fairywren, that uses MinGW, is unhappy: https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=fairywren&dt=2021-07-12%2004%3A47%3A13 Looking at it now. -- Michael
Attachment
On Mon, Jul 12, 2021 at 02:09:41PM +0900, Michael Paquier wrote: > And fairywren, that uses MinGW, is unhappy: > https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=fairywren&dt=2021-07-12%2004%3A47%3A13 > Looking at it now. I am not sure what to do here to cool down MinGW, so the patch has been reverted for now: - Plain stat() is not enough to do a proper detection of the files pending for deletion on MSVC, so reverting only the part with microsoft_native_stat() is not going to help. - We are going to need an evaluation of the stat() implementation in MinGW and check if is it possible to rely on it more. If yes, we could get away with more tweaks based on __MINGW32__/__MINGW64__. -- Michael
Attachment
Hello Michael, 12.07.2021 08:52, Michael Paquier wrote: > On Mon, Jul 12, 2021 at 02:09:41PM +0900, Michael Paquier wrote: >> And fairywren, that uses MinGW, is unhappy: >> https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=fairywren&dt=2021-07-12%2004%3A47%3A13 >> Looking at it now. > I am not sure what to do here to cool down MinGW, so the patch has > been reverted for now: > - Plain stat() is not enough to do a proper detection of the files > pending for deletion on MSVC, so reverting only the part with > microsoft_native_stat() is not going to help. > - We are going to need an evaluation of the stat() implementation in > MinGW and check if is it possible to rely on it more. If yes, we > could get away with more tweaks based on __MINGW32__/__MINGW64__. I'll take care of it and will prepare mingw-compatible patch tomorrow. Best regards, Alexander
On Mon, Jul 12, 2021 at 09:06:01AM +0300, Alexander Lakhin wrote: > I'll take care of it and will prepare mingw-compatible patch tomorrow. Thanks. Do you have an environment with 32b or 64b MinGW? -- Michael
Attachment
12.07.2021 09:23, Michael Paquier wrote: > On Mon, Jul 12, 2021 at 09:06:01AM +0300, Alexander Lakhin wrote: >> I'll take care of it and will prepare mingw-compatible patch tomorrow. > Thanks. Do you have an environment with 32b or 64b MinGW? Yes, I have VMs with 32- and 64-bit mingw environments. Best regards, Alexander
Hello Michael,
12.07.2021 08:52, Michael Paquier wrote:
12.07.2021 08:52, Michael Paquier wrote:
I've managed to adapt open/win32stat for MinGW by preventing stat overriding at the implementation level. Thus, the code that calls stat() will use the overridden struct/function(s), but inside of open/win32_stat we could access original stat and reference to __pgstat64 where we want to use our.On Mon, Jul 12, 2021 at 02:09:41PM +0900, Michael Paquier wrote:And fairywren, that uses MinGW, is unhappy: https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=fairywren&dt=2021-07-12%2004%3A47%3A13 Looking at it now.I am not sure what to do here to cool down MinGW, so the patch has been reverted for now: - Plain stat() is not enough to do a proper detection of the files pending for deletion on MSVC, so reverting only the part with microsoft_native_stat() is not going to help. - We are going to need an evaluation of the stat() implementation in MinGW and check if is it possible to rely on it more. If yes, we could get away with more tweaks based on __MINGW32__/__MINGW64__.
Tested on MSVC, MinGW64 and MinGW32 — the fixed code compiles everywhere.
But when using perl from msys (not ActivePerl) while testing I've got the same test failure due to another error condition:
In this case CreateFile() fails with ERROR_SHARING_VIOLATION (not ERROR_ACCESS_DENIED) and it leads to the same "Permission denied" error. This condition is handled in the pgwin32_open() but not in _pgstat64() yet.
I think I should develop another test for MSVC environment that will demonstrate a such failure too.
But as it's not related to the DELETE_PENDING state, I wonder whether this should be fixed in a separate patch.
Best regards,
Alexander
Attachment
> On 13 Jul 2021, at 20:00, Alexander Lakhin <exclusion@gmail.com> wrote: > > Hello Michael, > 12.07.2021 08:52, Michael Paquier wrote: >> On Mon, Jul 12, 2021 at 02:09:41PM +0900, Michael Paquier wrote: >> >>> And fairywren, that uses MinGW, is unhappy: >>> >>> https://buildfarm.postgresql.org/cgi-bin/show_log.pl?nm=fairywren&dt=2021-07-12%2004%3A47%3A13 >>> >>> Looking at it now. >>> >> I am not sure what to do here to cool down MinGW, so the patch has >> been reverted for now: >> - Plain stat() is not enough to do a proper detection of the files >> pending for deletion on MSVC, so reverting only the part with >> microsoft_native_stat() is not going to help. >> - We are going to need an evaluation of the stat() implementation in >> MinGW and check if is it possible to rely on it more. If yes, we >> could get away with more tweaks based on __MINGW32__/__MINGW64__. >> > I've managed to adapt open/win32stat for MinGW by preventing stat overriding at the implementation level. Thus, the codethat calls stat() will use the overridden struct/function(s), but inside of open/win32_stat we could access originalstat and reference to __pgstat64 where we want to use our. > Tested on MSVC, MinGW64 and MinGW32 — the fixed code compiles everywhere. > > But when using perl from msys (not ActivePerl) while testing I've got the same test failure due to another error condition: > > <ghffjapimnefdgac.png> > > In this case CreateFile() fails with ERROR_SHARING_VIOLATION (not ERROR_ACCESS_DENIED) and it leads to the same "Permissiondenied" error. This condition is handled in the pgwin32_open() but not in _pgstat64() yet. > > I think I should develop another test for MSVC environment that will demonstrate a such failure too. > But as it's not related to the DELETE_PENDING state, I wonder whether this should be fixed in a separate patch. Michael, have you had a chance to look at the updated patch here? I'm moving this patch entry from Waiting on Author to Needs Review. -- Daniel Gustafsson https://vmware.com/
On Wed, Dec 01, 2021 at 11:51:58AM +0100, Daniel Gustafsson wrote: > Michael, have you had a chance to look at the updated patch here? I'm moving > this patch entry from Waiting on Author to Needs Review. No, I haven't. Before being touched more, this requires first a bit more of testing infrastructure based on MinGW, and I don't have that in place yet :/ -- Michael
Attachment
Hello Daniel and Michael, 02.12.2021 08:03, Michael Paquier wrote: > On Wed, Dec 01, 2021 at 11:51:58AM +0100, Daniel Gustafsson wrote: >> Michael, have you had a chance to look at the updated patch here? I'm moving >> this patch entry from Waiting on Author to Needs Review. > No, I haven't. Before being touched more, this requires first a bit > more of testing infrastructure based on MinGW, and I don't have that > in place yet :/ I think that my patch should be withdrawn in favor of https://commitfest.postgresql.org/34/3326/ ("Check for STATUS_DELETE_PENDING on Windows" by Thomas Munro), that use deeper understanding of the problematic status, not indirect indication of it. Barring objections, I'll withdraw my commitfest entry. Best regards, Alexander