diff options
| author | Andres Freund <andres@anarazel.de> | 2023-04-08 00:24:24 -0700 | 
|---|---|---|
| committer | Andres Freund <andres@anarazel.de> | 2023-04-08 01:06:00 -0700 | 
| commit | e101dfac3a53c20bfbf1ca85d30a368c2954facf (patch) | |
| tree | 1a5c755d9eb0a2f6f1d6251d9dd9f185654534cb /src/backend/catalog/system_functions.sql | |
| parent | 26669757b6a7665c1069e77e6472bd8550193ca6 (diff) | |
| download | postgresql-e101dfac3a53c20bfbf1ca85d30a368c2954facf.tar.gz | |
For cascading replication, wake physical and logical walsenders separately
Physical walsenders can't send data until it's been flushed; logical
walsenders can't decode and send data until it's been applied. On the
standby, the WAL is flushed first, which will only wake up physical
walsenders; and then applied, which will only wake up logical
walsenders.
Previously, all walsenders were awakened when the WAL was flushed. That
was fine for logical walsenders on the primary; but on the standby the
flushed WAL would have been not applied yet, so logical walsenders were
awakened too early.
Per idea from Jeff Davis and Amit Kapila.
Author: "Drouvot, Bertrand" <bertranddrouvot.pg@gmail.com>
Reviewed-By: Jeff Davis <pgsql@j-davis.com>
Reviewed-By: Robert Haas <robertmhaas@gmail.com>
Reviewed-by: Amit Kapila <amit.kapila16@gmail.com>
Reviewed-by: Masahiko Sawada <sawada.mshk@gmail.com>
Discussion: https://postgr.es/m/CAA4eK1+zO5LUeisabX10c81LU-fWMKO4M9Wyg1cdkbW7Hqh6vQ@mail.gmail.com
Diffstat (limited to 'src/backend/catalog/system_functions.sql')
0 files changed, 0 insertions, 0 deletions
