mirror of
				https://github.com/carrotquest/django-clickhouse.git
				synced 2025-10-25 05:01:15 +03:00 
			
		
		
		
	Trying to fix queue monitoring increment bug
This commit is contained in:
		
							parent
							
								
									4249b0e2b9
								
							
						
					
					
						commit
						8d31209a58
					
				|  | @ -98,38 +98,40 @@ class Storage: | |||
|         """ | ||||
|         raise NotImplemented() | ||||
| 
 | ||||
|     def register_operations(self, import_key, operation, *pks):  # type: (str, str, *Any) -> None | ||||
|     def register_operations(self, import_key, operation, *pks):  # type: (str, str, *Any) -> int | ||||
|         """ | ||||
|         Registers new incoming operation | ||||
|         :param import_key: A key, returned by ClickHouseModel.get_import_key() method | ||||
|         :param operation: One of insert, update, delete | ||||
|         :param pk: Primary key to find records in main database. Should be string-serializable with str() method. | ||||
|         :return: None | ||||
|         :return: Number of registered operations | ||||
|         """ | ||||
|         raise NotImplementedError() | ||||
| 
 | ||||
|     def register_operations_wrapped(self, import_key, operation, *pks): | ||||
|         # type: (str, str, *Any)  -> None | ||||
|         # type: (str, str, *Any)  -> int | ||||
|         """ | ||||
|         This is a wrapper for register_operation method, checking main parameters. | ||||
|         This method should be called from inner functions. | ||||
|         :param import_key: A key, returned by ClickHouseModel.get_import_key() method | ||||
|         :param operation: One of insert, update, delete | ||||
|         :param pks: Primary keys to find records in main database. Should be string-serializable with str() method. | ||||
|         :return: None | ||||
|         :return: Number of registered operations | ||||
|         """ | ||||
|         if operation not in {'insert', 'update', 'delete'}: | ||||
|             raise ValueError('operation must be one of [insert, update, delete]') | ||||
| 
 | ||||
|         statsd_key = "%s.sync.%s.queue" % (config.STATSD_PREFIX, import_key) | ||||
|         statsd.gauge(statsd_key, len(pks), delta=True) | ||||
|         logger.debug('django-clickhouse: registered %s on %d items (%s) to storage' | ||||
|                      % (operation, len(pks), import_key)) | ||||
| 
 | ||||
|         statsd_key = "%s.sync.%s.register_operations" % (config.STATSD_PREFIX, import_key) | ||||
|         statsd.incr(statsd_key + '.%s' % operation, len(pks)) | ||||
|         with statsd.timer(statsd_key): | ||||
|             return self.register_operations(import_key, operation, *pks) | ||||
|             ops_count = self.register_operations(import_key, operation, *pks) | ||||
| 
 | ||||
|         statsd_key = "%s.sync.%s.queue" % (config.STATSD_PREFIX, import_key) | ||||
|         statsd.gauge(statsd_key, ops_count, delta=True) | ||||
|         logger.debug('django-clickhouse: registered %s on %d items (%s) to storage' | ||||
|                      % (operation, len(pks), import_key)) | ||||
| 
 | ||||
|         return ops_count | ||||
| 
 | ||||
|     def flush(self): | ||||
|         """ | ||||
|  | @ -180,7 +182,7 @@ class RedisStorage(with_metaclass(SingletonMeta, Storage)): | |||
|         score = datetime.datetime.now().timestamp() | ||||
| 
 | ||||
|         items = {'%s:%s' % (operation, str(pk)): score for pk in pks} | ||||
|         redis_zadd(self._redis, key, items) | ||||
|         return redis_zadd(self._redis, key, items) | ||||
| 
 | ||||
|     def operations_count(self, import_key, **kwargs): | ||||
|         ops_key = self.REDIS_KEY_OPS_TEMPLATE.format(import_key=import_key) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user