Djangoアプリをmanage.py runserver
の下で実行しているときにトレースメッセージ(print
など)をコンソールに送信できますが、それらのメッセージはログファイルに送信されます。 m Apacheでアプリを実行していますか?
Django logging を確認しましたが、高度な使用のための柔軟性と構成可能性には感心しましたが、単純なユースケースの処理方法にはまだ困惑しています。
Mod_wsgiで実行すると、stderrに出力されたテキストがhttpdのエラーログに表示されます。 print
を直接使用するか、代わりにlogging
を使用できます。
print >>sys.stderr, 'Goodbye, cruel world!'
これが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/ を参照してください。
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の設定に依存しているため、設定方法について心配する必要はありません。 このDjangoアプリケーションが開発サーバーで実行されているかどうかを確認するにはどうすればよいですか? のこの回答を参照してください。編集:上記の例はDjango 1.1プロジェクトのものであり、Djangoのロギング構成はそのバージョン以降多少変更されています。
私はこれを使用します:
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 __== '__main__':
main()
これは私の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',
}
これは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'])
モジュールを自分で拡張し、ログ機能を簡単に上書きできます。