2010-09-07 7 views
1

Я использую функцию AbortableTask Celery, но пример документации для меня не работает. Пример, приведенный в:Django Celery AbortableTask использование

from celery.contrib.abortable import AbortableTask 

def MyLongRunningTask(AbortableTask): 

    def run(self, **kwargs): 
     logger = self.get_logger(**kwargs) 
     results = [] 
     for x in xrange(100): 
      # Check after every 5 loops.. 
      if x % 5 == 0: # alternatively, check when some timer is due 
       if self.is_aborted(**kwargs): 
        # Respect the aborted status and terminate 
        # gracefully 
        logger.warning("Task aborted.") 
        return None 
      y = do_something_expensive(x) 
      results.append(y) 
     logger.info("Task finished.") 
     return results 

и

from myproject.tasks import MyLongRunningTask 

def myview(request): 

    async_result = MyLongRunningTask.delay() 
    # async_result is of type AbortableAsyncResult 

    # After 10 seconds, abort the task 
    time.sleep(10) 
    async_result.abort() 

    ... 

Однако я получаю сообщение об ошибке:

TypeError: MyLongRunningTask() takes exactly 1 argument (0 given) 

Что я делаю неправильно?

ответ

2

Только предположение, но я думаю, что это должно быть

class MyLongRunningTask(AbortableTask) 

и не

def MyLongRunningTask(AbortableTask) 
+0

Я дал этот выстрел (имеет смысл), но сохраняется ошибка. Я не должен называть эту задачу правильной. – Anon

+0

Я дал еще одну попытку, так как казалось, что это будет правильно, и теперь это работает. Я предполагаю, что я просто не обновил файл с задачей. – Anon