ext_logging.py 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import logging
  2. import os
  3. import sys
  4. from logging.handlers import RotatingFileHandler
  5. from flask import Flask
  6. def init_app(app: Flask):
  7. log_handlers = None
  8. log_file = app.config.get("LOG_FILE")
  9. if log_file:
  10. log_dir = os.path.dirname(log_file)
  11. os.makedirs(log_dir, exist_ok=True)
  12. log_handlers = [
  13. RotatingFileHandler(
  14. filename=log_file,
  15. maxBytes=1024 * 1024 * 1024,
  16. backupCount=5,
  17. ),
  18. logging.StreamHandler(sys.stdout),
  19. ]
  20. logging.basicConfig(
  21. level=app.config.get("LOG_LEVEL"),
  22. format=app.config.get("LOG_FORMAT"),
  23. datefmt=app.config.get("LOG_DATEFORMAT"),
  24. handlers=log_handlers,
  25. force=True,
  26. )
  27. log_tz = app.config.get("LOG_TZ")
  28. if log_tz:
  29. from datetime import datetime
  30. import pytz
  31. timezone = pytz.timezone(log_tz)
  32. def time_converter(seconds):
  33. return datetime.utcfromtimestamp(seconds).astimezone(timezone).timetuple()
  34. for handler in logging.root.handlers:
  35. handler.formatter.converter = time_converter