Cleanup opentracing logging for syncs (#10828)

We added a bunch of spans in #10704, but this ended up adding a lot of
redundant spans for rooms where nothing changed, so instead we only
start the span if there might be something interesting going on.
This commit is contained in:
Erik Johnston 2021-09-15 17:14:25 +01:00 committed by GitHub
parent 474edce1c4
commit 9a6f4a684f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 155 additions and 139 deletions

1
changelog.d/10828.bugfix Normal file
View file

@ -0,0 +1 @@
Added opentrace logging to help debug #9424.

View file

@ -1533,21 +1533,18 @@ class SyncHandler:
newly_left_rooms = room_changes.newly_left_rooms newly_left_rooms = room_changes.newly_left_rooms
async def handle_room_entries(room_entry: "RoomSyncResultBuilder"): async def handle_room_entries(room_entry: "RoomSyncResultBuilder"):
with start_active_span("generate_room_entry"): logger.debug("Generating room entry for %s", room_entry.room_id)
set_tag("room_id", room_entry.room_id) res = await self._generate_room_entry(
log_kv({"events": len(room_entry.events or [])}) sync_result_builder,
logger.debug("Generating room entry for %s", room_entry.room_id) ignored_users,
res = await self._generate_room_entry( room_entry,
sync_result_builder, ephemeral=ephemeral_by_room.get(room_entry.room_id, []),
ignored_users, tags=tags_by_room.get(room_entry.room_id),
room_entry, account_data=account_data_by_room.get(room_entry.room_id, {}),
ephemeral=ephemeral_by_room.get(room_entry.room_id, []), always_include=sync_result_builder.full_state,
tags=tags_by_room.get(room_entry.room_id), )
account_data=account_data_by_room.get(room_entry.room_id, {}), logger.debug("Generated room entry for %s", room_entry.room_id)
always_include=sync_result_builder.full_state, return res
)
logger.debug("Generated room entry for %s", room_entry.room_id)
return res
await concurrently_execute(handle_room_entries, room_entries, 10) await concurrently_execute(handle_room_entries, room_entries, 10)
@ -1960,139 +1957,157 @@ class SyncHandler:
room_id = room_builder.room_id room_id = room_builder.room_id
since_token = room_builder.since_token since_token = room_builder.since_token
upto_token = room_builder.upto_token upto_token = room_builder.upto_token
log_kv(
{
"since_token": since_token,
"upto_token": upto_token,
}
)
batch = await self._load_filtered_recents( with start_active_span("generate_room_entry"):
room_id, set_tag("room_id", room_id)
sync_config, log_kv({"events": len(events or ())})
now_token=upto_token,
since_token=since_token,
potential_recents=events,
newly_joined_room=newly_joined,
)
log_kv(
{
"batch_events": len(batch.events),
"prev_batch": batch.prev_batch,
"batch_limited": batch.limited,
}
)
# Note: `batch` can be both empty and limited here in the case where log_kv(
# `_load_filtered_recents` can't find any events the user should see {
# (e.g. due to having ignored the sender of the last 50 events). "since_token": since_token,
"upto_token": upto_token,
}
)
if newly_joined: batch = await self._load_filtered_recents(
# debug for https://github.com/matrix-org/synapse/issues/4422 room_id,
issue4422_logger.debug( sync_config,
"Timeline events after filtering in newly-joined room %s: %r", now_token=upto_token,
since_token=since_token,
potential_recents=events,
newly_joined_room=newly_joined,
)
log_kv(
{
"batch_events": len(batch.events),
"prev_batch": batch.prev_batch,
"batch_limited": batch.limited,
}
)
# Note: `batch` can be both empty and limited here in the case where
# `_load_filtered_recents` can't find any events the user should see
# (e.g. due to having ignored the sender of the last 50 events).
if newly_joined:
# debug for https://github.com/matrix-org/synapse/issues/4422
issue4422_logger.debug(
"Timeline events after filtering in newly-joined room %s: %r",
room_id,
batch,
)
# When we join the room (or the client requests full_state), we should
# send down any existing tags. Usually the user won't have tags in a
# newly joined room, unless either a) they've joined before or b) the
# tag was added by synapse e.g. for server notice rooms.
if full_state:
user_id = sync_result_builder.sync_config.user.to_string()
tags = await self.store.get_tags_for_room(user_id, room_id)
# If there aren't any tags, don't send the empty tags list down
# sync
if not tags:
tags = None
account_data_events = []
if tags is not None:
account_data_events.append({"type": "m.tag", "content": {"tags": tags}})
for account_data_type, content in account_data.items():
account_data_events.append(
{"type": account_data_type, "content": content}
)
account_data_events = (
sync_config.filter_collection.filter_room_account_data(
account_data_events
)
)
ephemeral = sync_config.filter_collection.filter_room_ephemeral(ephemeral)
if not (
always_include
or batch
or account_data_events
or ephemeral
or full_state
):
return
state = await self.compute_state_delta(
room_id, room_id,
batch, batch,
sync_config,
since_token,
now_token,
full_state=full_state,
) )
# When we join the room (or the client requests full_state), we should summary: Optional[JsonDict] = {}
# send down any existing tags. Usually the user won't have tags in a
# newly joined room, unless either a) they've joined before or b) the
# tag was added by synapse e.g. for server notice rooms.
if full_state:
user_id = sync_result_builder.sync_config.user.to_string()
tags = await self.store.get_tags_for_room(user_id, room_id)
# If there aren't any tags, don't send the empty tags list down # we include a summary in room responses when we're lazy loading
# sync # members (as the client otherwise doesn't have enough info to form
if not tags: # the name itself).
tags = None if sync_config.filter_collection.lazy_load_members() and (
# we recalculate the summary:
account_data_events = [] # if there are membership changes in the timeline, or
if tags is not None: # if membership has changed during a gappy sync, or
account_data_events.append({"type": "m.tag", "content": {"tags": tags}}) # if this is an initial sync.
any(ev.type == EventTypes.Member for ev in batch.events)
for account_data_type, content in account_data.items(): or (
account_data_events.append({"type": account_data_type, "content": content}) # XXX: this may include false positives in the form of LL
# members which have snuck into state
account_data_events = sync_config.filter_collection.filter_room_account_data( batch.limited
account_data_events and any(t == EventTypes.Member for (t, k) in state)
)
ephemeral = sync_config.filter_collection.filter_room_ephemeral(ephemeral)
if not (
always_include or batch or account_data_events or ephemeral or full_state
):
return
state = await self.compute_state_delta(
room_id, batch, sync_config, since_token, now_token, full_state=full_state
)
summary: Optional[JsonDict] = {}
# we include a summary in room responses when we're lazy loading
# members (as the client otherwise doesn't have enough info to form
# the name itself).
if sync_config.filter_collection.lazy_load_members() and (
# we recalculate the summary:
# if there are membership changes in the timeline, or
# if membership has changed during a gappy sync, or
# if this is an initial sync.
any(ev.type == EventTypes.Member for ev in batch.events)
or (
# XXX: this may include false positives in the form of LL
# members which have snuck into state
batch.limited
and any(t == EventTypes.Member for (t, k) in state)
)
or since_token is None
):
summary = await self.compute_summary(
room_id, sync_config, batch, state, now_token
)
if room_builder.rtype == "joined":
unread_notifications: Dict[str, int] = {}
room_sync = JoinedSyncResult(
room_id=room_id,
timeline=batch,
state=state,
ephemeral=ephemeral,
account_data=account_data_events,
unread_notifications=unread_notifications,
summary=summary,
unread_count=0,
)
if room_sync or always_include:
notifs = await self.unread_notifs_for_room_id(room_id, sync_config)
unread_notifications["notification_count"] = notifs["notify_count"]
unread_notifications["highlight_count"] = notifs["highlight_count"]
room_sync.unread_count = notifs["unread_count"]
sync_result_builder.joined.append(room_sync)
if batch.limited and since_token:
user_id = sync_result_builder.sync_config.user.to_string()
logger.debug(
"Incremental gappy sync of %s for user %s with %d state events"
% (room_id, user_id, len(state))
) )
elif room_builder.rtype == "archived": or since_token is None
archived_room_sync = ArchivedSyncResult( ):
room_id=room_id, summary = await self.compute_summary(
timeline=batch, room_id, sync_config, batch, state, now_token
state=state, )
account_data=account_data_events,
) if room_builder.rtype == "joined":
if archived_room_sync or always_include: unread_notifications: Dict[str, int] = {}
sync_result_builder.archived.append(archived_room_sync) room_sync = JoinedSyncResult(
else: room_id=room_id,
raise Exception("Unrecognized rtype: %r", room_builder.rtype) timeline=batch,
state=state,
ephemeral=ephemeral,
account_data=account_data_events,
unread_notifications=unread_notifications,
summary=summary,
unread_count=0,
)
if room_sync or always_include:
notifs = await self.unread_notifs_for_room_id(room_id, sync_config)
unread_notifications["notification_count"] = notifs["notify_count"]
unread_notifications["highlight_count"] = notifs["highlight_count"]
room_sync.unread_count = notifs["unread_count"]
sync_result_builder.joined.append(room_sync)
if batch.limited and since_token:
user_id = sync_result_builder.sync_config.user.to_string()
logger.debug(
"Incremental gappy sync of %s for user %s with %d state events"
% (room_id, user_id, len(state))
)
elif room_builder.rtype == "archived":
archived_room_sync = ArchivedSyncResult(
room_id=room_id,
timeline=batch,
state=state,
account_data=account_data_events,
)
if archived_room_sync or always_include:
sync_result_builder.archived.append(archived_room_sync)
else:
raise Exception("Unrecognized rtype: %r", room_builder.rtype)
async def get_rooms_for_user_at( async def get_rooms_for_user_at(
self, user_id: str, room_key: RoomStreamToken self, user_id: str, room_key: RoomStreamToken