diff options
author | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2024-11-14 16:12:28 +0200 |
---|---|---|
committer | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2024-11-14 16:12:28 +0200 |
commit | a78af0427015449269fb7d9d8c6057cfcb740149 (patch) | |
tree | eae2ea6af8d455dd8d352d0e38f667ece481bfd5 /src/backend/tcop/postgres.c | |
parent | bb861414fea31073f27aaab75a0ceaf3638d7985 (diff) | |
download | postgresql-a78af0427015449269fb7d9d8c6057cfcb740149.tar.gz postgresql-a78af0427015449269fb7d9d8c6057cfcb740149.zip |
Assign a child slot to every postmaster child process
Previously, only backends, autovacuum workers, and background workers
had an entry in the PMChildFlags array. With this commit, all
postmaster child processes, including all the aux processes, have an
entry. Dead-end backends still don't get an entry, though, and other
processes that don't touch shared memory will never mark their
PMChildFlags entry as active.
We now maintain separate freelists for different kinds of child
processes. That ensures that there are always slots available for
autovacuum and background workers. Previously, pre-authentication
backends could prevent autovacuum or background workers from starting
up, by using up all the slots.
The code to manage the slots in the postmaster process is in a new
pmchild.c source file. Because postmaster.c is just so large.
Assigning pmsignal slot numbers is now pmchild.c's responsibility.
This replaces the PMChildInUse array in pmsignal.c.
Some of the comments in postmaster.c still talked about the "stats
process", but that was removed in commit 5891c7a8ed. Fix those while
we're at it.
Reviewed-by: Andres Freund <andres@anarazel.de>
Discussion: https://www.postgresql.org/message-id/a102f15f-eac4-4ff2-af02-f9ff209ec66f@iki.fi
Diffstat (limited to 'src/backend/tcop/postgres.c')
-rw-r--r-- | src/backend/tcop/postgres.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/src/backend/tcop/postgres.c b/src/backend/tcop/postgres.c index aac0b96bbc6..184b8301687 100644 --- a/src/backend/tcop/postgres.c +++ b/src/backend/tcop/postgres.c @@ -4189,6 +4189,12 @@ PostgresSingleUserMain(int argc, char *argv[], /* Initialize MaxBackends */ InitializeMaxBackends(); + /* + * We don't need postmaster child slots in single-user mode, but + * initialize them anyway to avoid having special handling. + */ + InitPostmasterChildSlots(); + /* Initialize size of fast-path lock cache. */ InitializeFastPathLocks(); |