JDK 25, to be released on September 16, is set to include three new Java Enhancement Proposals (JEPs) for JFR and several enhancements to the jdk.jfr API and the jfr command.
JEP 518: JFR Cooperative Sampling
JEP 518: JFR Cooperative Sampling reworks the method sampling mechanism in the HotSpot JVM. Stack walking now happens from a safepoint, but without the safepoint bias that JVM TI-based profilers suffer from. The result is safer stack walking with ZGC and a more scalable method sampler that supports concurrent stack walking. The JEP also adds a new experimental event, SafepointLatency, which records the time it takes for a thread to reach a safepoint. You can enable it on the command line as follows:
JEP 509: JFR CPU-Time Profiling (Experimental)
JEP 509: JFR CPU-Time Profiling (Experimental) introduces an experimental Linux-only event that uses SIGPROF to record method samples. The current method sampling event, jdk.ExecutionSample, works on all platforms, but it only samples methods running Java code. The new jdk.CPUTimeSample event also takes into account methods executing in native code, for example, a call to a native method using the new FFM API. The feature builds on JEP 518: JFR Cooperative Sampling to ensure that stacks can be walked safely. To try out CPU-time profiling on Linux, use the following commands:
The JEP is still out for review, but if it is integrated in time for Rampdown Phase One, it will be available in JDK 25.
JEP 520: JFR Method Timing & Tracing
JEP 520: JFR Method Timing & Tracing adds two new events to trace and time methods. Timing and tracing method invocations can help identify performance bottlenecks, optimize code, and find the root causes of bugs. The JEP text demonstrates several command-line examples, so they will not be repeated here. Instead, I will display a simple GUI I created to validate the design and to demonstrate how third-party tools can use the JFR APIs with the two new the events.

The source code will be available on GitHub when early-access builds are released (build 26), allowing you to run the application as shown below:
The application is Swing-based and can connect to either a local or remote application over JMX. It uses JFR Event Streaming and Remote Recording Streaming for data transfer. If you find issues with the JEP, please report them to the hotspot-jfr-dev mailing list or send a direct message to @ErikGahlin.
Updates to the jfr command
The jfr scrub command is used to remove sensitive information, such as values stored in system properties or environment variables, from a JFR recording file. Previously, verifying the results of the command required using the jfr summary command to compare files before and after scrubbing. In JDK 25, the jfr scrub command has been updated to print the number of events that were removed, making it easier to verify that sensitive information has been redacted. For example:
Another update to the jfr tool is the new print –exact option. It prints timestamps, timespans, and memory data with full precision. For example:
Exact values are useful for comparing results across multiple runs or for including precise information in bug reports. See the CSR for more details.
New report-on-exit Option
The -XX:StartFlightRecording option gets a new sub-option called report-on-exit that prints a report/view when the JVM exits. For more information about views, see my earlier blog post. In the following example, the new method timing event is used to print the time it took for class initializers to execute, which can be useful when optimizing the startup time of your application.
Another example of the report-on-exit option is to print a summary of GC pauses when the application exits:
For more information about the feature, see the CSR, or use the new -XX:StartFlightRecording:help command, introduced in JDK 24.
Rate-limited Sampling
JDK 25 will add support for Rate-limited sampling of Java events. For example, you may want to track data that is posted to a queue at a very high frequency. Recording every event may result in the recording file becoming filled with queue-related events, potentially displacing other important data. By annotating your event with @Throttle, you can set an upper limit on the number of events per time unit. For example:
Event objects that are throttled cannot be reused because they must hold their sample state between a call to shouldCommit() and commit(). Like other event settings, throttling can be controlled from the command line. The following example shows how throttling can be disabled so that all events are emitted:
Contextual Events
JDK 25 comes with a new annotation to help tools visualize contextual information. Contextual information here refers to data shared across all events in the same thread during the lifespan of an event annotated with @Contextual.
For example, to trace requests or transactions in a system, a trace event can be created to provide context.
To track details within an order service, an order event can be created where only the order ID provides context.
If an order in the order service stalls due to lock contention, a user interface can display contextual information together with the JavaMonitorEnter event to simplify troubleshooting, for example:
Removal of the Security Manager
With JDK 24, the Security Manager was permanently disabled, which allowed for the removal of around 3,000 lines of JFR code in JDK 25. You may notice this as faster startup when using JFR, as the number of classes that need to be loaded is reduced. But more importantly, OpenJDK developers no longer need to analyze every new feature to make it work with the Security Manager.
Going forward, expect a more rapid stream of enhancements!
.png)
 4 months ago
                                14
                        4 months ago
                                14
                     
  

