Commit 030273b7 authored by Alvaro Herrera's avatar Alvaro Herrera

Fix inadequacies in recently added wait events

In commit 9915de6c, we introduced a new wait point for replication
slots and incorrectly labelled it as wait event PG_WAIT_LOCK.  That's
wrong, so invent an appropriate new wait event instead, and document it
properly.

While at it, fix numerous other problems in the vicinity:
- two different walreceiver wait events were being mixed up in a single
  wait event (which wasn't documented either); split it out so that they
  can be distinguished, and document the new events properly.

- ParallelBitmapPopulate was documented but didn't exist.

- ParallelBitmapScan was not documented (I think this should be called
  "ParallelBitmapScanInit" instead.)

- Logical replication wait events weren't documented

- various symbols had been added in dartboard order in various places.
  Put them in alphabetical order instead, as was originally intended.

Discussion: https://postgr.es/m/20170808181131.mu4fjepuh5m75cyq@alvherre.pgsql
parent b4a2eea0
...@@ -1175,6 +1175,14 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser ...@@ -1175,6 +1175,14 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser
<entry><literal>CheckpointerMain</></entry> <entry><literal>CheckpointerMain</></entry>
<entry>Waiting in main loop of checkpointer process.</entry> <entry>Waiting in main loop of checkpointer process.</entry>
</row> </row>
<row>
<entry><literal>LogicalLauncherMain</></entry>
<entry>Waiting in main loop of logical launcher process.</entry>
</row>
<row>
<entry><literal>LogicalApplyMain</></entry>
<entry>Waiting in main loop of logical apply process.</entry>
</row>
<row> <row>
<entry><literal>PgStatMain</></entry> <entry><literal>PgStatMain</></entry>
<entry>Waiting in main loop of the statistics collector process.</entry> <entry>Waiting in main loop of the statistics collector process.</entry>
...@@ -1212,6 +1220,14 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser ...@@ -1212,6 +1220,14 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser
<entry><literal>ClientWrite</></entry> <entry><literal>ClientWrite</></entry>
<entry>Waiting to write data from the client.</entry> <entry>Waiting to write data from the client.</entry>
</row> </row>
<row>
<entry><literal>LibPQWalReceiverConnect</></entry>
<entry>Waiting in WAL receiver to establish connection to remote server.<entry>
</row>
<row>
<entry><literal>LibPQWalReceiverReceive</></entry>
<entry>Waiting in WAL receiver to receive data from remote server.<entry>
</row>
<row> <row>
<entry><literal>SSLOpenServer</></entry> <entry><literal>SSLOpenServer</></entry>
<entry>Waiting for SSL while attempting connection.</entry> <entry>Waiting for SSL while attempting connection.</entry>
...@@ -1250,6 +1266,14 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser ...@@ -1250,6 +1266,14 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser
<entry><literal>ExecuteGather</></entry> <entry><literal>ExecuteGather</></entry>
<entry>Waiting for activity from child process when executing <literal>Gather</> node.</entry> <entry>Waiting for activity from child process when executing <literal>Gather</> node.</entry>
</row> </row>
<row>
<entry><literal>LogicalSyncData</></entry>
<entry>Waiting for logical replication remote server to send data for initial table synchronization.</entry>
</row>
<row>
<entry><literal>LogicalSyncStateChange</></entry>
<entry>Waiting for logical replication remote server to change state.</entry>
</row>
<row> <row>
<entry><literal>MessageQueueInternal</></entry> <entry><literal>MessageQueueInternal</></entry>
<entry>Waiting for other process to be attached in shared message queue.</entry> <entry>Waiting for other process to be attached in shared message queue.</entry>
...@@ -1271,13 +1295,17 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser ...@@ -1271,13 +1295,17 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser
<entry>Waiting for parallel workers to finish computing.</entry> <entry>Waiting for parallel workers to finish computing.</entry>
</row> </row>
<row> <row>
<entry><literal>ParallelBitmapPopulate</></entry> <entry><literal>ParallelBitmapScan</></entry>
<entry>Waiting for the leader to populate the TidBitmap.</entry> <entry>Waiting for parallel bitmap scan to become initialized.</entry>
</row> </row>
<row> <row>
<entry><literal>ProcArrayGroupUpdate</></entry> <entry><literal>ProcArrayGroupUpdate</></entry>
<entry>Waiting for group leader to clear transaction id at transaction end.</entry> <entry>Waiting for group leader to clear transaction id at transaction end.</entry>
</row> </row>
<row>
<entry><literal>ReplicationSlotDrop</></entry>
<entry>Waiting for a replication slot to become inactive to be dropped.</entry>
</row>
<row> <row>
<entry><literal>SafeSnapshot</></entry> <entry><literal>SafeSnapshot</></entry>
<entry>Waiting for a snapshot for a <literal>READ ONLY DEFERRABLE</> transaction.</entry> <entry>Waiting for a snapshot for a <literal>READ ONLY DEFERRABLE</> transaction.</entry>
......
...@@ -3481,6 +3481,12 @@ pgstat_get_wait_activity(WaitEventActivity w) ...@@ -3481,6 +3481,12 @@ pgstat_get_wait_activity(WaitEventActivity w)
case WAIT_EVENT_CHECKPOINTER_MAIN: case WAIT_EVENT_CHECKPOINTER_MAIN:
event_name = "CheckpointerMain"; event_name = "CheckpointerMain";
break; break;
case WAIT_EVENT_LOGICAL_LAUNCHER_MAIN:
event_name = "LogicalLauncherMain";
break;
case WAIT_EVENT_LOGICAL_APPLY_MAIN:
event_name = "LogicalApplyMain";
break;
case WAIT_EVENT_PGSTAT_MAIN: case WAIT_EVENT_PGSTAT_MAIN:
event_name = "PgStatMain"; event_name = "PgStatMain";
break; break;
...@@ -3502,12 +3508,6 @@ pgstat_get_wait_activity(WaitEventActivity w) ...@@ -3502,12 +3508,6 @@ pgstat_get_wait_activity(WaitEventActivity w)
case WAIT_EVENT_WAL_WRITER_MAIN: case WAIT_EVENT_WAL_WRITER_MAIN:
event_name = "WalWriterMain"; event_name = "WalWriterMain";
break; break;
case WAIT_EVENT_LOGICAL_LAUNCHER_MAIN:
event_name = "LogicalLauncherMain";
break;
case WAIT_EVENT_LOGICAL_APPLY_MAIN:
event_name = "LogicalApplyMain";
break;
/* no default case, so that compiler will warn */ /* no default case, so that compiler will warn */
} }
...@@ -3533,15 +3533,18 @@ pgstat_get_wait_client(WaitEventClient w) ...@@ -3533,15 +3533,18 @@ pgstat_get_wait_client(WaitEventClient w)
case WAIT_EVENT_CLIENT_WRITE: case WAIT_EVENT_CLIENT_WRITE:
event_name = "ClientWrite"; event_name = "ClientWrite";
break; break;
case WAIT_EVENT_LIBPQWALRECEIVER_CONNECT:
event_name = "LibPQWalReceiverConnect";
break;
case WAIT_EVENT_LIBPQWALRECEIVER_RECEIVE:
event_name = "LibPQWalReceiverReceive";
break;
case WAIT_EVENT_SSL_OPEN_SERVER: case WAIT_EVENT_SSL_OPEN_SERVER:
event_name = "SSLOpenServer"; event_name = "SSLOpenServer";
break; break;
case WAIT_EVENT_WAL_RECEIVER_WAIT_START: case WAIT_EVENT_WAL_RECEIVER_WAIT_START:
event_name = "WalReceiverWaitStart"; event_name = "WalReceiverWaitStart";
break; break;
case WAIT_EVENT_LIBPQWALRECEIVER:
event_name = "LibPQWalReceiver";
break;
case WAIT_EVENT_WAL_SENDER_WAIT_WAL: case WAIT_EVENT_WAL_SENDER_WAIT_WAL:
event_name = "WalSenderWaitForWAL"; event_name = "WalSenderWaitForWAL";
break; break;
...@@ -3579,6 +3582,12 @@ pgstat_get_wait_ipc(WaitEventIPC w) ...@@ -3579,6 +3582,12 @@ pgstat_get_wait_ipc(WaitEventIPC w)
case WAIT_EVENT_EXECUTE_GATHER: case WAIT_EVENT_EXECUTE_GATHER:
event_name = "ExecuteGather"; event_name = "ExecuteGather";
break; break;
case WAIT_EVENT_LOGICAL_SYNC_DATA:
event_name = "LogicalSyncData";
break;
case WAIT_EVENT_LOGICAL_SYNC_STATE_CHANGE:
event_name = "LogicalSyncStateChange";
break;
case WAIT_EVENT_MQ_INTERNAL: case WAIT_EVENT_MQ_INTERNAL:
event_name = "MessageQueueInternal"; event_name = "MessageQueueInternal";
break; break;
...@@ -3600,18 +3609,15 @@ pgstat_get_wait_ipc(WaitEventIPC w) ...@@ -3600,18 +3609,15 @@ pgstat_get_wait_ipc(WaitEventIPC w)
case WAIT_EVENT_PROCARRAY_GROUP_UPDATE: case WAIT_EVENT_PROCARRAY_GROUP_UPDATE:
event_name = "ProcArrayGroupUpdate"; event_name = "ProcArrayGroupUpdate";
break; break;
case WAIT_EVENT_REPLICATION_SLOT_DROP:
event_name = "ReplicationSlotDrop";
break;
case WAIT_EVENT_SAFE_SNAPSHOT: case WAIT_EVENT_SAFE_SNAPSHOT:
event_name = "SafeSnapshot"; event_name = "SafeSnapshot";
break; break;
case WAIT_EVENT_SYNC_REP: case WAIT_EVENT_SYNC_REP:
event_name = "SyncRep"; event_name = "SyncRep";
break; break;
case WAIT_EVENT_LOGICAL_SYNC_DATA:
event_name = "LogicalSyncData";
break;
case WAIT_EVENT_LOGICAL_SYNC_STATE_CHANGE:
event_name = "LogicalSyncStateChange";
break;
/* no default case, so that compiler will warn */ /* no default case, so that compiler will warn */
} }
......
...@@ -181,7 +181,7 @@ libpqrcv_connect(const char *conninfo, bool logical, const char *appname, ...@@ -181,7 +181,7 @@ libpqrcv_connect(const char *conninfo, bool logical, const char *appname,
WL_LATCH_SET | io_flag, WL_LATCH_SET | io_flag,
PQsocket(conn->streamConn), PQsocket(conn->streamConn),
0, 0,
WAIT_EVENT_LIBPQWALRECEIVER); WAIT_EVENT_LIBPQWALRECEIVER_CONNECT);
/* Emergency bailout? */ /* Emergency bailout? */
if (rc & WL_POSTMASTER_DEATH) if (rc & WL_POSTMASTER_DEATH)
...@@ -582,7 +582,7 @@ libpqrcv_PQexec(PGconn *streamConn, const char *query) ...@@ -582,7 +582,7 @@ libpqrcv_PQexec(PGconn *streamConn, const char *query)
WL_LATCH_SET, WL_LATCH_SET,
PQsocket(streamConn), PQsocket(streamConn),
0, 0,
WAIT_EVENT_LIBPQWALRECEIVER); WAIT_EVENT_LIBPQWALRECEIVER_RECEIVE);
/* Emergency bailout? */ /* Emergency bailout? */
if (rc & WL_POSTMASTER_DEATH) if (rc & WL_POSTMASTER_DEATH)
......
...@@ -391,7 +391,8 @@ retry: ...@@ -391,7 +391,8 @@ retry:
name, active_pid))); name, active_pid)));
/* Wait here until we get signaled, and then restart */ /* Wait here until we get signaled, and then restart */
ConditionVariableSleep(&slot->active_cv, PG_WAIT_LOCK); ConditionVariableSleep(&slot->active_cv,
WAIT_EVENT_REPLICATION_SLOT_DROP);
ConditionVariableCancelSleep(); ConditionVariableCancelSleep();
goto retry; goto retry;
} }
......
...@@ -759,15 +759,15 @@ typedef enum ...@@ -759,15 +759,15 @@ typedef enum
WAIT_EVENT_BGWRITER_HIBERNATE, WAIT_EVENT_BGWRITER_HIBERNATE,
WAIT_EVENT_BGWRITER_MAIN, WAIT_EVENT_BGWRITER_MAIN,
WAIT_EVENT_CHECKPOINTER_MAIN, WAIT_EVENT_CHECKPOINTER_MAIN,
WAIT_EVENT_LOGICAL_LAUNCHER_MAIN,
WAIT_EVENT_LOGICAL_APPLY_MAIN,
WAIT_EVENT_PGSTAT_MAIN, WAIT_EVENT_PGSTAT_MAIN,
WAIT_EVENT_RECOVERY_WAL_ALL, WAIT_EVENT_RECOVERY_WAL_ALL,
WAIT_EVENT_RECOVERY_WAL_STREAM, WAIT_EVENT_RECOVERY_WAL_STREAM,
WAIT_EVENT_SYSLOGGER_MAIN, WAIT_EVENT_SYSLOGGER_MAIN,
WAIT_EVENT_WAL_RECEIVER_MAIN, WAIT_EVENT_WAL_RECEIVER_MAIN,
WAIT_EVENT_WAL_SENDER_MAIN, WAIT_EVENT_WAL_SENDER_MAIN,
WAIT_EVENT_WAL_WRITER_MAIN, WAIT_EVENT_WAL_WRITER_MAIN
WAIT_EVENT_LOGICAL_LAUNCHER_MAIN,
WAIT_EVENT_LOGICAL_APPLY_MAIN
} WaitEventActivity; } WaitEventActivity;
/* ---------- /* ----------
...@@ -782,9 +782,10 @@ typedef enum ...@@ -782,9 +782,10 @@ typedef enum
{ {
WAIT_EVENT_CLIENT_READ = PG_WAIT_CLIENT, WAIT_EVENT_CLIENT_READ = PG_WAIT_CLIENT,
WAIT_EVENT_CLIENT_WRITE, WAIT_EVENT_CLIENT_WRITE,
WAIT_EVENT_LIBPQWALRECEIVER_CONNECT,
WAIT_EVENT_LIBPQWALRECEIVER_RECEIVE,
WAIT_EVENT_SSL_OPEN_SERVER, WAIT_EVENT_SSL_OPEN_SERVER,
WAIT_EVENT_WAL_RECEIVER_WAIT_START, WAIT_EVENT_WAL_RECEIVER_WAIT_START,
WAIT_EVENT_LIBPQWALRECEIVER,
WAIT_EVENT_WAL_SENDER_WAIT_WAL, WAIT_EVENT_WAL_SENDER_WAIT_WAL,
WAIT_EVENT_WAL_SENDER_WRITE_DATA WAIT_EVENT_WAL_SENDER_WRITE_DATA
} WaitEventClient; } WaitEventClient;
...@@ -802,6 +803,8 @@ typedef enum ...@@ -802,6 +803,8 @@ typedef enum
WAIT_EVENT_BGWORKER_STARTUP, WAIT_EVENT_BGWORKER_STARTUP,
WAIT_EVENT_BTREE_PAGE, WAIT_EVENT_BTREE_PAGE,
WAIT_EVENT_EXECUTE_GATHER, WAIT_EVENT_EXECUTE_GATHER,
WAIT_EVENT_LOGICAL_SYNC_DATA,
WAIT_EVENT_LOGICAL_SYNC_STATE_CHANGE,
WAIT_EVENT_MQ_INTERNAL, WAIT_EVENT_MQ_INTERNAL,
WAIT_EVENT_MQ_PUT_MESSAGE, WAIT_EVENT_MQ_PUT_MESSAGE,
WAIT_EVENT_MQ_RECEIVE, WAIT_EVENT_MQ_RECEIVE,
...@@ -809,10 +812,9 @@ typedef enum ...@@ -809,10 +812,9 @@ typedef enum
WAIT_EVENT_PARALLEL_FINISH, WAIT_EVENT_PARALLEL_FINISH,
WAIT_EVENT_PARALLEL_BITMAP_SCAN, WAIT_EVENT_PARALLEL_BITMAP_SCAN,
WAIT_EVENT_PROCARRAY_GROUP_UPDATE, WAIT_EVENT_PROCARRAY_GROUP_UPDATE,
WAIT_EVENT_REPLICATION_SLOT_DROP,
WAIT_EVENT_SAFE_SNAPSHOT, WAIT_EVENT_SAFE_SNAPSHOT,
WAIT_EVENT_SYNC_REP, WAIT_EVENT_SYNC_REP
WAIT_EVENT_LOGICAL_SYNC_DATA,
WAIT_EVENT_LOGICAL_SYNC_STATE_CHANGE
} WaitEventIPC; } WaitEventIPC;
/* ---------- /* ----------
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment