django log日志模块无法正常工作,记录日志信息

背景描述:

  1. 使用gunicorn +django +nginx部署,

  2. 在指定目录会自动创建info.log ,error.log,warn.log

  3. 屏幕上可以正常显示日志信息

  4. 没有往日志文件写入信息

  5. 使用runserver启动服务,日志可以正常书写

代码

logger.py

# _*_ coding:utf-8
from __future__ import unicode_literals

__author__ = 'chenAdmin'
__date__ = '2018/7/12 0012 16:36'

import os


BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
BASE_LOG_DIR = os.path.join(BASE_DIR, "log")

LOGGING = {
    'version': 1,  # 保留的参数,默认是1
    'disable_existing_loggers': False,  # 是否禁用已经存在的logger示例,不禁用
    'formatters': {
        'standard': {  # 定义一个标准的日志格式化
            'format': '%(levelname)s %(asctime)s %(module)s %(message)s'
        },
        'error': {
            'format': '%(levelname)s %(asctime)s %(pathname)s %(module)s %(message)s'
        },
        'simple': {  # 定义一个简单的日志格式化
            'format': '%(levelname)s %(asctime)s %(message)s'
        },
        'collect': {  # 定义一个特殊的日志格式化
            'format': '%(message)s'
        }
    },
    # 过滤器
    'filters': {
        # 只有在deubg=True的过滤器
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue',
        },
    },
    # 处理器
    'handlers': {
        # 定义一个专门往终端打印日志的控制器
        'console': {
            'level': 'DEBUG',
            'filters': ['require_debug_true'],  # 只有在Django debug为True时才在屏幕打印日志
            'class': 'logging.StreamHandler',  # 使用什么类去处理日志流
            'formatter': 'simple'
        },
        # 定义一个默认的日志处理器
        'default': {
            'level': 'INFO',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "info.log"),  # 日志文件
            'maxBytes': 1024 * 1024 * 50,  # 日志大小 50M
            'backupCount': 5,  # 日志文件备份的数量
            'formatter': 'standard',
            'encoding': 'utf-8',
        },
        # 定义一个默认的日志处理器
        'warn': {
            'level': 'WARN',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "warn.log"),  # 日志文件
            'maxBytes': 1024 * 1024 * 50,  # 日志大小 50M
            'backupCount': 5,  # 日志文件备份的数量
            'formatter': 'standard',
            'encoding': 'utf-8',
        },
        # 定义一个专门及错误日志的处理器
        'error': {
            'level': 'ERROR',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件,自动切
            'filename': os.path.join(BASE_LOG_DIR, "error.log"),  # 日志文件
            'maxBytes': 1024 * 1024 * 50,  # 日志大小 50M
            'backupCount': 5,
            'formatter': 'error',
            'encoding': 'utf-8',
        },
    },

    'loggers': {
        # 默认的logger应用如下配置
        '': {
            'handlers': ['default', 'warn', 'error'],  # 上线之后可以把'console'移除
            'level': 'DEBUG',
            'propagate': True,  # 如果有父级的logger示例,表示不要向上传递日志流
        },
        'collect': {
            'handlers': ['console', 'default', 'warn', 'error'],
            'level': 'INFO',
        }
    },
}

setting.py

from logger import LOGGING

views.py

import logging


logger = logging.getLogger(__name__)

class RandomImagination(APIView):
    def post(self, request):
        logger.info(u'路径:{} 用户id:{}'.format(request.path, user_id, result_dict['msg']))
        return Response({'status':100})

解决思路:

在https://github.com/benoitc/gunicorn/issues/1244中看到解决方案

Looking at this again I think you may just need to move the empty logger key up to a top-level root dict. 
I was re-reading https://docs.python.org/2/library/logging.config.html#dictionary-schema-details 
and I had forgotten about that.

views.py

import logging


logger = logging.getLogger('collect')

class RandomImagination(APIView):
    def post(self, request):
        logger.info(u'路径:{} 用户id:{}'.format(request.path, user_id, result_dict['msg']))
        return Response({'status':100}

原文:django log日志模块无法正常工作,记录日志信息

猜你喜欢

转载自blog.csdn.net/a1007720052/article/details/81354542
今日推荐