mirror of
				https://github.com/matrix-org/synapse.git
				synced 2025-10-26 22:01:02 +01:00 
			
		
		
		
	Merge pull request #2203 from matrix-org/erikj/event_cache_hit_ratio
Don't update event cache hit ratio from get_joined_users
This commit is contained in:
		
						commit
						40dcf0d856
					
				| @ -1343,11 +1343,26 @@ class EventsStore(SQLBaseStore): | |||||||
|     def _invalidate_get_event_cache(self, event_id): |     def _invalidate_get_event_cache(self, event_id): | ||||||
|             self._get_event_cache.invalidate((event_id,)) |             self._get_event_cache.invalidate((event_id,)) | ||||||
| 
 | 
 | ||||||
|     def _get_events_from_cache(self, events, allow_rejected): |     def _get_events_from_cache(self, events, allow_rejected, update_metrics=True): | ||||||
|  |         """Fetch events from the caches | ||||||
|  | 
 | ||||||
|  |         Args: | ||||||
|  |             events (list(str)): list of event_ids to fetch | ||||||
|  |             allow_rejected (bool): Whether to teturn events that were rejected | ||||||
|  |             update_metrics (bool): Whether to update the cache hit ratio metrics | ||||||
|  | 
 | ||||||
|  |         Returns: | ||||||
|  |             dict of event_id -> _EventCacheEntry for each event_id in cache. If | ||||||
|  |             allow_rejected is `False` then there will still be an entry but it | ||||||
|  |             will be `None` | ||||||
|  |         """ | ||||||
|         event_map = {} |         event_map = {} | ||||||
| 
 | 
 | ||||||
|         for event_id in events: |         for event_id in events: | ||||||
|             ret = self._get_event_cache.get((event_id,), None) |             ret = self._get_event_cache.get( | ||||||
|  |                 (event_id,), None, | ||||||
|  |                 update_metrics=update_metrics, | ||||||
|  |             ) | ||||||
|             if not ret: |             if not ret: | ||||||
|                 continue |                 continue | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -421,9 +421,13 @@ class RoomMemberStore(SQLBaseStore): | |||||||
|         # We check if we have any of the member event ids in the event cache |         # We check if we have any of the member event ids in the event cache | ||||||
|         # before we ask the DB |         # before we ask the DB | ||||||
| 
 | 
 | ||||||
|  |         # We don't update the event cache hit ratio as it completely throws off | ||||||
|  |         # the hit ratio counts. After all, we don't populate the cache if we | ||||||
|  |         # miss it here | ||||||
|         event_map = self._get_events_from_cache( |         event_map = self._get_events_from_cache( | ||||||
|             member_event_ids, |             member_event_ids, | ||||||
|             allow_rejected=False, |             allow_rejected=False, | ||||||
|  |             update_metrics=False, | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
|         missing_member_event_ids = [] |         missing_member_event_ids = [] | ||||||
|  | |||||||
| @ -96,7 +96,7 @@ class Cache(object): | |||||||
|                     "Cache objects can only be accessed from the main thread" |                     "Cache objects can only be accessed from the main thread" | ||||||
|                 ) |                 ) | ||||||
| 
 | 
 | ||||||
|     def get(self, key, default=_CacheSentinel, callback=None): |     def get(self, key, default=_CacheSentinel, callback=None, update_metrics=True): | ||||||
|         """Looks the key up in the caches. |         """Looks the key up in the caches. | ||||||
| 
 | 
 | ||||||
|         Args: |         Args: | ||||||
| @ -104,6 +104,7 @@ class Cache(object): | |||||||
|             default: What is returned if key is not in the caches. If not |             default: What is returned if key is not in the caches. If not | ||||||
|                 specified then function throws KeyError instead |                 specified then function throws KeyError instead | ||||||
|             callback(fn): Gets called when the entry in the cache is invalidated |             callback(fn): Gets called when the entry in the cache is invalidated | ||||||
|  |             update_metrics (bool): whether to update the cache hit rate metrics | ||||||
| 
 | 
 | ||||||
|         Returns: |         Returns: | ||||||
|             Either a Deferred or the raw result |             Either a Deferred or the raw result | ||||||
| @ -113,6 +114,7 @@ class Cache(object): | |||||||
|         if val is not _CacheSentinel: |         if val is not _CacheSentinel: | ||||||
|             if val.sequence == self.sequence: |             if val.sequence == self.sequence: | ||||||
|                 val.callbacks.update(callbacks) |                 val.callbacks.update(callbacks) | ||||||
|  |                 if update_metrics: | ||||||
|                     self.metrics.inc_hits() |                     self.metrics.inc_hits() | ||||||
|                 return val.deferred |                 return val.deferred | ||||||
| 
 | 
 | ||||||
| @ -121,6 +123,7 @@ class Cache(object): | |||||||
|             self.metrics.inc_hits() |             self.metrics.inc_hits() | ||||||
|             return val |             return val | ||||||
| 
 | 
 | ||||||
|  |         if update_metrics: | ||||||
|             self.metrics.inc_misses() |             self.metrics.inc_misses() | ||||||
| 
 | 
 | ||||||
|         if default is _CacheSentinel: |         if default is _CacheSentinel: | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user