django-测量中间件的延迟

时间:2019-03-16 00:27:14

标签: django

我为django 1.8编写了此代码,以计算处理请求所需的时间。我故意使视图花费4秒,但是此代码中显示的增量时间为8毫秒。 有什么想法可以在中间件中进行衡量吗?

from datetime import datetime

class MonitorMiddleware(object):
    def process_request(self, request):
        request.start = datetime.now()

    def process_response(self, request, response):
        print 'Took: ', round((datetime.now() - request.start).microseconds / 1000000.0, 3)
        return response

1 个答案:

答案 0 :(得分:1)

我不确定您的时间计算是否正确。我已经研究了源代码 django-request-profiler并编译了它们实现方式的简短版本。

from django.utils import timezone
class ProfilingMiddleware:
    def process_request(self, request):
        self.start_ts = timezone.now()

    def process_response(self, request, response):
        self.end_ts = timezone.now()
        duration = (self.end_ts - self.start_ts).total_seconds()
        return response

我强烈建议您在那里使用开源django分析器。