This repository has been archived by the owner on Jul 12, 2023. It is now read-only.
Ping db on health instead of opening new connection #1503
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The previous logic relied on creating a new database connection. This would be a different database connection from the one the rest of the app is using, and could lead to false successes. This changes the health endpoint to use the same db that the other handlers use.
Additionally, since it's just a ping now (instead of a full config parsing), the limit is increased from 1/min to 1/sec. The response code when the limit is exceeded is now a 429 instead of silently falling through to 200.
Finally, the monitoring uptime checks are updated to use this endpoint instead of the generic /health. It's safe to say that the service is "down" if it cannot connect to the database.
Release Note
/assign @yegle
/assign @whaught