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

Tracking issue for Jetty sending RST_STREAM(cancel) when AsyncContext.complete() is called #6400

Open
niloc132 opened this issue Nov 19, 2024 · 1 comment
Assignees
Labels
Milestone

Comments

@niloc132
Copy link
Member

niloc132 commented Nov 19, 2024

Tracking issue to let us close #5996 with its workaround, to resolve whatever spec issue exists between Jetty/Tomcat/etc, and to see about adding tests to grpc-java to validate the expected behavior.

Unexpected sideeffect of this is that grpc-timeout can't be managed by the servlet container implementation this way - apparently while closing the output stream does end the h2 stream, it does not terminate the timeout.

@niloc132 niloc132 self-assigned this Nov 19, 2024
@rcaudy rcaudy removed the triage label Nov 19, 2024
@rcaudy rcaudy modified the milestones: Backlog, 0.38.0 Nov 19, 2024
niloc132 added a commit that referenced this issue Nov 21, 2024
This is a Jetty-specific workaround to avoid irritating the Python gRPC
client into failing calls that had already half-closed successfully.

See #6400
Fixes #5996
niloc132 added a commit that referenced this issue Nov 22, 2024
niloc132 added a commit that referenced this issue Nov 26, 2024
This is a Jetty-specific workaround to avoid irritating the Python gRPC
client into failing calls that had already half-closed successfully.

Since we're now using ServletOutputStream.close() in place of
AsyncContext.complete(), we need to apply the same wrapping for trailers
to close() - that is, when the stream is clsoed, we can't rely on the
servlet container sending our trailers because grpc-web trailers are
actually a DATA frame which must be explicitly written.

See #6400
Fixes #5996
Reapplies #6401
nbauernfeind pushed a commit to nbauernfeind/deephaven-core that referenced this issue Nov 29, 2024
…ven#6401)

This is a Jetty-specific workaround to avoid irritating the Python gRPC
client into failing calls that had already half-closed successfully.

See deephaven#6400
Fixes deephaven#5996
niloc132 added a commit that referenced this issue Dec 12, 2024
…6478)

Changes from #6420 were supposed to be reverted in #6424, but apparently
git interpreted the branch's relationship with main differently than I
did.

This patch reapplies #6401, with an additional change to avoid noisy
stack traces from grpc clients that set `grpc-timeout`. At this time,
Deephaven doesn't handle timeouts nor do any default clients set
timeouts, so the impact here should be minimal.

Fixes #5996 
See #6400
niloc132 added a commit to niloc132/deephaven-core that referenced this issue Dec 12, 2024
…eephaven#6478)

Changes from deephaven#6420 were supposed to be reverted in deephaven#6424, but apparently
git interpreted the branch's relationship with main differently than I
did.

This patch reapplies deephaven#6401, with an additional change to avoid noisy
stack traces from grpc clients that set `grpc-timeout`. At this time,
Deephaven doesn't handle timeouts nor do any default clients set
timeouts, so the impact here should be minimal.

Fixes deephaven#5996 
See deephaven#6400
devinrsmith pushed a commit that referenced this issue Dec 12, 2024
This is a Jetty-specific workaround to avoid irritating the Python gRPC
client into failing calls that had already half-closed successfully.

Since we're now using ServletOutputStream.close() in place of
AsyncContext.complete(), we need to apply the same wrapping for trailers
to close() - that is, when the stream is clsoed, we can't rely on the
servlet container sending our trailers because grpc-web trailers are
actually a DATA frame which must be explicitly written.

See #6400
Fixes #5996
Reapplies #6401
Backport #6424
Backport #6478
nbauernfeind pushed a commit to nbauernfeind/deephaven-core that referenced this issue Dec 16, 2024
niloc132 added a commit to niloc132/deephaven-core that referenced this issue Jan 17, 2025
…eephaven#6478)

Changes from deephaven#6420 were supposed to be reverted in deephaven#6424, but apparently
git interpreted the branch's relationship with main differently than I
did.

This patch reapplies deephaven#6401, with an additional change to avoid noisy
stack traces from grpc clients that set `grpc-timeout`. At this time,
Deephaven doesn't handle timeouts nor do any default clients set
timeouts, so the impact here should be minimal.

Fixes deephaven#5996
See deephaven#6400
niloc132 added a commit to niloc132/deephaven-core that referenced this issue Jan 18, 2025
…eephaven#6478)

Changes from deephaven#6420 were supposed to be reverted in deephaven#6424, but apparently
git interpreted the branch's relationship with main differently than I
did.

This patch reapplies deephaven#6401, with an additional change to avoid noisy
stack traces from grpc clients that set `grpc-timeout`. At this time,
Deephaven doesn't handle timeouts nor do any default clients set
timeouts, so the impact here should be minimal.

Fixes deephaven#5996
See deephaven#6400
@niloc132
Copy link
Member Author

It looks like my notes are incorrect, this does appear to be fixed by Jetty 12, at least based on building a test project for it. Need to recheck when resuming #5264.

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

No branches or pull requests

2 participants