diff options
author | Robert Haas <rhaas@postgresql.org> | 2013-12-18 12:57:20 -0500 |
---|---|---|
committer | Robert Haas <rhaas@postgresql.org> | 2013-12-18 13:09:09 -0500 |
commit | 001a573a2011d605f2a6e10aee9996de8581d099 (patch) | |
tree | 5bec5fa0c42508d9d17ae324191f8c6d3ca7e05d /src/backend/utils/init/postinit.c | |
parent | 613c6d26bd42dd8c2dd0664315be9551475b8864 (diff) | |
download | postgresql-001a573a2011d605f2a6e10aee9996de8581d099.tar.gz postgresql-001a573a2011d605f2a6e10aee9996de8581d099.zip |
Allow on-detach callbacks for dynamic shared memory segments.
Just as backends must clean up their shared memory state (releasing
lwlocks, buffer pins, etc.) before exiting, they must also perform
any similar cleanups related to dynamic shared memory segments they
have mapped before unmapping those segments. So add a mechanism to
ensure that.
Existing on_shmem_exit hooks include both "user level" cleanup such
as transaction abort and removal of leftover temporary relations and
also "low level" cleanup that forcibly released leftover shared
memory resources. On-detach callbacks should run after the first
group but before the second group, so create a new before_shmem_exit
function for registering the early callbacks and keep on_shmem_exit
for the regular callbacks. (An earlier draft of this patch added an
additional argument to on_shmem_exit, but that had a much larger
footprint and probably a substantially higher risk of breaking third
party code for no real gain.)
Patch by me, reviewed by KaiGai Kohei and Andres Freund.
Diffstat (limited to 'src/backend/utils/init/postinit.c')
-rw-r--r-- | src/backend/utils/init/postinit.c | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/src/backend/utils/init/postinit.c b/src/backend/utils/init/postinit.c index 2c7f0f17641..5caa488e6d6 100644 --- a/src/backend/utils/init/postinit.c +++ b/src/backend/utils/init/postinit.c @@ -587,15 +587,14 @@ InitPostgres(const char *in_dbname, Oid dboid, const char *username, RelationCacheInitializePhase2(); /* - * Set up process-exit callback to do pre-shutdown cleanup. This has to - * be after we've initialized all the low-level modules like the buffer - * manager, because during shutdown this has to run before the low-level - * modules start to close down. On the other hand, we want it in place - * before we begin our first transaction --- if we fail during the - * initialization transaction, as is entirely possible, we need the - * AbortTransaction call to clean up. + * Set up process-exit callback to do pre-shutdown cleanup. This is the + * first before_shmem_exit callback we register; thus, this will be the + * last thing we do before low-level modules like the buffer manager begin + * to close down. We need to have this in place before we begin our first + * transaction --- if we fail during the initialization transaction, as is + * entirely possible, we need the AbortTransaction call to clean up. */ - on_shmem_exit(ShutdownPostgres, 0); + before_shmem_exit(ShutdownPostgres, 0); /* The autovacuum launcher is done here */ if (IsAutoVacuumLauncherProcess()) |