From b45450a0831ecd0984d68ee518f041f33b0ca681 Mon Sep 17 00:00:00 2001 From: Erik Johnston Date: Wed, 23 Sep 2020 16:58:56 +0100 Subject: [PATCH 1/2] Add new sequences to port DB script --- scripts/synapse_port_db | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/scripts/synapse_port_db b/scripts/synapse_port_db index a34bdf18302c..1b439f8f4ce1 100755 --- a/scripts/synapse_port_db +++ b/scripts/synapse_port_db @@ -627,6 +627,7 @@ class Porter(object): self.progress.set_state("Setting up sequence generators") await self._setup_state_group_id_seq() await self._setup_user_id_seq() + await self._setup_events_stream_seqs() self.progress.done() except Exception as e: @@ -803,6 +804,29 @@ class Porter(object): return self.postgres_store.db_pool.runInteraction("setup_user_id_seq", r) + def _setup_events_stream_seqs(self): + def r(txn): + txn.execute("SELECT MAX(stream_ordering) FROM events") + curr_id = txn.fetchone()[0] + if curr_id: + next_id = curr_id + 1 + txn.execute( + "ALTER SEQUENCE events_stream_seq RESTART WITH %s", (next_id,) + ) + + txn.execute("SELECT -MIN(stream_ordering) FROM events") + curr_id = txn.fetchone()[0] + if curr_id: + next_id = curr_id + 1 + txn.execute( + "ALTER SEQUENCE events_backfill_stream_seq RESTART WITH %s", + (next_id,), + ) + + return self.postgres_store.db_pool.runInteraction( + "_setup_events_stream_seqs", r + ) + ############################################## # The following is simply UI stuff From 3bf428c57011ffa197d333be4ce8c76c464364e5 Mon Sep 17 00:00:00 2001 From: Erik Johnston Date: Wed, 23 Sep 2020 17:00:12 +0100 Subject: [PATCH 2/2] Newsfile --- changelog.d/8387.feature | 1 + 1 file changed, 1 insertion(+) create mode 100644 changelog.d/8387.feature diff --git a/changelog.d/8387.feature b/changelog.d/8387.feature new file mode 100644 index 000000000000..b363e929ea8c --- /dev/null +++ b/changelog.d/8387.feature @@ -0,0 +1 @@ +Add experimental support for sharding event persister.