</listitem>
      </varlistentry>
 
+     <varlistentry id="guc-cluster-name" xreflabel="cluster_name">
+      <term><varname>cluster_name</varname> (<type>string</type>)</term>
+      <indexterm>
+       <primary><varname>cluster_name</> configuration parameter</primary>
+      </indexterm>
+      <listitem>
+       <para>
+        Sets the cluster name that appears in the process title for all
+        processes in this cluster. The name can be any string of less than
+        <symbol>NAMEDATALEN</> characters (64 characters in a standard
+        build). Only printable ASCII characters may be used in the
+        <varname>application_name</varname> value. Other characters will be
+        replaced with question marks (<literal>?</literal>).  No name is shown
+        if this parameter is set to the empty string <literal>''</> (which is
+        the default). This parameter can only be set at server start.
+       </para>
+       <para>
+        The process title is typically viewed using programs like
+        <application>ps</> or, on Windows, <application>Process Explorer</>.
+       </para>
+      </listitem>
+     </varlistentry>
+
      <varlistentry>
       <term><varname>debug_print_parse</varname> (<type>boolean</type>)
       <indexterm>
 
   system view to determine who is blocking whom.)
   </para>
 
+  <para>
+   If <xref linkend="guc-cluster-name"> has been configured the
+   cluster name will also be show in <command>ps</> output:
+<screen>
+$ psql -c 'SHOW cluster_name'
+ cluster_name
+--------------
+ server1
+(1 row)
+
+$ ps aux|grep server1
+postgres   27093  0.0  0.0  30096  2752 ?        Ss   11:34   0:00 postgres: server1: writer process
+...
+</screen>
+  </para>
+
   <para>
    If you have turned off <xref linkend="guc-update-process-title"> then the
    activity indicator is not updated; the process title is set only once
 
 static void assign_pgstat_temp_directory(const char *newval, void *extra);
 static bool check_application_name(char **newval, void **extra, GucSource source);
 static void assign_application_name(const char *newval, void *extra);
+static bool check_cluster_name(char **newval, void **extra, GucSource source);
 static const char *show_unix_socket_permissions(void);
 static const char *show_log_file_mode(void);
 
 
 int            num_temp_buffers = 1024;
 
+char      *cluster_name = "";
 char      *data_directory;
 char      *ConfigFileName;
 char      *HbaFileName;
        check_application_name, assign_application_name, NULL
    },
 
+   {
+       {"cluster_name", PGC_POSTMASTER, LOGGING_WHAT,
+           gettext_noop("Sets the name of the cluster which is included in the process title."),
+           NULL,
+           GUC_IS_NAME
+       },
+       &cluster_name,
+       "",
+       check_cluster_name, NULL, NULL
+   },
+
    /* End-of-list marker */
    {
        {NULL, 0, 0, NULL, NULL}, NULL, NULL, NULL, NULL, NULL
    pgstat_report_appname(newval);
 }
 
+static bool
+check_cluster_name(char **newval, void **extra, GucSource source)
+{
+   /* Only allow clean ASCII chars in the cluster name */
+   char       *p;
+
+   for (p = *newval; *p; p++)
+   {
+       if (*p < 32 || *p > 126)
+           *p = '?';
+   }
+
+   return true;
+}
+
 static const char *
 show_unix_socket_permissions(void)
 {
 
                    # than the specified size in kilobytes;
                    # -1 disables, 0 logs all temp files
 #log_timezone = 'GMT'
-
+#cluster_name = ''         # added to process titles if nonempty
+                   # (change requires restart)
 
 #------------------------------------------------------------------------------
 # RUNTIME STATISTICS
 
 #include "libpq/libpq.h"
 #include "miscadmin.h"
 #include "utils/ps_status.h"
+#include "utils/guc.h"
 
 extern char **environ;
 bool       update_process_title = true;
     * apparently setproctitle() already adds a `progname:' prefix to the ps
     * line
     */
-   snprintf(ps_buffer, ps_buffer_size,
-            "%s %s %s ",
-            username, dbname, host_info);
+#define PROGRAM_NAME_PREFIX ""
 #else
-   snprintf(ps_buffer, ps_buffer_size,
-            "postgres: %s %s %s ",
-            username, dbname, host_info);
+#define PROGRAM_NAME_PREFIX "postgres: "
 #endif
 
+   if (*cluster_name == '\0')
+   {
+       snprintf(ps_buffer, ps_buffer_size,
+                PROGRAM_NAME_PREFIX "%s %s %s ",
+                username, dbname, host_info);
+   }
+   else
+   {
+       snprintf(ps_buffer, ps_buffer_size,
+                PROGRAM_NAME_PREFIX "%s: %s %s %s ",
+                cluster_name, username, dbname, host_info);
+   }
+
    ps_buffer_cur_len = ps_buffer_fixed_size = strlen(ps_buffer);
 
    set_ps_display(initial_str, true);
 
 
 extern int num_temp_buffers;
 
+extern char *cluster_name;
 extern char *data_directory;
 extern char *ConfigFileName;
 extern char *HbaFileName;