Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Logging app initialization failure using config.log #218

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

pdelagrave
Copy link

@pdelagrave pdelagrave commented Apr 26, 2024

On exiting due to an unhandled exception during the app initialization (lifespan), the process(es) spawned by multiprocessing.BaseContext.Process.start() in _populate() would have their stack traceback directly printed to stderr by BaseProcess:_bootstrap.

Using the user-configurable config.log logger instead makes the log output more consistent.


Notes on the changeset:

  • The exc_info is added and created manually to the logger.exception() call, as we're not in an except block and using exc_info=True wouldn't help as later sys.exc_info() wouldn't return anything. This tuple contains what's expected as per the documentation.
  • As we're not exiting the process by raising an unhandled exception anymore, we have to exit(1) in order for the "active" loop in hypercorn/run.py:run() to break and hypercorn to shutdown instead of respawning a process for the app. Exiting the process with an exception was also exiting with code 1 but also printed the stack traceback which is what we want to avoid.
  • Upon a failure at this point, nothing was initialized yet so it's safe to exit() without having to do any cleanup.

Motivation

We're using fastapi/hypercorn in production with structlog and a json formatter so the logs can be ingested by some logs storage and visualization tooling.
We've configured everything so the application outputs JSON logs but in the case the app fails to start, hypercorn was outputting a raw stack traceback to stderr, which isn't consistent with how the logging system was configured.

On exiting due to an unhandled exception during the app initialization (lifespan), the process(es) spawned by `multiprocessing.BaseContext.Process.start()` in `_populate()` would have their stack traceback directly printed to stderr by `BaseProcess:_bootstrap`.

Using the user-configurable `config.log` logger instead makes the log output more consistent.
@pdelagrave pdelagrave force-pushed the init_app_error_log branch from f8e8d18 to 79cef1c Compare July 30, 2024 15:11
@dhirschfeld
Copy link
Contributor

ping!

Also interested in your configuration to enable structlog @pdelagrave, if you're free to share?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants