Run push_receipts_to_remotes as background job (#4707)

I suspect the CPU usage metrics for this are going to /dev/null at the moment.
This commit is contained in:
Richard van der Hoff 2019-02-21 17:50:30 +00:00 committed by GitHub
parent 16e0680498
commit 6d65659b62
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 32 additions and 31 deletions

1
changelog.d/4707.misc Normal file
View file

@ -0,0 +1 @@
Run push_receipts_to_remotes as background job.

View file

@ -16,8 +16,8 @@ import logging
from twisted.internet import defer from twisted.internet import defer
from synapse.metrics.background_process_metrics import run_as_background_process
from synapse.types import get_domain_from_id from synapse.types import get_domain_from_id
from synapse.util import logcontext
from ._base import BaseHandler from ._base import BaseHandler
@ -59,7 +59,9 @@ class ReceiptsHandler(BaseHandler):
if is_new: if is_new:
# fire off a process in the background to send the receipt to # fire off a process in the background to send the receipt to
# remote servers # remote servers
self._push_remotes([receipt]) run_as_background_process(
'push_receipts_to_remotes', self._push_remotes, receipt
)
@defer.inlineCallbacks @defer.inlineCallbacks
def _received_remote_receipt(self, origin, content): def _received_remote_receipt(self, origin, content):
@ -125,15 +127,13 @@ class ReceiptsHandler(BaseHandler):
defer.returnValue(True) defer.returnValue(True)
@logcontext.preserve_fn # caller should not yield on this
@defer.inlineCallbacks @defer.inlineCallbacks
def _push_remotes(self, receipts): def _push_remotes(self, receipt):
"""Given a list of receipts, works out which remote servers should be """Given a receipt, works out which remote servers should be
poked and pokes them. poked and pokes them.
""" """
try: try:
# TODO: Some of this stuff should be coallesced. # TODO: optimise this to move some of the work to the workers.
for receipt in receipts:
room_id = receipt["room_id"] room_id = receipt["room_id"]
receipt_type = receipt["receipt_type"] receipt_type = receipt["receipt_type"]
user_id = receipt["user_id"] user_id = receipt["user_id"]