Python/Django:在runserver下登录到控制台,在Apache下登录到文件

Posted

技术标签:

【中文标题】Python/Django:在runserver下登录到控制台,在Apache下登录到文件【英文标题】:Python/Django: log to console under runserver, log to file under Apache 【发布时间】:2011-06-01 07:51:31 【问题描述】:

当我在manage.py runserver 下运行我的 Django 应用程序时,如何将跟踪消息发送到控制台(如 print),但是当我在 Apache 下运行应用程序时将这些消息发送到日志文件?

我查看了Django logging,虽然我对它在高级用途中的灵活性和可配置性印象深刻,但我仍然不知道如何处理我的简单用例。

【问题讨论】:

最简单的解决方案是主服务器和开发环境有不同的settings.py文件,见deploydjango.com/django_project_structure 【参考方案1】:

这是一个基于 Django 日志记录的解决方案。它使用 DEBUG 设置,而不是实际检查您是否正在运行开发服务器,但如果您找到更好的方法来检查它应该很容易适应。

LOGGING = 
    'version': 1,
    'formatters': 
        'verbose': 
            'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'
        ,
        'simple': 
            'format': '%(levelname)s %(message)s'
        ,
    ,
    'handlers': 
        'console': 
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        ,
        'file': 
            'level': 'DEBUG',
            'class': 'logging.FileHandler',
            'filename': '/path/to/your/file.log',
            'formatter': 'simple'
        ,
    ,
    'loggers': 
        'django': 
            'handlers': ['file'],
            'level': 'DEBUG',
            'propagate': True,
        ,
    


if DEBUG:
    # make all loggers use the console.
    for logger in LOGGING['loggers']:
        LOGGING['loggers'][logger]['handlers'] = ['console']

详情请参阅https://docs.djangoproject.com/en/dev/topics/logging/。

【讨论】:

也可以试试LOGGING['loggers'][logger]['handlers'] += ['console'] @m01: 在settings.py中配置后,如何使用它进行打印?谢谢 我将答案中的代码放入我的settings.py 的底部,并设置DEBUG = True(在同一文件的顶部附近查找该设置)。然后,我从终端运行python manage.py runserver(有关详细信息,请参阅 django 文档),日志消息将出现在终端窗口中。在生产中,我会使用不同的 settings.py,其中 DEBUG = False - 日志消息转到 /path/to/your/file.log 你的缩进让我头疼。不过感谢您提供的信息,它有效! 谢谢!我对缩进做了一些更改,希望现在更好【参考方案2】:

在 mod_wsgi 下运行时,打印到 stderr 的文本将显示在 httpd 的错误日志中。您可以直接使用print,也可以改用logging

print >>sys.stderr, 'Goodbye, cruel world!'

【讨论】:

虽然它在技术上不是有效的 WSGI,但会在更严格的环境中触发错误。 就 WSGI 而言,使用 'print' 和 'sys.stderr' 没有任何问题,它不应该触发错误。 我导入了 sys 但这似乎对我不起作用。 这在 Python 3 中不起作用看看here。你需要print("Goodbye cruel world!", file=sys.stderr)【参考方案3】:

您可以在 settings.py 文件中配置日志记录。

一个例子:

if DEBUG:
    # will output to your console
    logging.basicConfig(
        level = logging.DEBUG,
        format = '%(asctime)s %(levelname)s %(message)s',
    )
else:
    # will output to logging file
    logging.basicConfig(
        level = logging.DEBUG,
        format = '%(asctime)s %(levelname)s %(message)s',
        filename = '/my_log_file.log',
        filemode = 'a'
    )

但这取决于设置 DEBUG,也许您不想担心它是如何设置的。请参阅How can I tell whether my Django application is running on development server or not? 上的此答案,以更好地编写该条件。编辑:上面的示例来自 Django 1.1 项目,Django 中的日志记录配置自该版本以来发生了一些变化。

【讨论】:

我不想依赖DEBUG;我宁愿依赖其他帖子中链接的开发服务器检测机制。但是另一个帖子的检测机制依赖于对请求实例的访问。如何在 settings.py 中获取请求实例?【参考方案4】:

我用这个:

logging.conf:

[loggers]
keys=root,applog
[handlers]
keys=rotateFileHandler,rotateConsoleHandler

[formatters]
keys=applog_format,console_format

[formatter_applog_format]
format=%(asctime)s-[%(levelname)-8s]:%(message)s

[formatter_console_format]
format=%(asctime)s-%(filename)s%(lineno)d[%(levelname)s]:%(message)s

[logger_root]
level=DEBUG
handlers=rotateFileHandler,rotateConsoleHandler

[logger_applog]
level=DEBUG
handlers=rotateFileHandler
qualname=simple_example

[handler_rotateFileHandler]
class=handlers.RotatingFileHandler
level=DEBUG
formatter=applog_format
args=('applog.log', 'a', 10000, 9)

[handler_rotateConsoleHandler]
class=StreamHandler
level=DEBUG
formatter=console_format
args=(sys.stdout,)

testapp.py:

import logging
import logging.config

def main():
    logging.config.fileConfig('logging.conf')
    logger = logging.getLogger('applog')

    logger.debug('debug message')
    logger.info('info message')
    logger.warn('warn message')
    logger.error('error message')
    logger.critical('critical message')
    #logging.shutdown()

if __name__ == '__main__':
    main()

【讨论】:

【参考方案5】:

您可以使用 tagalog (https://github.com/dorkitude/tagalog) 轻松完成此操作

例如,当标准 python 模块写入以附加模式打开的文件对象时,App Engine 模块 (https://github.com/dorkitude/tagalog/blob/master/tagalog_appengine.py) 会覆盖此行为并而是使用logging.INFO

要在 App Engine 项目中获得此行为,只需执行以下操作:

import tagalog.tagalog_appengine as tagalog
tagalog.log('whatever message', ['whatever','tags'])

您可以自己扩展模块并轻松覆盖日志功能。

【讨论】:

【参考方案6】:

这在我的 local.py 中运行良好,让我免于搞乱常规日志记录:

from .settings import *

LOGGING['handlers']['console'] = 
    'level': 'DEBUG',
    'class': 'logging.StreamHandler',
    'formatter': 'verbose'

LOGGING['loggers']['foo.bar'] = 
    'handlers': ['console'],
    'propagate': False,
    'level': 'DEBUG',

【讨论】:

以上是关于Python/Django:在runserver下登录到控制台,在Apache下登录到文件的主要内容,如果未能解决你的问题,请参考以下文章

python+django 更改了urls.py 之后runserver报错的解决办法

Django 2021年最新版教程36 python django runserver 后台运行

当我执行 python manage.py runserver 时,CMD 抛出 AttributeError:

python django启动报错

django web应用runserver模式下cpu占用高解决办法

Django Admin 通过 apache 破坏了 CSS 链接,但在 runserver 模式下工作