-
Notifications
You must be signed in to change notification settings - Fork 226
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix perf when streams don't change often (#17767)
There is a bug with the `StreamChangeCache` where it would incorrectly return that all entities had changed if asked for entities changed *since* the earliest stream position. Note that for streams we use the inequalities: `$min_stream_id < stream_id <= $max_stream_id`, i.e. when we ask the stream change cache for all things that have changed since `$stream_id` we don't care for events that happened *at* `$stream_id`. Specifically: `_earliest_known_stream_pos` is the position at which we know that we'll have entries for all changes since that point, we can use the cache for any stream IDs that equal `_earliest_known_stream_pos`. `_earliest_known_stream_pos` is set in three places: - On startup we set it either to: - the current maximum stream ID, with not prefilled values; or - the minimum of the latest N values we pulled from the DB - When we evict items from the bottom, we set it to the stream ID of the evicted items. This was changed in matrix-org/synapse#14435, but I think we were overly conservative there. --------- Co-authored-by: Andrew Morgan <[email protected]>
- Loading branch information
1 parent
ae4862c
commit 81e0f57
Showing
3 changed files
with
19 additions
and
14 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Fix performance of streams that don't change often. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -53,8 +53,8 @@ def test_has_entity_changed(self) -> None: | |
# return True, whether it's a known entity or not. | ||
self.assertTrue(cache.has_entity_changed("[email protected]", 0)) | ||
self.assertTrue(cache.has_entity_changed("[email protected]", 0)) | ||
self.assertTrue(cache.has_entity_changed("[email protected]", 3)) | ||
self.assertTrue(cache.has_entity_changed("[email protected]", 3)) | ||
self.assertTrue(cache.has_entity_changed("[email protected]", 2)) | ||
self.assertTrue(cache.has_entity_changed("[email protected]", 2)) | ||
|
||
def test_entity_has_changed_pops_off_start(self) -> None: | ||
""" | ||
|
@@ -76,9 +76,11 @@ def test_entity_has_changed_pops_off_start(self) -> None: | |
self.assertTrue("[email protected]" not in cache._entity_to_key) | ||
|
||
self.assertEqual( | ||
cache.get_all_entities_changed(3).entities, ["[email protected]"] | ||
cache.get_all_entities_changed(2).entities, | ||
["[email protected]", "[email protected]"], | ||
) | ||
self.assertFalse(cache.get_all_entities_changed(2).hit) | ||
self.assertFalse(cache.get_all_entities_changed(1).hit) | ||
self.assertTrue(cache.get_all_entities_changed(2).hit) | ||
|
||
# If we update an existing entity, it keeps the two existing entities | ||
cache.entity_has_changed("[email protected]", 5) | ||
|
@@ -89,7 +91,8 @@ def test_entity_has_changed_pops_off_start(self) -> None: | |
cache.get_all_entities_changed(3).entities, | ||
["[email protected]", "[email protected]"], | ||
) | ||
self.assertFalse(cache.get_all_entities_changed(2).hit) | ||
self.assertFalse(cache.get_all_entities_changed(1).hit) | ||
self.assertTrue(cache.get_all_entities_changed(2).hit) | ||
|
||
def test_get_all_entities_changed(self) -> None: | ||
""" | ||
|
@@ -114,7 +117,8 @@ def test_get_all_entities_changed(self) -> None: | |
self.assertEqual( | ||
cache.get_all_entities_changed(3).entities, ["[email protected]"] | ||
) | ||
self.assertFalse(cache.get_all_entities_changed(1).hit) | ||
self.assertFalse(cache.get_all_entities_changed(0).hit) | ||
self.assertTrue(cache.get_all_entities_changed(1).hit) | ||
|
||
# ... later, things gest more updates | ||
cache.entity_has_changed("[email protected]", 5) | ||
|
@@ -149,7 +153,7 @@ def test_has_any_entity_changed(self) -> None: | |
# With no entities, it returns True for the past, present, and False for | ||
# the future. | ||
self.assertTrue(cache.has_any_entity_changed(0)) | ||
self.assertTrue(cache.has_any_entity_changed(1)) | ||
self.assertFalse(cache.has_any_entity_changed(1)) | ||
self.assertFalse(cache.has_any_entity_changed(2)) | ||
|
||
# We add an entity | ||
|