如何使用Python代码以编程方式列出当前工作程序及其相应的celery.worker.consumer.Consumer实例?
mhe*_*her 24
您可以使用celery.control.inspect来检查正在运行的worker:
>>> import celery
>>> celery.current_app.control.inspect().ping()
{u'celery@host': {u'ok': u'pong'}}
Run Code Online (Sandbox Code Playgroud)
简短回答:
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}},
Run Code Online (Sandbox Code Playgroud)
如果您在启动时添加--events密钥。您可以检查此模块以检查当前工人等。http://docs.celeryproject.org/en/latest/userguide/monitoring.html
| 归档时间: |
|
| 查看次数: |
10501 次 |
| 最近记录: |