Re: Intermittent pg_ctl failures on Windows
От | r.zharkov@postgrespro.ru |
---|---|
Тема | Re: Intermittent pg_ctl failures on Windows |
Дата | |
Msg-id | 3b46fc8be044c79b5eff7d26c810d2fd@postgrespro.ru обсуждение исходный текст |
Ответ на | Re: Intermittent pg_ctl failures on Windows (Tom Lane <tgl@sss.pgh.pa.us>) |
Ответы |
Re: Intermittent pg_ctl failures on Windows
|
Список | pgsql-hackers |
On 2019-07-17 20:51, Tom Lane wrote: > r.zharkov@postgrespro.ru writes: >> pg_ctl now opens the postmaster.pid file using pgwin32_open() function >> to correctly handle share locks. > > HEAD already does that, no? See f02259fe9. > You are right. I tested branch REL_11_STABLE and it is my mistake. >> On Windows systems we cannot handle ERROR_DELETE_PENDING because >> GetLastError() returns ERROR_ACCESS_DENIED instead. >> So we rename the lock files before delete them. > > This seems improbably broken/stupid. Also, I've not seen any buildfarm > failures that would match this; it's always pg_ctl complaining not the > postmaster. > The probability is very small. In one of our tests pg_ctl fails with that error sometime. In a test with multiple frequent restarts the probability is 5-6%. On other machines probability differs. To find out the real error code we used the Process Monitor utility. >> To avoid the second error we added the wait for cmd.exe finish in the >> do_stop() and do_restart() functions. > > Hmmm ... there seems the germ of a good idea here, but can't we do > it with less (and less ugly) code? > > Alternatively, perhaps we could fix things so that the parent cmd.exe > shell isn't involved in logfile access? That'd require teaching the > postmaster to open/redirect its stdout/stderr, which is kind of > annoying, but it might beat hacking things as you have done here. > If we need parent cmd.exe only for log writing, can we start the postmaster without it? Is cmd.exe necessary? -- regards, Roman Zharkov
В списке pgsql-hackers по дате отправления: