Skip to content
Advertisement

Java Flight Recorder – Continuous rolling recording

Question

How to get a rolling recording into disk, with a maximum age?

Context

When something goes bad in my server, I want to be able to dump the profiling information of the hours prior and analyse it, to know what went wrong.

  1. As I don’t know when things will go bad, the JDK should be continuously saving the events to disk.
  2. As the server is not rebooted often, to avoid the files growing unbounded, I need to set some sort of cap (either age, or size).

So, in other words, I wanted the JDK to save the recordings continuously to disk, but remove the older files/recordings such that the total amount remains under a certain threshold (age or size).

To that end, these are the options I have for version Oracle JDK 1.8.0_144:

-XX:+UnlockCommercialFeatures
-XX:+FlightRecorder
-XX:StartFlightRecording
   name=<foo-bar>
-XX:FlightRecorderOptions
   defaultrecording=true   // what does this do even?
   disk=true
   maxage=1h // this is what I thought would solve my problem! 
   repository=<path-to-where-I-want-the-recording>
   maxchunksize=5M

I would have thought that setting maxage=1h would only keep the last 1 hour of recording on disk. But no! Its been past 1 day, and the files are not being capped.

At the same time the maxchunksize appears to work. The various .jfr files have approximately 5M. Of which there are many such files, since the the age capped is not being enforced.

What am I doing wrong?

Advertisement

Answer

The problem, I think, is that you are starting two recordings, one with-XX:StartFlightRecording and one with -XX:FlightRecorderOptions=defaultrecording=true.

The one with -XX:StartFlightRecording is unbounded. I think the following would be appropriate option for Oracle JDK 1.8.0_144 and your use case:

-XX:+UnlockCommercialFeatures
-XX:FlightRecorderOptions=repository=<path>
-XX:StartFlightRecording=maxage=1h,name=<name>

-XX:+UnlockCommercialFeatures is needed because JFR is a commercial feature in Oracle JDK 8. From JDK 11, it’s no longer needed.

-XX:+FlightRecorder is not needed with -XX:StartFlightRecoding for JDK 8u40 or later. The JFR buffers are now setup when the first recording is started, not when the JVM starts. If a recording is started with defaultrecording=true, -XX:+FlightRecorder is still needed.

-XX:FlightRecorderOptions=defaultrecording=true does a lot of things, mostly for historical reasons, but only needed when doing in-memory recordings. From JDK 9, the option is never needed and has been removed.

-XX:FlightRecorderOptions=disk=true,maxage=1h isn’t needed if -XX:StartFlightRecording is used, which is the recommended way to start JFR.

Unless you have an issue, I would keep the maxchunksize at the default (12 MB). It’s the chunk files size JFR has been optimized for and tested against.

User contributions licensed under: CC BY-SA
3 People found this is helpful
Advertisement