我正在尝试将视频文件上传到 s3,但在使用 celery 放入任务队列后。当视频上传时,用户可以做其他事情。
我的views.py调用celery任务
def upload_blob(request, iterator, interview_id, candidate_id, question_id):
try:
interview_obj = Interview.objects.get(id=interview_id)
except ObjectDoesNotExist:
interview_obj = None
current_interview = interview_obj
if request.method == 'POST':
print("inside POST")
# newdoc1 = Document(upload=request.FILES['uploaded_video'], name="videos/interview_"+interview_id+"_candidate_"+candidate_id+"_question_"+question_id)
# newdoc1.save()
save_document_model.delay(request.FILES['uploaded_video'],"videos/interview_"+interview_id+"_candidate_"+candidate_id+"_question_"+question_id)
# newdoc2 = Document(upload=request.FILES['uploaded_audio'], name="audios/interview_"+interview_id+"_candidate_"+candidate_id+"_question_"+question_id)
# newdoc2.save()
save_document_model.delay(request.FILES['uploaded_audio'],"audios/interview_"+interview_id+"_candidate_"+candidate_id+"_question_"+question_id)
iterator = str(int(iterator) + 1)
return HttpResponseRedirect(reverse('candidate:show_question', kwargs={'iterator': iterator,'interview_id':current_interview.id,'question_id':question_id}))
else:
return render(request, 'candidate/record_answer.html')
Run Code Online (Sandbox Code Playgroud)
实际的芹菜任务.py
@task(name="save_document_model")
def save_document_model(uploaded_file, file_name):
newdoc = Document(upload=uploaded_file, name=file_name)
newdoc.save()
logger.info("document saved successfully")
return HttpResponse("document saved successfully")
Run Code Online (Sandbox Code Playgroud)
文档模型
def upload_function(instance, filename):
getname …Run Code Online (Sandbox Code Playgroud)