django 中间件

最近有个需要用prometheus对django服务的接口进行监控的任务,由于接口比较多,写装饰器比较麻烦,因此,研究了中间件的用法

1. 编写monitor.middleware

编写一个middleware.py文件,内容如下:

from django.http import HttpResponse
from django.utils.deprecation import MiddlewareMixin
from django.views import View
from prometheus_client import CollectorRegistry, Counter, generate_latest, Gauge
import time

# 注册采集器
LABELS = ['req_status', 'req_method', 'req_url']  # 标签定义

REGISTRY = CollectorRegistry()


class ExporterView(View):
    """
    exporter主页面
    """
    def get(self, request, *args, **kwargs):
        return HttpResponse(generate_latest(REGISTRY), status=200, content_type="application/json")


class MonitorMiddleware(MiddlewareMixin):
    """
    监控指标埋点
    该类主要是采集http性能相关的指标
    """
    def __init__(self, get_response=None, t=None):
        super().__init__(get_response)
        self.start = t
        self.g_requests_total = Counter('requests_total',
                                        'url request total num',
                                        LABELS,
                                        registry=REGISTRY
                                        )
        self.g_response_time_seconds = Gauge('avg_response_time_seconds',
                                             'Seconds of prediction cost in total',
                                             LABELS,
                                             registry=REGISTRY
                                             )

    def process_request(self, request):
        self.start = time.time()

    def process_response(self, request, response):
        method = request.method
        status = response.status_code
        url = request.path
        avg_rt = time.time() - self.start
        self.g_requests_total.labels(status, method, url).inc()  # 统计请求次数
        self.g_response_time_seconds.labels(status, method, url).set(avg_rt)
        return response

然后,在setting.py中配置该中间件

MIDDLEWARE = [
    '....',  # 其它默认的中间件
    'monitor.middleware.MonitorMiddleware',   # 自定义的监控中间件
]

将django工程打包成docker镜像后,启动django工程(本项目使用8080端口),可以在该url下看到监控日志http://<ip>:8080/metrics在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值