1

我不知道为什么这不起作用。我使用 linode 来托管我的 ubuntu 服务器,而 apache 托管我的 django。

在我的 settings.py 文件中,我有这个来定义我的记录器

 import logging

 LOGGING = {
    'version': 1,
    'disable_existing_loggers': True,
    'formatters': {
    'standard': {
            'format' : '%(asctime)s [%(levelname)s] %(name)s: %(message)s'
    },
},

'handlers': {
    'default': {
        'level': 'DEBUG',
        'class': 'logging.handlers.RotatingFileHandler',
        'filename': '/logs/django.log',
        'maxBytes': 1024*1024*5,
        'formatter' : 'standard',
        'backupCount': 5,
    },
},
'loggers': {
    '': {
        'handlers': ['default'],
        'level': 'DEBUG',
        'propagate': True,
    },
},

}

然后我像这样在我的视图中使用它

   import logging
   logr = logging.getLogger(__name__)

   def login(request):
      logr.debug("THIS BETTER WORK >:O")
      c = {}
      c.update(csrf(request))
      return render_to_response('accounts/login.html', c)

我没有收到任何错误消息或任何输出,只是没有写入文件或任何内容。

我究竟做错了什么?我创建了日志文件,并将其放在正确的位置并授予它完全权限。在这一点上,我变得非常绝望。我只是想要任何方式来记录一些东西,这样我就可以开始调试我的网站了。

4

2 回答 2

1

我曾经陷入同样的​​问题。我的发现让我有点困惑,但它确实有效。问题出在参数上

disable_existing_loggers: True,

将此参数设置为 true,意味着您要禁用所有记录器并用您定义的现有 django 记录器覆盖它。但是,它不会自动这样做。您还需要在 settings.py 文件中重新定义这些记录器以及它们的父级。

就我而言,我没有任何这样的要求。因此,与其摆脱重新定义所有记录器的痛苦,我只是更改了参数并将其设置为 false。它奏效了。

disable_existing_loggers: False,

我希望这能解决你的问题。也可以执行权限检查。

另外,您可以使用Sentry来跟踪您的代码有什么问题。

于 2014-02-06T11:29:01.907 回答
1

我迟到了几年,但无论如何我遇到了类似的问题,下面是我的评论

'filename': '/logs/django.log',

'filename': '/fillpath/logs/django.log',
or
BASE_DIR = 'django project path'
'filename': os.path.join(BASE_DIR, 'logs/django.log'),

也在视图中或您想要记录的任何地方

下面一个适用于 django runserver 但不适用于 apache httpd

import logging
logme = logging.getLogger('__name__')

进行以下更改,它将适用于 apache/httpd

import logging
logme = logging.getLogger('seekers')
于 2016-10-02T11:18:37.853 回答