mirror of
https://git.anonymousland.org/anonymousland/synapse-product.git
synced 2025-01-04 00:10:46 -05:00
Merge pull request #3603 from matrix-org/erikj/handle_outliers
Correctly handle outliers during persist events
This commit is contained in:
commit
3849f7f69f
1
changelog.d/3601.bugfix
Normal file
1
changelog.d/3601.bugfix
Normal file
@ -0,0 +1 @@
|
||||
Fix failure to persist events over federation under load
|
@ -574,11 +574,13 @@ class EventsStore(EventsWorkerStore):
|
||||
|
||||
for ev, ctx in events_context:
|
||||
if ctx.state_group is None:
|
||||
# I don't think this can happen, but let's double-check
|
||||
raise Exception(
|
||||
"Context for new extremity event %s has no state "
|
||||
"group" % (ev.event_id, ),
|
||||
)
|
||||
# This should only happen for outlier events.
|
||||
if not ev.internal_metadata.is_outlier():
|
||||
raise Exception(
|
||||
"Context for new event %s has no state "
|
||||
"group" % (ev.event_id, ),
|
||||
)
|
||||
continue
|
||||
|
||||
if ctx.state_group in state_groups_map:
|
||||
continue
|
||||
@ -606,7 +608,7 @@ class EventsStore(EventsWorkerStore):
|
||||
for event_id in new_latest_event_ids:
|
||||
# First search in the list of new events we're adding.
|
||||
for ev, ctx in events_context:
|
||||
if event_id == ev.event_id:
|
||||
if event_id == ev.event_id and ctx.state_group is not None:
|
||||
event_id_to_state_group[event_id] = ctx.state_group
|
||||
break
|
||||
else:
|
||||
|
Loading…
Reference in New Issue
Block a user