-
Notifications
You must be signed in to change notification settings - Fork 565
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
Add metrics related to virtual threads #9619
Conversation
Some general questions @tjquinno ...
Is there also a counter for platform threads?
Under what conditions would this counter be incremented? |
...system-meters/src/main/java/io/helidon/metrics/systemmeters/VThreadSystemMetersProvider.java
Show resolved
Hide resolved
@@ -1,5 +1,5 @@ | |||
/* | |||
* Copyright (c) 2023 Oracle and/or its affiliates. | |||
* Copyright (c) 2023, 2024 Oracle and/or its affiliates. | |||
* |
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.
Just a copyright update?
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.
This is a remnant from an earlier iteration of the change I was contemplating. Not needed.
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.
Fixed. File no longer in the changed list.
...system-meters/src/main/java/io/helidon/metrics/systemmeters/VThreadSystemMetersProvider.java
Show resolved
Hide resolved
The existing Helidon built-in meters created in `SystemMetersProvider.java include some platform-thread related ones:
This JMX MBean makes a number of other thread-related values available: Probably the most useful value that's available we don't currently expose is the total started thread count. We could add that.
I don't have an interesting example of the value. Here is an example of the output, taken from the updated doc that's part of this PR (obviously with no interesting output): "vthreads.recentPinned": {
"count": 0,
"max": 0.0,
"mean": 0.0,
"total": 0.0,
"p0.5": 0.0,
"p0.75": 0.0,
"p0.95": 0.0,
"p0.98": 0.0,
"p0.99": 0.0,
"p0.999": 0.0
},
Here's what the Java Flight Recorded doc says about the value it reports about pinned virtual threads.
See the previous link. |
…e file unchanged except for copyright date
67800cc
to
8040b24
Compare
The latest push accomplished:
|
…ecause the virtual threads recentPinned meter is now a timer
Few comments,
In JFR stream or JFR, the details as to which events are captured, threshold used for each event , stack capture etc depends on settings used to create the Recording (RecordingStream internally creates Recording) . JDK ships with 2 settings "default" and "profile". Below are settings for ”jdk.VirtualThreadPinned” event in JDK bundled settings "default" and "profile" . This would means when these settings are used, a Pinned JFR event would be recorded only for cases where the carrier thread was pinned for 20ms or longer.
However many cases the system also run with custom settings via custom JFC file, and can can customise settings for both built-in JDK provided as well as custom defined JFR events. 2 ”jdk.VirtualThreadPinned” JFR events are not generated for all pinning cases. For example carrier thread also get pinned in Java-21 when the vthread mounted on them execute Object.wait(). But these do not generate ”jdk.VirtualThreadPinned”. Same is true for pinning due to blocking operation in class initialiser ( for ex : static blocks), or pining due to certain blocking operation in native code. So primarily, we get pinning events only for blocking operation from sync blocks. I guess this is more for information/documentation purposes, so that one doesn't assume all pinning events are reported by this metric. |
We looked into this earlier and to get initial support for meters related to virtual threads in place quickly with the simplest ease-of-use we implemented the feature as written. Some examples of the complexities:
All doable, but for the first implementation we chose to simplify things. I've had this sort of enhancement in mind but finally recorded it as an issue: #9652 (generally more likely to get visibility than comments on a previously-merged PR). Add any further comments you might have there. |
Description
Resolves #9533
New meters related to virtual thread usage
The virtual thread count meters are disabled by default for performance reasons. Enable them by setting
metrics.virtual-threads.count.enabled=true
in configuration, but be aware doing so can degrade the server's performance.New meter related to platform threads
Helidon also now exposes the new system meter
thread.starts
which displays the total number of platform thread starts performed in the JVM since server start-up.The PR adds a new
MetersProvider
implementation to thehelidon-metrics-system-meters
component. The new implementation registers for selected Java Flight Recorder events to track data related to virtual threads.The three virtual thread meters that are enabled by default should be rare so monitoring the JFR events for them adds very little overhead. In contrast, to maintain the current number of active virtual threads and the total number of virtual thread starts the added code must register for and respond to virtual thread start and end events which can be costly. That's why those two meters--and the registration of listeners for those events from JFR--are disabled by default.
Documentation
Small additions to the SE and MP metrics guide and doc pages.