python – Django芹菜使用Ajax检索任务状态

前端之家收集整理的这篇文章主要介绍了python – Django芹菜使用Ajax检索任务状态前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用芹菜2.5.3和 django芹菜 – 2.5.5.我正在使用 mysql作为经纪人.

这是一个场景,当用户请求我在工作组中排队从另一个站点获取数据的作业时.这可能需要几分钟,具体取决于数据的大小.一旦作业开始,我们必须显示加载器图像.当工人完成下载数据(将采用html格式)时,我必须用检索到的数据替换加载器图像.

我们使用芹菜的原因是有时脚本需要超过30秒来完成和超时.

目前我打算使用ajax调用来检查作业的状态,这个函数将以固定的间隔使用.

我经历过一些问题,这就是我提出的问题

为了启动worker,我正在使用这段代码

def testCelery(request):
   result=testadd.apply_async()
   return HttpResponse(str(result.task_id))

这会将task_id返回给客户端并使用ajax我将向服务器发送请求以检查作业是否已完成

def getStat(request,task_id):
      res = AsyncResult(task_id)
      s=res.ready()
      if s==True:
         return HttpResponse(str(res.get()))
      else:
         return HttpResponse(str(s))

我不确定这是否是正确的方法,或者它在实时场景中的表现如何.

请指教.

编辑:使用djcelery视图检查状态

好吧,我修改了我的代码,因为bruno建议现在看起来像

from djcelery import views as celery_views
def getStat(request,task_id):
    return celery_views.is_task_successful(request,task_id)

它似乎正在发挥作用.并且仍然使用task_id的ajax调用来检索状态.

解决方法

Django-celery已经提供了你正在寻找的视图和url – views.task_status和views.is_task_successful都将task_id作为参数并返回一个json响应(resp.)完整状态(如果任务失败则包括异常和回溯)或者只是一个布尔标志.

例如,将以下内容添加到urls.py:

urlpatterns += patterns('djcelery.views',url(r'^task/status/(?P<task_id>.+)/$','task_status',name='task-status')
)

猜你在找的Python相关文章