forked from patroni/patroni
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Disable WAL streaming on standby node via new boolean tag "nostream" (p…
…atroni#2842) Add support for ``nostream`` tag. If set to ``true`` the node will not use replication protocol to stream WAL. It will rely instead on archive recovery (if ``restore_command`` is configured) and ``pg_wal``/``pg_xlog`` polling. It also disables copying and synchronization of permanent logical replication slots on the node itself and all its cascading replicas. Setting this tag on primary node has no effect.
- Loading branch information
Showing
14 changed files
with
119 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -136,3 +136,4 @@ tags: | |
noloadbalance: false | ||
clonefrom: false | ||
nosync: false | ||
nostream: false |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -124,6 +124,68 @@ def test_process_permanent_slots(self): | |
"confirmed_flush_lsn": 12345, "catalog_xmin": 105}])] | ||
self.assertEqual(self.p.slots(), {}) | ||
|
||
def test_nostream_slot_processing(self): | ||
config = ClusterConfig( | ||
1, {'slots': {'foo': {'type': 'logical', 'database': 'a', 'plugin': 'b'}, 'bar': {'type': 'physical'}}}, 1) | ||
nostream_node = Member(0, 'test-2', 28, { | ||
'state': 'running', 'conn_url': 'postgres://replicator:[email protected]:5436/postgres', | ||
'tags': {'nostream': 'True'} | ||
}) | ||
cascade_node = Member(0, 'test-3', 28, { | ||
'state': 'running', 'conn_url': 'postgres://replicator:[email protected]:5436/postgres', | ||
'tags': {'replicatefrom': 'test-2'} | ||
}) | ||
stream_node = Member(0, 'test-4', 28, { | ||
'state': 'running', 'conn_url': 'postgres://replicator:[email protected]:5436/postgres'}) | ||
cluster = Cluster( | ||
True, config, self.leader, Status.empty(), | ||
[self.leadermem, nostream_node, cascade_node, stream_node], None, SyncState.empty(), None, None) | ||
global_config.update(cluster) | ||
|
||
# sanity for primary | ||
self.p.name = self.leadermem.name | ||
self.assertEqual( | ||
cluster._get_permanent_slots(self.p, self.leadermem, 'primary'), | ||
{'foo': {'type': 'logical', 'database': 'a', 'plugin': 'b'}, 'bar': {'type': 'physical'}}) | ||
self.assertEqual( | ||
cluster._get_members_slots(self.p.name, 'primary'), | ||
{'test_4': {'type': 'physical'}}) | ||
|
||
# nostream node must not have slot on primary | ||
self.p.name = nostream_node.name | ||
# permanent logical slots are not allowed on nostream node | ||
self.assertEqual( | ||
cluster._get_permanent_slots(self.p, nostream_node, 'replica'), | ||
{'bar': {'type': 'physical'}}) | ||
self.assertEqual( | ||
cluster.get_slot_name_on_primary(self.p.name, nostream_node), | ||
None) | ||
|
||
# check cascade member-slot existence on nostream node | ||
self.assertEqual( | ||
cluster._get_members_slots(nostream_node.name, 'replica'), | ||
{'test_3': {'type': 'physical'}}) | ||
|
||
# cascade also does not entitled to have logical slot on itself ... | ||
self.p.name = cascade_node.name | ||
self.assertEqual( | ||
cluster._get_permanent_slots(self.p, cascade_node, 'replica'), | ||
{'bar': {'type': 'physical'}}) | ||
# ... and member-slot on primary | ||
self.assertEqual( | ||
cluster.get_slot_name_on_primary(self.p.name, cascade_node), | ||
None) | ||
|
||
# simple replica must have every permanent slot ... | ||
self.p.name = stream_node.name | ||
self.assertEqual( | ||
cluster._get_permanent_slots(self.p, stream_node, 'replica'), | ||
{'foo': {'type': 'logical', 'database': 'a', 'plugin': 'b'}, 'bar': {'type': 'physical'}}) | ||
# ... and member-slot on primary | ||
self.assertEqual( | ||
cluster.get_slot_name_on_primary(self.p.name, stream_node), | ||
'test_4') | ||
|
||
@patch.object(Postgresql, 'is_primary', Mock(return_value=False)) | ||
def test__ensure_logical_slots_replica(self): | ||
self.p.set_role('replica') | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters