Allow UNLISTEN in hot-standby mode.
authorTom Lane <[email protected]>
Sat, 26 Jan 2019 02:14:31 +0000 (21:14 -0500)
committerTom Lane <[email protected]>
Sat, 26 Jan 2019 02:14:49 +0000 (21:14 -0500)
Since LISTEN is (still) disallowed, UNLISTEN must be a no-op in a
hot-standby session, and so there's no harm in allowing it.  This
change allows client code to not worry about whether it's connected
to a primary or standby server when performing session-state-reset
type activities.  (Note that DISCARD ALL, which includes UNLISTEN,
was already allowed, making it inconsistent to reject UNLISTEN.)

Per discussion, back-patch to all supported versions.

Shay Rojansky, reviewed by Mi Tar

Discussion: https://postgr.es/m/CADT4RqCf2gA_TJtPAjnGzkC3ZiexfBZiLmA-mV66e4UyuVv8bA@mail.gmail.com

doc/src/sgml/high-availability.sgml
src/backend/tcop/utility.c
src/test/regress/expected/hs_standby_allowed.out
src/test/regress/expected/hs_standby_disallowed.out
src/test/regress/sql/hs_standby_allowed.sql
src/test/regress/sql/hs_standby_disallowed.sql

index 4882b20828a3d6967e6ae714f737f7a43eeb9ede..bbab7395a2182e9f0142f0b38005d4b9cb681b1a 100644 (file)
@@ -1767,6 +1767,11 @@ if (!triggered)
        Plugins and extensions - <command>LOAD</command>
       </para>
      </listitem>
+     <listitem>
+      <para>
+       <command>UNLISTEN</command>
+      </para>
+     </listitem>
     </itemizedlist>
    </para>
 
@@ -1856,7 +1861,7 @@ if (!triggered)
      </listitem>
      <listitem>
       <para>
-       <command>LISTEN</command>, <command>UNLISTEN</command>, <command>NOTIFY</command>
+       <command>LISTEN</command>, <command>NOTIFY</command>
       </para>
      </listitem>
     </itemizedlist>
@@ -1864,8 +1869,8 @@ if (!triggered)
 
    <para>
     In normal operation, <quote>read-only</quote> transactions are allowed to
-    use <command>LISTEN</command>, <command>UNLISTEN</command>, and
-    <command>NOTIFY</command>, so Hot Standby sessions operate under slightly tighter
+    use <command>LISTEN</command> and <command>NOTIFY</command>,
+    so Hot Standby sessions operate under slightly tighter
     restrictions than ordinary read-only sessions.  It is possible that some
     of these restrictions might be loosened in a future release.
    </para>
index 27ae6be751779e06960099de51d09f03c07eab1b..6ec795f1b4608cf73db7a469d449dd1ac22bcc68 100644 (file)
@@ -629,7 +629,7 @@ standard_ProcessUtility(PlannedStmt *pstmt,
            {
                UnlistenStmt *stmt = (UnlistenStmt *) parsetree;
 
-               PreventCommandDuringRecovery("UNLISTEN");
+               /* we allow UNLISTEN during recovery, as it's a noop */
                CheckRestrictedOperation("UNLISTEN");
                if (stmt->conditionname)
                    Async_Unlisten(stmt->conditionname);
index 526f88f2bec3bba1ba2aec99cedae2e4db035024..00b8faf9eb66e0619d70ac3badec85c446a1fc69 100644 (file)
@@ -208,6 +208,9 @@ LOCK hs1 IN ACCESS SHARE MODE;
 LOCK hs1 IN ROW SHARE MODE;
 LOCK hs1 IN ROW EXCLUSIVE MODE;
 COMMIT;
+-- UNLISTEN
+UNLISTEN a;
+UNLISTEN *;
 -- LOAD
 -- should work, easier if there is no test for that...
 -- ALLOWED COMMANDS
index bc117413ffdb375a0279269276581e22430ec904..dff0953e9a6987a45d669f26269d2088d9e74db9 100644 (file)
@@ -118,10 +118,6 @@ listen a;
 ERROR:  cannot execute LISTEN during recovery
 notify a;
 ERROR:  cannot execute NOTIFY during recovery
-unlisten a;
-ERROR:  cannot execute UNLISTEN during recovery
-unlisten *;
-ERROR:  cannot execute UNLISTEN during recovery
 -- disallowed commands
 ANALYZE hs1;
 ERROR:  cannot execute ANALYZE during recovery
index a33199dbbdf726d282c9b68346398aa8a5a0338d..6debddc5e999a3c7f6684c3bce9a9c56921b9776 100644 (file)
@@ -110,6 +110,10 @@ LOCK hs1 IN ROW SHARE MODE;
 LOCK hs1 IN ROW EXCLUSIVE MODE;
 COMMIT;
 
+-- UNLISTEN
+UNLISTEN a;
+UNLISTEN *;
+
 -- LOAD
 -- should work, easier if there is no test for that...
 
index 21bbf526b741337ad05b644d6661287d8b07932e..a470600eec88330d22e9bf5b1cf7bebdbf3e9a5c 100644 (file)
@@ -88,8 +88,6 @@ COMMIT;
 -- Listen
 listen a;
 notify a;
-unlisten a;
-unlisten *;
 
 -- disallowed commands