我在 django 中进行长时间计算时遇到了麻烦。由于我公司的白痴,我无法安装 Celery,所以我必须“重新发明轮子”。
我正在尝试在 TaskQueue 类中进行所有计算,该类将所有计算存储在字典“结果”中。另外,我正在尝试制作“请稍候”页面,该页面将询问此任务队列是否已准备好提供密钥的任务。
问题是结果不知何故消失了。
我对长时间的计算有一些看法。
def some_view(request):
...
uuid = task_queue.add_task(method_name, params) #method_name(params) returns HttpResponse
return redirect('/please_wait/?uuid={0}'.format(uuid))
请等待视图:
def please_wait(request):
uuid = request.GET.get('uuid','0')
ready = task_queue.task_ready(uuid)
if ready:
return task_queue.task_result(uuid)
elif ready == None:
return render_to_response('admin/please_wait.html',{'not_found':True})
else:
return render_to_response('admin/please_wait.html',{'not_found':False})
最后一个代码,我的任务队列:
class TaskQueue:
def __init__(self):
self.pool = ThreadPool()
self.results = {}
self.lock = Lock()
def add_task(self, method, params):
self.lock.acquire()
new_uuid = self.generate_new_uuid()
while self.results.has_key(new_uuid):
new_uuid = self.generate_new_uuid()
self.results[new_uuid] = self.pool.apply_async(func=method, args=params)
self.lock.release()
return new_uuid
def generate_new_uuid(self):
return uuid.uuid1().hex[0:8]
def task_ready(self, task_id):
if self.results.has_key(task_id):
return self.results[task_id].ready()
else:
return None
def task_result(self, task_id):
if self.task_ready(task_id):
return self.results[task_id].get()
else:
return None
global task_queue = TaskQueue()
添加任务后,我可以记录结果,提供它的 uuid 几秒钟,然后它说任务没有准备好。这是我的日志:(我正在输出 task_queue.results)
[INFO] 2013-10-01 16:04:52,782 logger: {'ade5d154': <multiprocessing.pool.ApplyResult object at 0x1989906c>}
[INFO] 2013-10-01 16:05:05,740 logger: {}
请帮帮我!为什么地狱的结果消失了?
UPD:@freakish 帮助我找到了一些新信息。这个结果不会永远消失,如果我重复尝试记录它,它有时会消失。
[INFO] 2013-10-01 16:52:41,743 logger: {}
[INFO] 2013-10-01 16:52:45,775 logger: {}
[INFO] 2013-10-01 16:52:48,855 logger: {'ade5d154': <multiprocessing.pool.ApplyResult object at 0x1989906c>}