-
Notifications
You must be signed in to change notification settings - Fork 4.9k
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
quic: add quic version counters in http3 codec stats. #16943
Conversation
Signed-off-by: Renjie Tang <renjietang@google.com>
/assign @alyssawilk |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice addition!
/wait
@@ -194,6 +194,12 @@ On the upstream side all http3 statistics are rooted at *cluster.<name>.http3.* | |||
rx_reset, Counter, Total number of reset stream frames received by Envoy | |||
tx_reset, Counter, Total number of reset stream frames transmitted by Envoy | |||
metadata_not_supported_error, Counter, Total number of metadata dropped during HTTP/3 encoding | |||
quic_version_43, Counter, Total number of quic connections that use transport version 43. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmmm, we have a general Envoy policy that stats don't get removed, but I think it makes sense that as we remove versions of HTTP/3 that we can remove the stats as they'd be implicitly 0 forevermore.
I think this is OK but I want to run this by @envoyproxy/senior-maintainers for second opinion. Alternately we can not add stats for the versions which are going away, but it'd be annoying between now and Q4 when we remove support for outdated versions.
Second, AFIK (@DavidSchinazi) we plan to remove support for non-H3 QUIC this fall as IETF-quic becomes the standard. I think we should make this EoL clear here now (even through QUIC is in alpha and has no guarantees) as part of bubbling up data on which versions are supported.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To clarify the plan from the QUIC side of things:
- The default version today is h3-29
- in some number of weeks, h3 (also called RFCv1 in parts of the code) will become the default version, and we plan on supporting that version for years to come
- h3-29 will stay supported for some number of months, but then we'll drop support
- version 43-51 will all be removed in some number of months
I'd suggest only supporting h3/RFCv1 when QUIC leaves Alpha in Envoy, as that's the only version we'll support long-term.
I think we have two options:
- Add all the current version here, and remove stats as we deprecate versions
- Add all the current version here, and have old version stats at 0 forever
- Only add h3-29 and h3 here, and when we remove h3-29 we'll keep that stat at 0 forever
I'd personally lean towards option 1 if that's acceptable to Envoy, but if that's not an option then I'd suggest option 3.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I'd lean towards 1 as well, I just want a thumbs up from a non-googler as a double check. I think if we comment that the stat will be going away as support is removed by EoY that makes it clear for users.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I prefer 1 as well. I want to be able to monitor the QUIC version deprecation process in Envoy as well.
Happy to add more notes in this doc if Envoy maintainers agree.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I hear no objections so let's just go for it :-P
@@ -169,6 +170,34 @@ void QuicFilterManagerConnectionImpl::onConnectionCloseEvent( | |||
ASSERT(network_connection_ != nullptr); | |||
network_connection_ = nullptr; | |||
} | |||
|
|||
if (!codec_stats_.has_value()) { | |||
// The connection is closed before it can be used. stats are not recorded. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: -> was closed before it could be used
stats -> Stats
codec_stats_->quic_version_50_.inc(); | ||
return; | ||
case quic::QUIC_VERSION_51: | ||
std::cout << "logging" << std::endl; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
clean up?
codec_stats_->quic_version_rfc_v1_.inc(); | ||
return; | ||
default: | ||
return; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we make sure we have unit tests for all of these for coverage?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sure. I added a new EnvoyClientSessionAllQuicVersionTest for this since none of the existing tests cover all QUIC versions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice work! Some thoughts inline.
@@ -158,7 +158,8 @@ void QuicFilterManagerConnectionImpl::maybeApplyDelayClosePolicy() { | |||
} | |||
|
|||
void QuicFilterManagerConnectionImpl::onConnectionCloseEvent( | |||
const quic::QuicConnectionCloseFrame& frame, quic::ConnectionCloseSource source) { | |||
const quic::QuicConnectionCloseFrame& frame, quic::ConnectionCloseSource source, | |||
quic::QuicTransportVersion version) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In general I'd prefer to plumb ParsedQuicVersion instead of QuicTransportVersion. We currently have a 1:1 mapping but that wasn't always the case and won't necessarily stay that way.
@@ -194,6 +194,12 @@ On the upstream side all http3 statistics are rooted at *cluster.<name>.http3.* | |||
rx_reset, Counter, Total number of reset stream frames received by Envoy | |||
tx_reset, Counter, Total number of reset stream frames transmitted by Envoy | |||
metadata_not_supported_error, Counter, Total number of metadata dropped during HTTP/3 encoding | |||
quic_version_43, Counter, Total number of quic connections that use transport version 43. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To clarify the plan from the QUIC side of things:
- The default version today is h3-29
- in some number of weeks, h3 (also called RFCv1 in parts of the code) will become the default version, and we plan on supporting that version for years to come
- h3-29 will stay supported for some number of months, but then we'll drop support
- version 43-51 will all be removed in some number of months
I'd suggest only supporting h3/RFCv1 when QUIC leaves Alpha in Envoy, as that's the only version we'll support long-term.
I think we have two options:
- Add all the current version here, and remove stats as we deprecate versions
- Add all the current version here, and have old version stats at 0 forever
- Only add h3-29 and h3 here, and when we remove h3-29 we'll keep that stat at 0 forever
I'd personally lean towards option 1 if that's acceptable to Envoy, but if that's not an option then I'd suggest option 3.
Signed-off-by: Renjie Tang <renjietang@google.com>
/retest |
Retrying Azure Pipelines: |
Signed-off-by: Renjie Tang <renjietang@google.com>
…bridge-stream * upstream/main: (268 commits) tools: adding dio,better comments (envoyproxy#17104) doc: fix misplaced #[extension-category] for Wasm runtimes (envoyproxy#17078) ci: Speedup deps precheck (envoyproxy#17102) doc: fix wrong link on wasm network filter. (envoyproxy#17079) docs: Added v3 API reference. (envoyproxy#17095) docs: Update include paths in repo (envoyproxy#17098) exception: make Ipv6Instance and Ipv4Instance not throw and remove some try catch pattern (envoyproxy#16122) tools: adding reminders for API shephards (envoyproxy#17081) ci: Fix wasm verify example (envoyproxy#17086) [fuzz]: fix oss fuzz bug 34515, limit maglev table size (envoyproxy#16671) test: silencing flaky test (envoyproxy#17084) Set `validate` flag when the SAN(SubjectAltName) matching is performed (envoyproxy#16816) Listener: reset the file event when destroying listener filters (envoyproxy#16952) docs: link additional filters that emit dynamic metadata (envoyproxy#17059) rds: add config reload time stat for rds (envoyproxy#17033) bazel: Use color by default for build and run commands (envoyproxy#17077) ci: Add timing for docker pull (envoyproxy#17074) [Windows] Adding note section in Original Source HTTP Filter (envoyproxy#17058) quic: add quic version counters in http3 codec stats. (envoyproxy#16943) quiche: change crypto stream factory interfaces (envoyproxy#17046) ... Signed-off-by: Garrett Bourg <bourg@squareup.com>
Commit Message: add quic version counters in http3 codec stats. Additional Description: Risk Level: Low Testing: Integration tests Docs Changes: docs/root/configuration/http/http_conn_man/stats.rst Signed-off-by: Renjie Tang <renjietang@google.com> Signed-off-by: chris.xin <xinchuantao@qq.com>
Commit Message: add quic version counters in http3 codec stats. Additional Description: Risk Level: Low Testing: Integration tests Docs Changes: docs/root/configuration/http/http_conn_man/stats.rst Signed-off-by: Renjie Tang <renjietang@google.com>
Signed-off-by: Renjie Tang renjietang@google.com
Commit Message: add quic version counters in http3 codec stats.
Additional Description:
Risk Level: Low
Testing: Integration tests
Docs Changes: docs/root/configuration/http/http_conn_man/stats.rst