您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“django如何利用request id便于定位及給日志加上request_id”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“django如何利用request id便于定位及給日志加上request_id”這篇文章吧。
簡介
在開發(fā)大型系統(tǒng)的時候,往往是進行微服務(wù)化,變成了多個系統(tǒng)之間的交互??焖俚銜l(fā)現(xiàn)線上的系統(tǒng)很多很復(fù)雜,這時候一個用戶請求過來會經(jīng)過很多內(nèi)部系統(tǒng),如果這時候發(fā)生錯誤,我們?nèi)ゲ榭慈罩镜臅r候,根本不知道,哪個錯誤來自哪一個用戶,這時候我們給每一個請求加上一個Request ID就可以很好的區(qū)分了。
django-log-request-id
這個項目為我們提供了輪子,直接使用即可
github: https://github.com/dabapps/django-log-request-id (本地下載)
安裝
pip install django-log-request-id
添加middleware
需要加在其它middleware前面
MIDDLEWARE_CLASSES = ( 'log_request_id.middleware.RequestIDMiddleware', # ... other middleware goes here )
header中添加RequestID
LOG_REQUEST_ID_HEADER = "HTTP_X_REQUEST_ID" GENERATE_REQUEST_ID_IF_NOT_IN_HEADER = True REQUEST_ID_RESPONSE_HEADER = "RESPONSE_HEADER_NAME"
日志中添加RequestID
LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'filters': { 'request_id': { '()': 'log_request_id.filters.RequestIDFilter' } }, 'formatters': { 'standard': { 'format': '%(levelname)-8s [%(asctime)s] [%(request_id)s] %(name)s: %(message)s' }, }, 'handlers': { 'console': { 'level': 'DEBUG', 'class': 'logging.StreamHandler', 'filters': ['request_id'], 'formatter': 'standard', }, }, 'loggers': { 'myapp': { 'handlers': ['console'], 'level': 'DEBUG', 'propagate': False, }, } }
給Django日志加上request_id
用來標(biāo)識同一個請求的日志,方便檢索和分析。
request_id用uuid自動生成。如果請求頭有X-Request-ID,就用請求頭的,這樣一個請求涉及多個服務(wù)調(diào)用的時候可以把request_id帶過去,標(biāo)識為同一個請求的request_id.
下面是代碼示例。
在一個文件中自定義Middleware和Logging Filter.
import logging import threading import uuid from django.utils.deprecation import MiddlewareMixin local = threading.local() class RequestIDFilter(logging.Filter): def filter(self, record): record.request_id = getattr(local, 'request_id', "none") return True class RequestIDMiddleware(MiddlewareMixin): def process_request(self, request): local.request_id = request.META.get('HTTP_X_REQUEST_ID', uuid.uuid4().hex) def process_response(self, request, response): if hasattr(request, 'request_id'): response['X-Request-ID'] = local.request_id try: del local.request_id except AttributeError: pass return response
然后在settings.py中引用.
LOGGING配置示例
LOGGING = { 'filters': { 'request_id': { # 自定義的filter '()': 'xxx.middlewares.RequestIDFilter' } }, 'formatters': { 'standard': { 'format': '%(levelname)s [%(asctime)s] [%(request_id)s] %(name)s: %(message)s' # 這里使用filter request_id里的request_id字段 }, }, 'handlers': { 'console': { 'level': 'DEBUG', 'class': 'logging.StreamHandler', 'filters': ['request_id'], # 這里使用上面的filter: request_id 'formatter': 'standard', # 這里使用上面的formatter: standard }, }, 'loggers': { 'xxx': { 'handlers': ['console'], # 這里使用上面的handler: console 'level': 'DEBUG', 'propagate': False, }, } }
ok, 現(xiàn)在代碼里用logging打的日志就會帶上request_id了.
以上是“django如何利用request id便于定位及給日志加上request_id”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。