mirror of
https://github.com/postgres/postgres.git
synced 2025-06-29 10:41:53 +03:00
Fix elog(FATAL) before PostmasterMain() or just after fork().
Since commit 97550c0711
, these failed with
"PANIC: proc_exit() called in child process" due to uninitialized or
stale MyProcPid. That was reachable if close() failed in
ClosePostmasterPorts() or setlocale(category, "C") failed, both
unlikely. Back-patch to v13 (all supported versions).
Discussion: https://postgr.es/m/20241208034614.45.nmisch@google.com
This commit is contained in:
@ -33,6 +33,7 @@
|
|||||||
|
|
||||||
#include "bootstrap/bootstrap.h"
|
#include "bootstrap/bootstrap.h"
|
||||||
#include "common/username.h"
|
#include "common/username.h"
|
||||||
|
#include "miscadmin.h"
|
||||||
#include "port/atomics.h"
|
#include "port/atomics.h"
|
||||||
#include "postmaster/postmaster.h"
|
#include "postmaster/postmaster.h"
|
||||||
#include "storage/spin.h"
|
#include "storage/spin.h"
|
||||||
@ -95,6 +96,7 @@ main(int argc, char *argv[])
|
|||||||
* localization of messages may not work right away, and messages won't go
|
* localization of messages may not work right away, and messages won't go
|
||||||
* anywhere but stderr until GUC settings get loaded.
|
* anywhere but stderr until GUC settings get loaded.
|
||||||
*/
|
*/
|
||||||
|
MyProcPid = getpid();
|
||||||
MemoryContextInit();
|
MemoryContextInit();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "miscadmin.h"
|
||||||
#include "postmaster/fork_process.h"
|
#include "postmaster/fork_process.h"
|
||||||
|
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
@ -60,6 +61,7 @@ fork_process(void)
|
|||||||
if (result == 0)
|
if (result == 0)
|
||||||
{
|
{
|
||||||
/* fork succeeded, in child */
|
/* fork succeeded, in child */
|
||||||
|
MyProcPid = getpid();
|
||||||
#ifdef LINUX_PROFILE
|
#ifdef LINUX_PROFILE
|
||||||
setitimer(ITIMER_PROF, &prof_itimer, NULL);
|
setitimer(ITIMER_PROF, &prof_itimer, NULL);
|
||||||
#endif
|
#endif
|
||||||
|
@ -2646,7 +2646,7 @@ ClosePostmasterPorts(bool am_syslogger)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* InitProcessGlobals -- set MyProcPid, MyStartTime[stamp], random seeds
|
* InitProcessGlobals -- set MyStartTime[stamp], random seeds
|
||||||
*
|
*
|
||||||
* Called early in the postmaster and every backend.
|
* Called early in the postmaster and every backend.
|
||||||
*/
|
*/
|
||||||
@ -2655,7 +2655,6 @@ InitProcessGlobals(void)
|
|||||||
{
|
{
|
||||||
unsigned int rseed;
|
unsigned int rseed;
|
||||||
|
|
||||||
MyProcPid = getpid();
|
|
||||||
MyStartTimestamp = GetCurrentTimestamp();
|
MyStartTimestamp = GetCurrentTimestamp();
|
||||||
MyStartTime = timestamptz_to_time_t(MyStartTimestamp);
|
MyStartTime = timestamptz_to_time_t(MyStartTimestamp);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user