mirror of
https://github.com/postgres/postgres.git
synced 2025-12-21 05:21:08 +03:00
Resume conflict-relevant data retention automatically.
This commit resumes automatic retention of conflict-relevant data for a subscription. Previously, retention would stop if the apply process failed to advance its xmin (oldest_nonremovable_xid) within the configured max_retention_duration and user needs to manually re-enable retain_dead_tuples option. With this change, retention will resume automatically once the apply worker catches up and begins advancing its xmin (oldest_nonremovable_xid) within the configured threshold. Author: Zhijie Hou <houzj.fnst@fujitsu.com> Reviewed-by: shveta malik <shveta.malik@gmail.com> Reviewed-by: Amit Kapila <amit.kapila16@gmail.com> Reviewed-by: Dilip Kumar <dilipbalaut@gmail.com> Reviewed-by: Masahiko Sawada <sawada.mshk@gmail.com> Discussion: https://postgr.es/m/OS0PR01MB5716BE80DAEB0EE2A6A5D1F5949D2@OS0PR01MB5716.jpnprd01.prod.outlook.com
This commit is contained in:
@@ -631,6 +631,33 @@ $node_B->safe_psql('postgres',
|
||||
$node_B->adjust_conf('postgresql.conf', 'synchronized_standby_slots', "''");
|
||||
$node_B->reload;
|
||||
|
||||
###############################################################################
|
||||
# Check that dead tuple retention resumes when the max_retention_duration is set
|
||||
# 0.
|
||||
###############################################################################
|
||||
|
||||
$log_offset = -s $node_A->logfile;
|
||||
|
||||
# Set max_retention_duration to 0
|
||||
$node_A->safe_psql('postgres',
|
||||
"ALTER SUBSCRIPTION $subname_AB SET (max_retention_duration = 0);");
|
||||
|
||||
# Confirm that the retention resumes
|
||||
$node_A->wait_for_log(
|
||||
qr/logical replication worker for subscription "tap_sub_a_b" will resume retaining the information for detecting conflicts
|
||||
.*DETAIL:.* Retention is re-enabled as max_retention_duration is set to unlimited.*/,
|
||||
$log_offset);
|
||||
|
||||
ok( $node_A->poll_query_until(
|
||||
'postgres',
|
||||
"SELECT xmin IS NOT NULL from pg_replication_slots WHERE slot_name = 'pg_conflict_detection'"
|
||||
),
|
||||
"the xmin value of slot 'pg_conflict_detection' is valid on Node A");
|
||||
|
||||
$result = $node_A->safe_psql('postgres',
|
||||
"SELECT subretentionactive FROM pg_subscription WHERE subname='$subname_AB';");
|
||||
is($result, qq(t), 'retention is active');
|
||||
|
||||
###############################################################################
|
||||
# Check that the replication slot pg_conflict_detection is dropped after
|
||||
# removing all the subscriptions.
|
||||
|
||||
Reference in New Issue
Block a user