6

我有一个多租户设置,我想将某些客户特定信息,特别是request.host传递给 celery 任务,理想情况下它应该在全局变量中可用。有没有办法以对应用程序透明的方式进行设置?

任务将以相同的方式调用:

my_background_func.delay(foo, bar)

该任务的定义方式相同,除了它可以访问一个名为“request”的全局变量,该变量具有“主机”属性:

@celery_app.task
def my_background_func(foo, bar):
    print "running the task for host:" + request.host
4

1 回答 1

0

这就是我解决它的方法......

class MyTask(Task):
    abstract = True
    def delay(self, *args, **kwargs):
        return self.apply_async(args, kwargs, headers={'host': request.host})

在客户端:

 @celery_app.task(base=MyTask, bind=True)
 def hellohost(task):
     return "hello " +  task.request.headers['host']

它可以工作,但奇怪的是 hellohost.delay().get() 挂在客户端上

于 2014-02-14T12:03:34.020 回答