デフォルトの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'], }, } }