14

如何以编程方式使用 Python 代码列出当前工作人员及其相应的celery.worker.consumer.Consumer实例?

4

3 回答 3

30

您可以使用celery.control.inspect来检查正在运行的工作人员:

>>> import celery
>>> celery.current_app.control.inspect().ping()
 {u'celery@host': {u'ok': u'pong'}}
于 2013-01-07T08:37:11.883 回答
12

简短的回答:

your_celery_app.control.inspect().stats().keys()

一般来说,该stats()词典提供了很多信息。这是一个示例值:

{u'broker': {u'alternates': [],
             u'connect_timeout': 4,
             u'heartbeat': 0,
             u'hostname': u'mypcisdabom',
             u'insist': False,
             u'login_method': u'AMQPLAIN',
             u'port': 5672,
             u'ssl': False,
             u'transport': u'amqp',
             u'transport_options': {},
             u'uri_prefix': None,
             u'userid': u'celeryabuser',
             u'virtual_host': u'celeryvhost'},
 u'clock': u'182309',
 u'pid': 1660,
 u'pool': {u'max-concurrency': 1,
           u'max-tasks-per-child': u'N/A',
           u'processes': [2496],
           u'put-guarded-by-semaphore': True,
           u'timeouts': [0, 0],
           u'writes': u'N/A'},
 u'prefetch_count': 4,
 u'rusage': u'N/A',
 u'total': {u'mymodule.my_func': 8}},
于 2014-07-08T16:15:37.403 回答
1

如果您将--events在启动时添加密钥。您可以检查此模块以检查当前工作人员等。http://docs.celeryproject.org/en/latest/userguide/monitoring.html

于 2013-01-06T18:43:11.840 回答