2012-08-13 17:13:01 +00:00
|
|
|
Change the built-in default socket directory to be /var/run/postgresql.
|
|
|
|
For backwards compatibility with (probably non-libpq-based) clients that
|
|
|
|
might still expect to find the socket in /tmp, also create a socket in
|
|
|
|
/tmp. This is to resolve communication problems with clients operating
|
|
|
|
under systemd's PrivateTmp environment, which won't be using the same
|
|
|
|
global /tmp directory as the server; see bug #825448.
|
|
|
|
|
|
|
|
Note that we apply the socket directory change at the level of the
|
|
|
|
hard-wired defaults in the C code, not by just twiddling the setting in
|
|
|
|
postgresql.conf.sample; this is so that the change will take effect on
|
|
|
|
server package update, without requiring any existing postgresql.conf
|
|
|
|
to be updated. (Of course, a user who dislikes this behavior can still
|
|
|
|
override it via postgresql.conf.)
|
|
|
|
|
|
|
|
This patch must be applied after postgresql-multi-sockets.patch, at
|
|
|
|
least until 9.3 when that will be part of the upstream package.
|
|
|
|
|
|
|
|
|
2012-12-06 16:05:36 +00:00
|
|
|
diff -Naur postgresql-9.2.2.sockets/contrib/pg_upgrade/test.sh postgresql-9.2.2/contrib/pg_upgrade/test.sh
|
|
|
|
--- postgresql-9.2.2.sockets/contrib/pg_upgrade/test.sh 2012-12-03 15:16:10.000000000 -0500
|
|
|
|
+++ postgresql-9.2.2/contrib/pg_upgrade/test.sh 2012-12-04 14:34:04.661476094 -0500
|
|
|
|
@@ -71,10 +71,14 @@
|
2012-09-10 15:15:54 +00:00
|
|
|
rm -rf "$logdir"
|
|
|
|
mkdir "$logdir"
|
2012-08-13 17:13:01 +00:00
|
|
|
|
2012-09-10 15:15:54 +00:00
|
|
|
+# we want the Unix sockets in $temp_root
|
|
|
|
+PGHOST=$temp_root
|
|
|
|
+export PGHOST
|
|
|
|
+
|
|
|
|
set -x
|
|
|
|
|
|
|
|
$oldbindir/initdb
|
|
|
|
-$oldbindir/pg_ctl start -l "$logdir/postmaster1.log" -w
|
|
|
|
+$oldbindir/pg_ctl start -l "$logdir/postmaster1.log" -o "-c unix_socket_directories='$PGHOST'" -w
|
|
|
|
if "$MAKE" -C "$oldsrc" installcheck; then
|
|
|
|
pg_dumpall -f "$temp_root"/dump1.sql || pg_dumpall1_status=$?
|
|
|
|
if [ "$newsrc" != "$oldsrc" ]; then
|
2012-12-06 16:05:36 +00:00
|
|
|
@@ -117,7 +121,7 @@
|
2012-09-10 15:15:54 +00:00
|
|
|
|
|
|
|
pg_upgrade -d "${PGDATA}.old" -D "${PGDATA}" -b "$oldbindir" -B "$bindir"
|
|
|
|
|
|
|
|
-pg_ctl start -l "$logdir/postmaster2.log" -w
|
|
|
|
+pg_ctl start -l "$logdir/postmaster2.log" -o "-c unix_socket_directories='$PGHOST'" -w
|
|
|
|
|
2012-12-06 16:05:36 +00:00
|
|
|
case $testhost in
|
|
|
|
MINGW*) cmd /c analyze_new_cluster.bat ;;
|
|
|
|
diff -Naur postgresql-9.2.2.sockets/src/backend/utils/misc/guc.c postgresql-9.2.2/src/backend/utils/misc/guc.c
|
|
|
|
--- postgresql-9.2.2.sockets/src/backend/utils/misc/guc.c 2012-12-04 14:25:57.578967623 -0500
|
|
|
|
+++ postgresql-9.2.2/src/backend/utils/misc/guc.c 2012-12-04 14:34:04.663476214 -0500
|
2012-09-10 15:15:54 +00:00
|
|
|
@@ -2901,7 +2901,7 @@
|
2012-08-13 17:13:01 +00:00
|
|
|
},
|
|
|
|
&Unix_socket_directories,
|
|
|
|
#ifdef HAVE_UNIX_SOCKETS
|
|
|
|
- DEFAULT_PGSOCKET_DIR,
|
|
|
|
+ DEFAULT_PGSOCKET_DIR ", /tmp",
|
|
|
|
#else
|
|
|
|
"",
|
|
|
|
#endif
|
2012-12-06 16:05:36 +00:00
|
|
|
diff -Naur postgresql-9.2.2.sockets/src/bin/initdb/initdb.c postgresql-9.2.2/src/bin/initdb/initdb.c
|
|
|
|
--- postgresql-9.2.2.sockets/src/bin/initdb/initdb.c 2012-12-04 14:25:57.579967636 -0500
|
|
|
|
+++ postgresql-9.2.2/src/bin/initdb/initdb.c 2012-12-04 14:34:04.665476326 -0500
|
|
|
|
@@ -1007,7 +1007,7 @@
|
2012-08-13 17:13:01 +00:00
|
|
|
|
|
|
|
#ifdef HAVE_UNIX_SOCKETS
|
|
|
|
snprintf(repltok, sizeof(repltok), "#unix_socket_directories = '%s'",
|
|
|
|
- DEFAULT_PGSOCKET_DIR);
|
|
|
|
+ DEFAULT_PGSOCKET_DIR ", /tmp");
|
|
|
|
#else
|
|
|
|
snprintf(repltok, sizeof(repltok), "#unix_socket_directories = ''");
|
|
|
|
#endif
|
2012-12-06 16:05:36 +00:00
|
|
|
diff -Naur postgresql-9.2.2.sockets/src/include/pg_config_manual.h postgresql-9.2.2/src/include/pg_config_manual.h
|
|
|
|
--- postgresql-9.2.2.sockets/src/include/pg_config_manual.h 2012-12-03 15:16:10.000000000 -0500
|
|
|
|
+++ postgresql-9.2.2/src/include/pg_config_manual.h 2012-12-04 14:34:04.665476326 -0500
|
2012-09-10 15:15:54 +00:00
|
|
|
@@ -144,7 +144,7 @@
|
2012-08-13 17:13:01 +00:00
|
|
|
* here's where to twiddle it. You can also override this at runtime
|
|
|
|
* with the postmaster's -k switch.
|
|
|
|
*/
|
|
|
|
-#define DEFAULT_PGSOCKET_DIR "/tmp"
|
|
|
|
+#define DEFAULT_PGSOCKET_DIR "/var/run/postgresql"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The random() function is expected to yield values between 0 and
|
2012-12-06 16:05:36 +00:00
|
|
|
diff -Naur postgresql-9.2.2.sockets/src/test/regress/pg_regress.c postgresql-9.2.2/src/test/regress/pg_regress.c
|
|
|
|
--- postgresql-9.2.2.sockets/src/test/regress/pg_regress.c 2012-12-03 15:16:10.000000000 -0500
|
|
|
|
+++ postgresql-9.2.2/src/test/regress/pg_regress.c 2012-12-04 14:34:04.666476378 -0500
|
2012-09-10 15:15:54 +00:00
|
|
|
@@ -772,7 +772,7 @@
|
2012-08-13 17:13:01 +00:00
|
|
|
if (hostname != NULL)
|
|
|
|
doputenv("PGHOST", hostname);
|
|
|
|
else
|
|
|
|
- unsetenv("PGHOST");
|
|
|
|
+ doputenv("PGHOST", "/tmp");
|
|
|
|
unsetenv("PGHOSTADDR");
|
|
|
|
if (port != -1)
|
|
|
|
{
|
2012-12-06 16:05:36 +00:00
|
|
|
@@ -2246,7 +2246,7 @@
|
2012-08-13 17:13:01 +00:00
|
|
|
*/
|
|
|
|
header(_("starting postmaster"));
|
|
|
|
snprintf(buf, sizeof(buf),
|
|
|
|
- SYSTEMQUOTE "\"%s/postgres\" -D \"%s/data\" -F%s -c \"listen_addresses=%s\" > \"%s/log/postmaster.log\" 2>&1" SYSTEMQUOTE,
|
|
|
|
+ SYSTEMQUOTE "\"%s/postgres\" -D \"%s/data\" -F%s -c \"listen_addresses=%s\" -c \"unix_socket_directories=/tmp\" > \"%s/log/postmaster.log\" 2>&1" SYSTEMQUOTE,
|
|
|
|
bindir, temp_install,
|
|
|
|
debug ? " -d 5" : "",
|
|
|
|
hostname ? hostname : "",
|