Skip to content

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