Обсуждение: How to test replication without doing a failover
select pg_is_in_recovery() ;
select * from pg_stat_replication ;
How do I test and confirm whether replication is working or not besides depending on just running the SQL below?select pg_is_in_recovery() ;
select * from pg_stat_replication ;
Is it possible to force/initiate a log transaction and see if that gets replicated or not? I mean for example on Oracle we can do a switch logfile and check if that log gets shipped across and applied on the standby, is there something similar in PostgreSQL?
You can (usually) access the replica in read-only mode
So, what I do is do a transaction on the master and see if it appears on the replica. On a live database that often happens automatically, so I just look at, for instance, the latest entry in a busy table on the master, and check it's the same on the replica. If you do this a couple of times as things change on the master, then you'll know whether or not it's replicating properly
Paul
ListVery newbie here on PostgreSQL coming from an Oracle DBA background mostlyHow do I test and confirm whether replication is working or not besides depending on just running the SQL below?select pg_is_in_recovery() ;
select * from pg_stat_replication ;
Is it possible to force/initiate a log transaction and see if that gets replicated or not? I mean for example on Oracle we can do a switch logfile and check if that log gets shipped across and applied on the standby, is there something similar in PostgreSQL?Maybe someone can refer me to an example if there is one somewhere?Regards,Ed
Monitoring the replication
Compare the WAL positions of primary and secondary: select pg_current_wal_lsn(); on the primary
select pg_last_wal_receive_lsn(); on the standby or in the ps output of WAL receiver process.
Using the view pg_stat_replication
Check the difference between pg_current_wal_lsn() and the column sent_lsn of the view shows high load of the primary.
Difference between the column sent_lsn of the view and pg_last_wal_receive_lsn() on the standby shows network congestion or that the standby has high load.
-- Holger Jakobs, Bergisch Gladbach, Tel. +49-178-9759012
Вложения
On Nov 10, 2022, at 9:59 AM, Edwin UY <edwin.uy@gmail.com> wrote:Is it possible to force/initiate a log transaction and see if that gets replicated or not? I mean for example on Oracle we can do a switch logfile and check if that log gets shipped across and applied on the standby, is there something similar in PostgreSQL?
select * from pg_stat_replication ;
On Nov 10, 2022, at 9:59 AM, Edwin UY <edwin.uy@gmail.com> wrote:Is it possible to force/initiate a log transaction and see if that gets replicated or not? I mean for example on Oracle we can do a switch logfile and check if that log gets shipped across and applied on the standby, is there something similar in PostgreSQL?Yes, if you are using log shipping instead of replication you can use: select pg_switch_wal();However, replication doesn’t wait for a WAL file switch to replicate data; thus you can monitor it on the upstream server (master or cascading replication server) using the pg_stat_replication and pg_replication_slots views.I create and use the following views to monitor replication; viewing the lag by data size instead of lsn values.create or replace view dba.replication_statusasselect pg_stat_replication.client_addr, pg_stat_replication.application_name, pg_stat_replication.sync_priority, pg_stat_replication.sync_state, pg_stat_replication.state, case pg_is_in_recovery()when true then pg_size_pretty(pg_wal_lsn_diff(pg_last_wal_receive_lsn(), sent_lsn))else pg_size_pretty(pg_wal_lsn_diff(pg_current_wal_lsn(), sent_lsn))end as sent_lag, case pg_is_in_recovery()when true then pg_size_pretty(pg_wal_lsn_diff(pg_last_wal_receive_lsn(), flush_lsn))else pg_size_pretty(pg_wal_lsn_diff(pg_current_wal_lsn(), flush_lsn))end as flush_lag, case pg_is_in_recovery()when true then pg_size_pretty(pg_wal_lsn_diff(pg_last_wal_receive_lsn(), replay_lsn))else pg_size_pretty(pg_wal_lsn_diff(pg_current_wal_lsn(), replay_lsn))end as replay_lagfrom pg_stat_replication;create or replace view dba.replication_slot_statusasselect slot_name, slot_type, temporary, active, active_pid, xmin, catalog_xmin, restart_lsn, case pg_is_in_recovery()when true then pg_size_pretty(pg_wal_lsn_diff(pg_last_wal_receive_lsn(), restart_lsn))else pg_size_pretty(pg_wal_lsn_diff(pg_current_wal_lsn(), restart_lsn))end as restart_lag, confirmed_flush_lsn as flush_lsn, case pg_is_in_recovery()when true then pg_size_pretty(pg_wal_lsn_diff(pg_last_wal_receive_lsn(), confirmed_flush_lsn))else pg_size_pretty(pg_wal_lsn_diff(pg_current_wal_lsn(), confirmed_flush_lsn))end as flush_lagfrom pg_replication_slots;
On Nov 12, 2022, at 1:24 AM, Edwin UY <edwin.uy@gmail.com> wrote:If using log shipping, the SQL below will return nothing, is that correct?select * from pg_stat_replication ;