1. 程式人生 > >django開發日誌配置

django開發日誌配置

做django開發離不開 日誌,這用於儲存我門的伺服器的日誌資訊,便於開發人員的維護。


直接上程式碼:

在setting.py檔案裡直接配置即可

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s'
        },
        'simple'
: { 'format': '%(levelname)s %(module)s %(lineno)d %(message)s' }, }, 'filters': { 'require_debug_true': { '()': 'django.utils.log.RequireDebugTrue', }, }, 'handlers': { 'console': { 'level': 'DEBUG', 'filters
': ['require_debug_true'], 'class': 'logging.StreamHandler', 'formatter': 'simple' }, 'file': { 'level': 'INFO', 'class': 'logging.handlers.RotatingFileHandler', 'filename': os.path.join(os.path.dirname(BASE_DIR), "logs/meiduo.log
"), # 日誌檔案的位置 'maxBytes': 300 * 1024 * 1024, 'backupCount': 10, 'formatter': 'verbose' }, }, 'loggers': { 'django': { # 定義了一個名為django的日誌器 'handlers': ['console', 'file'], 'propagate': True, }, } }

 

下面是一段重寫 rest_framework 異常處理方式,並增加redis異常 和資料庫異常

from rest_framework.views import exception_handler as drf_exception_handler
import logging
from django.db import DatabaseError
from redis.exceptions import RedisError
from rest_framework.response import Response
from rest_framework import status

# 獲取在配置檔案中定義的logger,用來記錄日誌
logger = logging.getLogger('django')

def exception_handler(exc, context):
    '''
    修改Django REST framework的預設異常處理方法,補充處理資料庫異常和Redis異常。
    '''
    """
    自定義異常處理
    :param exc: 異常
    :param context: 丟擲異常的上下文
    :return: Response響應物件
    """
    # 呼叫drf框架原生的異常處理方法
    response = drf_exception_handler(exc, context)

    if response is None:
        view = context['view']
        if isinstance(exc, DatabaseError) or isinstance(exc, RedisError):
            # 資料庫異常
            logger.error('[%s] %s' % (view, exc))
            response = Response({'message': '伺服器內部錯誤'}, status=status.HTTP_507_INSUFFICIENT_STORAGE)
    return response