Ето как можете да получите броя на съобщенията в опашката, като използвате целина, която не зависи от брокера.
С помощта на connection_or_acquire
, можете да сведете до минимум броя на отворените връзки към вашия брокер, като използвате вътрешния пул за връзки на celery.
celery = Celery(app)
with celery.connection_or_acquire() as conn:
conn.default_channel.queue_declare(
queue='my-queue', passive=True).message_count
Можете също да разширите Celery, за да предоставите тази функционалност:
from celery import Celery as _Celery
class Celery(_Celery)
def get_message_count(self, queue):
'''
Raises: amqp.exceptions.NotFound: if queue does not exist
'''
with self.connection_or_acquire() as conn:
return conn.default_channel.queue_declare(
queue=queue, passive=True).message_count
celery = Celery(app)
num_messages = celery.get_message_count('my-queue')