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)
Что я делаю неправильно?
Я дал этот выстрел (имеет смысл), но сохраняется ошибка. Я не должен называть эту задачу правильной. – Anon
Я дал еще одну попытку, так как казалось, что это будет правильно, и теперь это работает. Я предполагаю, что я просто не обновил файл с задачей. – Anon