在线程中的任何位置获取当前celery任务ID

时间:2013-11-24 10:42:21

标签: python celery django-celery celery-task

我想在正在运行的任务中获取任务ID, 不知道我在哪个任务。 (这就是为什么我不能使用https://stackoverflow.com/a/8096086/245024

我希望它是这样的:

@task
def my_task():
    foo()

def foo():
    logger.log(current_task_id)

这个模式返回许多不同的任务,我不想将任务上下文带到每个内部方法调用。

一个选项可能是使用线程本地存储,但是我需要在任务启动之前初始化它,并在完成后清理它。

有什么更简单的东西吗?

1 个答案:

答案 0 :(得分:6)

from celery import current_task
print current_task.request.id

我只是从评论中复制这个,因为它应该是一个答案,所以感谢@asksol。