/* Flags set by signal handlers */
 static volatile sig_atomic_t got_SIGHUP = false;
-static volatile sig_atomic_t got_SIGTERM = false;
 
 static bool on_commit_launcher_wakeup = false;
 
    ApplyLauncherWakeup();
 }
 
-/* SIGTERM: set flag to exit at next convenient time */
-static void
-logicalrep_launcher_sigterm(SIGNAL_ARGS)
-{
-   int         save_errno = errno;
-
-   got_SIGTERM = true;
-
-   /* Waken anything waiting on the process latch */
-   SetLatch(MyLatch);
-
-   errno = save_errno;
-}
-
 /* SIGHUP: set flag to reload configuration at next convenient time */
 static void
 logicalrep_launcher_sighup(SIGNAL_ARGS)
 
    before_shmem_exit(logicalrep_launcher_onexit, (Datum) 0);
 
+   Assert(LogicalRepCtx->launcher_pid == 0);
+   LogicalRepCtx->launcher_pid = MyProcPid;
+
    /* Establish signal handlers. */
    pqsignal(SIGHUP, logicalrep_launcher_sighup);
-   pqsignal(SIGTERM, logicalrep_launcher_sigterm);
+   pqsignal(SIGTERM, die);
    BackgroundWorkerUnblockSignals();
 
-   LogicalRepCtx->launcher_pid = MyProcPid;
-
    /*
     * Establish connection to nailed catalogs (we only ever access
     * pg_subscription).
    BackgroundWorkerInitializeConnection(NULL, NULL);
 
    /* Enter main loop */
-   while (!got_SIGTERM)
+   for (;;)
    {
        int         rc;
        List       *sublist;
        TimestampTz now;
        long        wait_time = DEFAULT_NAPTIME_PER_CYCLE;
 
+       CHECK_FOR_INTERRUPTS();
+
        now = GetCurrentTimestamp();
 
        /* Limit the start retry to once a wal_retrieve_retry_interval */
        }
    }
 
-   LogicalRepCtx->launcher_pid = 0;
-
-   /* ... and if it returns, we're done */
-   ereport(DEBUG1,
-           (errmsg("logical replication launcher shutting down")));
+   /* Not reachable */
+}
 
-   proc_exit(0);
+/*
+ * Is current process the logical replication launcher?
+ */
+bool
+IsLogicalLauncher(void)
+{
+   return LogicalRepCtx->launcher_pid == MyProcPid;
 }
 
 /*
 
 #include "pg_getopt.h"
 #include "postmaster/autovacuum.h"
 #include "postmaster/postmaster.h"
+#include "replication/logicallauncher.h"
 #include "replication/logicalworker.h"
 #include "replication/slot.h"
 #include "replication/walsender.h"
            ereport(FATAL,
                    (errcode(ERRCODE_ADMIN_SHUTDOWN),
                     errmsg("terminating logical replication worker due to administrator command")));
+       else if (IsLogicalLauncher())
+       {
+           ereport(DEBUG1,
+                   (errmsg("logical replication launcher shutting down")));
+
+           /* The logical replication launcher can be stopped at any time. */
+           proc_exit(0);
+       }
        else if (RecoveryConflictPending && RecoveryConflictRetryable)
        {
            pgstat_report_recovery_conflict(RecoveryConflictReason);