やる気がストロングZERO

やる気のストロングスタイル

Djangoのログ設定

デフォルトのLogging設定だと 実行時エラーが起こった時に、

Debug=Trueの場合: ブラウザ上にエラーメッセージとスタックトレースが表示される。

Debug=Falseの場合: ブラウザ上にはnginxのstatusコードのみ。

となっていて、本番環境でエラーが起こった場合の原因を探りにくい。

adminとしてメールアドレスを設定しておくと、そこにメールが飛ぶようにデフォルト設定されているらしいが、 ファイルに出力したいと思ったので下記設定を行った。

※ec2上Docker運用でこのログファイルをec2<->コンテナで同期させた場合、パーミッションがrootになってしまいDjangoからログが書き込まれなかった。要調査。
↑調査したところ、ちゃんと書き込まれていた。構文エラーのときにはロガー自体が動作しないのでログに書き込まれないという状態だった。
パーミッションがrootになってしまうのは、コンテナ内でuwsgiをroot権限で動かしていたから。本当ならちゃんとuserを作成したほうが良さげ。

# logging_setting。デフォルト設定に対して、ファイル出力するように設定を追加し、時間も記録できるようにフォーマットを追加したもの
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse',
        },
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue',
        },
    },
    'formatters': {
        'verbose': {
            'format': '{levelname} {asctime} {module} {process:d} {thread:d} {message}',
            'style': '{',
        },
        'simple': {
            'format': '{levelname} {message}',
            'style': '{',
        },
    },
    'handlers': {
        'console': {
            'level': 'INFO',
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler',
        },
        'mail_admins': {
            'level': 'ERROR',
            'filters': ['require_debug_false'],
            'class': 'django.utils.log.AdminEmailHandler'
        },
        'file': {
            'level': 'INFO',
            'class': 'logging.FileHandler',
            'filename': '/logs/django.log', # ログファイルのパスを指定
            'formatter': 'verbose',
        },
    },
    'loggers': {
        'django': {
            'handlers': ['console', 'mail_admins', 'file'],
            'level': 'INFO',
        },
        'py.warnings': {
            'handlers': ['console', 'file'],
        },
    }
}