summary refs log tree commit diff
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2015-06-22 17:17:25 +0100
committerErik Johnston <erik@matrix.org>2015-06-22 17:17:25 +0100
commita4ad9b95567cc821b493e4b73477ed9f7cba9932 (patch)
treecb32d84b49f9e747d9dc99a1291e1d77eebd432b
parentImplement persist_event*s* (diff)
downloadsynapse-a4ad9b95567cc821b493e4b73477ed9f7cba9932.tar.xz
Only persist a maximum of 100 events at a time
-rw-r--r--synapse/storage/events.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/synapse/storage/events.py b/synapse/storage/events.py

index ec798704dc..f9984b7444 100644 --- a/synapse/storage/events.py +++ b/synapse/storage/events.py
@@ -416,6 +416,19 @@ class EventsStore(SQLBaseStore): def _persist_events_txn(self, txn, events_and_contexts, backfilled, is_new_state=True): + if len(events_and_contexts) > 100: + chunks = [ + events_and_contexts[x:x+100] + for x in xrange(0, len(events_and_contexts), 100) + ] + + for chunk in chunks: + self._persist_events_txn( + txn, + chunk, backfilled, is_new_state, + ) + return + # Remove the any existing cache entries for the event_ids for event, _ in events_and_contexts: txn.call_after(self._invalidate_get_event_cache, event.event_id)