pgsql: extension_control_path - Mailing list pgsql-committers

From Peter Eisentraut
Subject pgsql: extension_control_path
Date
Msg-id E1tumbY-003Dl3-2o@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
extension_control_path

The new GUC extension_control_path specifies a path to look for
extension control files.  The default value is $system, which looks in
the compiled-in location, as before.

The path search uses the same code and works in the same way as
dynamic_library_path.

Some use cases of this are: (1) testing extensions during package
builds, (2) installing extensions outside security-restricted
containers like Python.app (on macOS), (3) adding extensions to
PostgreSQL running in a Kubernetes environment using operators such as
CloudNativePG without having to rebuild the base image for each new
extension.

There is also a tweak in Makefile.global so that it is possible to
install extensions using PGXS into an different directory than the
default, using 'make install prefix=/else/where'.  This previously
only worked when specifying the subdirectories, like 'make install
datadir=/else/where/share pkglibdir=/else/where/lib', for purely
implementation reasons.  (Of course, without the path feature,
installing elsewhere was rarely useful.)

Author: Peter Eisentraut <peter@eisentraut.org>
Co-authored-by: Matheus Alcantara <matheusssilv97@gmail.com>
Reviewed-by: David E. Wheeler <david@justatheory.com>
Reviewed-by: Gabriele Bartolini <gabriele.bartolini@enterprisedb.com>
Reviewed-by: Marco Nenciarini <marco.nenciarini@enterprisedb.com>
Reviewed-by: Niccolò Fei <niccolo.fei@enterprisedb.com>
Discussion: https://www.postgresql.org/message-id/flat/E7C7BFFB-8857-48D4-A71F-88B359FADCFD@justatheory.com

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/4f7f7b0375854e2f89876473405a8f21c95012af

Modified Files
--------------
doc/src/sgml/config.sgml                           |  68 ++++
doc/src/sgml/extend.sgml                           |  19 +-
doc/src/sgml/ref/create_extension.sgml             |   6 +-
src/Makefile.global.in                             |  19 +-
src/backend/commands/extension.c                   | 403 +++++++++++++--------
src/backend/utils/fmgr/dfmgr.c                     |  77 ++--
src/backend/utils/misc/guc_tables.c                |  13 +
src/backend/utils/misc/postgresql.conf.sample      |   1 +
src/include/commands/extension.h                   |   2 +
src/include/fmgr.h                                 |   3 +
src/test/modules/test_extensions/Makefile          |   1 +
src/test/modules/test_extensions/meson.build       |   5 +
.../t/001_extension_control_path.pl                |  80 ++++
13 files changed, 512 insertions(+), 185 deletions(-)


pgsql-committers by date:

Previous
From: Michael Paquier
Date:
Subject: pgsql: psql: Allow queries terminated by semicolons while in pipeline m
Next
From: Peter Eisentraut
Date:
Subject: pgsql: Update a code comment