Django:如何将每个应用程序登录到单独的文件

时间:2018-12-08 11:17:27

标签: python django logging

我在settings.py文件中有我的Django日志定义,如下所示:

LOG_DIR = '/var/log/myapp/'
LOGGING = {
    'version': 1,
    'disable_existing_loggers': True,
    'formatters': {
        'standard': {
            'format' : "[%(asctime)s] %(levelname)s [%(name)s:%(lineno)s] %(message)s",
            'datefmt' : "%d/%b/%Y %H:%M:%S"
        },
    },
    'handlers': {
        'null': {
            'level':'DEBUG' if DEBUG else 'WARNING',
            'class':'logging.NullHandler',
        },
        'logfile': {
            'level':'DEBUG' if DEBUG else 'WARNING',
            'class':'logging.handlers.RotatingFileHandler',
            'filename': LOG_DIR + "/application.log",
            'maxBytes': 1024 * 1024 * 10, #Max 10MB
            'backupCount': 3,
            'formatter': 'standard',
        },
        'console':{
            'level':'INFO',
            'class':'logging.StreamHandler',
            'formatter': 'standard'
        },
    },
    'loggers': {
        'django': {
            'handlers':['console'],
            'propagate': True,
            'level':'WARN',
        },
        'django.db.backends': {
            'handlers': ['console'],
            'level': 'DEBUG' if DEBUG else 'WARNING',
            'propagate': False,
        },
        '': {
            'handlers': ['console', 'logfile'],
            'level': 'DEBUG',
        },
    }
}

现在,我在这个项目中有几个应用程序,我必须以一种简单的方式来组织它们的日志记录,彼此创建一个单独的日志,我的意思是:

  • 项目常规日志
  • My_App1日志
  • My_App2日志
  • My_App3日志

使用Django是否可以轻松实现?

1 个答案:

答案 0 :(得分:1)

在“记录器”下,您需要为每个应用输入一个条目:

'app1': {
            'handlers': ['app1'],
        },

同样在“处理程序”下:

'app1': {
        'level':'DEBUG' if DEBUG else 'WARNING',
        'class':'logging.handlers.RotatingFileHandler',
        'filename': LOG_DIR + "/app1.log",
        'maxBytes': 1024 * 1024 * 10, #Max 10MB
        'backupCount': 3,
        'formatter': 'standard',
},