mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-01-27 04:17:03 -05:00
Fix sharded federation sender sometimes using 100% CPU.
We pull all destinations requiring catchup from the DB in batches. However, if all those destinations get filtered out (due to the federation sender being sharded), then the `last_processed` destination doesn't get updated, and we keep requesting the same set repeatedly.
This commit is contained in:
parent
48d44ab142
commit
3a569fb200
1
changelog.d/9770.bugfix
Normal file
1
changelog.d/9770.bugfix
Normal file
@ -0,0 +1 @@
|
|||||||
|
Fix bug where sharded federation senders could get stuck repeatedly querying the DB in a loop, using lots of CPU.
|
@ -734,16 +734,18 @@ class FederationSender(AbstractFederationSender):
|
|||||||
self._catchup_after_startup_timer = None
|
self._catchup_after_startup_timer = None
|
||||||
break
|
break
|
||||||
|
|
||||||
|
last_processed = destinations_to_wake[-1]
|
||||||
|
|
||||||
destinations_to_wake = [
|
destinations_to_wake = [
|
||||||
d
|
d
|
||||||
for d in destinations_to_wake
|
for d in destinations_to_wake
|
||||||
if self._federation_shard_config.should_handle(self._instance_name, d)
|
if self._federation_shard_config.should_handle(self._instance_name, d)
|
||||||
]
|
]
|
||||||
|
|
||||||
for last_processed in destinations_to_wake:
|
for destination in destinations_to_wake:
|
||||||
logger.info(
|
logger.info(
|
||||||
"Destination %s has outstanding catch-up, waking up.",
|
"Destination %s has outstanding catch-up, waking up.",
|
||||||
last_processed,
|
last_processed,
|
||||||
)
|
)
|
||||||
self.wake_destination(last_processed)
|
self.wake_destination(destination)
|
||||||
await self.clock.sleep(CATCH_UP_STARTUP_INTERVAL_SEC)
|
await self.clock.sleep(CATCH_UP_STARTUP_INTERVAL_SEC)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user