django:无论如何都要直接从内存中提供文件

时间:2016-01-24 09:50:17

标签: python django

所以我让用户从django服务器请求他们的文件,其中一些进程发生在所请求的文件上。目前我正在将文件写入磁盘并从那里提供服务。

无论如何都要从内存中直接向用户提供文件以获得更高的效率和性能(使用x-sendfile)?

以下是我目前的观点:

def ServeSegment(request, segmentID):
    segments =[]
    obj = MainFile.objects.filter(owner=request.user)
    file_name = MainFile.objects.get(file_id=segmentID).file_name
    file_suffix = file_name = MainFile.objects.get(file_id=segmentID).file_suffix
    if request.method == 'GET':
        hosts = settings.HOSTS
        for i in hosts:
            try:
                url = 'http://' + i + ':8000/foo/'+str(segmentID)
                r = requests.get(url, timeout=1, stream=True)
                if r.status_code == 200:
                    segments.append(r.content)
            except:
                continue
        instance = SeIDA(filename='test', x=settings.M, y=settings.N)
        docfile = instance.decoder(segments)
        with open('/tmp/Files/'+file_name, 'wb') as f:
            f.write(docfile)
            response = HttpResponse()
            response['Content-Disposition'] = 'attachment; filename={0}'.format(file_name)
            response['X-Sendfile'] = "/tmp/Files/{0}".format(file_name)
            return response

注意:正在使用的SeIDA模块,将数据编码为N个段,使得M个段足以构建数据。因此,在上面的视图中,我正在检索存储服务器中的段并将它们组合起来。

我的问题是:如何在不保存的情况下直接提供docfile。反正有吗?

1 个答案:

答案 0 :(得分:0)

您无法使用X-Sendfile从内存中提供服务,因为Apache即使在完全独立的计算机上也在不同的进程中运行。

然而,在这种情况下,使用sendfile并不能真正提高效率。因为正如你所说的文件已经在内存中,你应该直接从那里开始服务而不需要通过Apache:只需在响应中返回它。

docfile = instance.decoder(segments)
response = HttpResponse()
response.write(docfile)
response['Content-Disposition'] = 'attachment; filename={0}'.format(file_name)
return response