mirror of
				https://github.com/matrix-org/synapse.git
				synced 2025-10-26 13:51:04 +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): | ||||
|             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 = {} | ||||
| 
 | ||||
|         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: | ||||
|                 continue | ||||
| 
 | ||||
|  | ||||
| @ -421,9 +421,13 @@ class RoomMemberStore(SQLBaseStore): | ||||
|         # We check if we have any of the member event ids in the event cache | ||||
|         # 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( | ||||
|             member_event_ids, | ||||
|             allow_rejected=False, | ||||
|             update_metrics=False, | ||||
|         ) | ||||
| 
 | ||||
|         missing_member_event_ids = [] | ||||
|  | ||||
| @ -96,7 +96,7 @@ class Cache(object): | ||||
|                     "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. | ||||
| 
 | ||||
|         Args: | ||||
| @ -104,6 +104,7 @@ class Cache(object): | ||||
|             default: What is returned if key is not in the caches. If not | ||||
|                 specified then function throws KeyError instead | ||||
|             callback(fn): Gets called when the entry in the cache is invalidated | ||||
|             update_metrics (bool): whether to update the cache hit rate metrics | ||||
| 
 | ||||
|         Returns: | ||||
|             Either a Deferred or the raw result | ||||
| @ -113,6 +114,7 @@ class Cache(object): | ||||
|         if val is not _CacheSentinel: | ||||
|             if val.sequence == self.sequence: | ||||
|                 val.callbacks.update(callbacks) | ||||
|                 if update_metrics: | ||||
|                     self.metrics.inc_hits() | ||||
|                 return val.deferred | ||||
| 
 | ||||
| @ -121,6 +123,7 @@ class Cache(object): | ||||
|             self.metrics.inc_hits() | ||||
|             return val | ||||
| 
 | ||||
|         if update_metrics: | ||||
|             self.metrics.inc_misses() | ||||
| 
 | ||||
|         if default is _CacheSentinel: | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user