Пример #1
0
    def __call__(self, request):
        ''' page render time '''
        start_time = time.time()
        response = self.get_response(request)
        http_user_agent = request.META.get('HTTP_USER_AGENT', '')

        if 'spider'.upper() not in http_user_agent.upper():
            try:
                cast_time = time.time() - start_time
                if ELASTICSEARCH_ENABLED:
                    time_taken = round((cast_time) * 1000, 2)
                    url = request.path
                    from django.utils import timezone

                    ElaspedTimeDocumentManager.create(
                        url=url,
                        time_taken=time_taken,
                        log_datetime=timezone.now(),
                        type='blog',
                        useragent=http_user_agent)
                response.content = response.content.replace(
                    b'<!!LOAD_TIMES!!>', str.encode(str(cast_time)[:5]))
            except Exception as e:
                logger.error("Error OnlineMiddleware: %s" % e)
        return response
Пример #2
0
 def handle(self, *args, **options):
     if ELASTICSEARCH_ENABLED:
         ElaspedTimeDocumentManager.build_index()
         manager = ElapsedTimeDocument()
         manager.init()
         manager = ArticleDocumentManager()
         manager.delete_index()
         manager.rebuild()
Пример #3
0
    def __call__(self, request):
        start_time = time.time()
        response = self.get_response(request)
        http_user_agent = request.META.get('HTTP_USER_AGENT', [])
        if 'Spider' in http_user_agent or 'spider' in http_user_agent:
            return response
        try:
            cast_time = time.time() - start_time
            if ELASTICSEARCH_ENABLED:
                time_taken = round((cast_time) * 1000, 2)
                url = request.path
                from django.utils import timezone

                ElaspedTimeDocumentManager.create(url=url, time_taken=time_taken, log_datetime=timezone.now(),
                                                  type='blog', useragent=http_user_agent)
            response.content = response.content.replace(b'<!!LOAD_TIMES!!>', str.encode(str(cast_time)[:5]))
        except:
            pass
        return response