You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
If a connection to the router is opened without sending anything, it will not be closed right away by hyper's graceful shutdown feature.
In browsers like Chrome, opening a page like the health check or prometheus results in one connection created for the initial request, and another eagerly created but not used (probably in case multiple requests must be done to download assets).
If we try to close the router at this point, graceful shutdown closes the first connection, but not the second one, because it has not sent anything. The connection will close after a while, once the tab is closed in the browser or the keepalive timeout triggers.
// so we tell the connection to do a graceful shutdown
// on the next request, then we wait for it to finish
_ = connection_shutdown.notified() => {
let c = connection.as_mut();
c.graceful_shutdown();
let _= connection.await;
}
app is an axum router. Hyper expects a tower service in the second argument of the serve_connection function.
We can make a wrapper service for app, that contains an AtomicBool shared with the task:
once the service's call() method receives the request, the bool is set to true
in the graceful shutdown code, we check for that bool. If it is false, that means we never receive the initial request, so we don't wait for the connection to shutdown, we close the task right away
if we have received at least one header, then hyper's read timeout code kicks in and can handle idle connections after the first initial requests
as an added bonus, we can add a timeout to cover the span between initial connection and receiving the entire request, using that bool
The text was updated successfully, but these errors were encountered:
Fix#3124Fix#3941
<!-- start metadata -->
---
**Checklist**
Complete the checklist (and note appropriate exceptions) before the PR
is marked ready-for-review.
- [ ] Changes are compatible[^1]
- [ ] Documentation[^2] completed
- [ ] Performance impact assessed and acceptable
- Tests added and passing[^3]
- [ ] Unit Tests
- [ ] Integration Tests
- [ ] Manual Tests
**Exceptions**
*Note any exceptions here*
**Notes**
[^1]: It may be appropriate to bring upcoming changes to the attention
of other (impacted) groups. Please endeavour to do this before seeking
PR approval. The mechanism for doing this will vary considerably, so use
your judgement as to how and when to do this.
[^2]: Configuration is an important part of many changes. Where
applicable please try to document configuration examples.
[^3]: Tick whichever testing boxes are applicable. If you are adding
Manual Tests, please document the manual testing (extensively) in the
Exceptions.
---------
Co-authored-by: Bryn Cooke <BrynCooke@gmail.com>
Co-authored-by: Gary Pennington <gary@apollographql.com>
If a connection to the router is opened without sending anything, it will not be closed right away by hyper's graceful shutdown feature.
In browsers like Chrome, opening a page like the health check or prometheus results in one connection created for the initial request, and another eagerly created but not used (probably in case multiple requests must be done to download assets).
If we try to close the router at this point, graceful shutdown closes the first connection, but not the second one, because it has not sent anything. The connection will close after a while, once the tab is closed in the browser or the keepalive timeout triggers.
Proposal to solve this:
In this part of the code:
router/apollo-router/src/axum_factory/listeners.rs
Lines 232 to 255 in beca2ac
app
is an axum router. Hyper expects a tower service in the second argument of theserve_connection
function.We can make a wrapper service for app, that contains an
AtomicBool
shared with the task:call()
method receives the request, the bool is set to trueThe text was updated successfully, but these errors were encountered: