

Custom JFR event templates with Cryostat 2.0
source link: https://developers.redhat.com/articles/2021/11/16/custom-jfr-event-templates-cryostat-20
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

Custom JFR event templates with Cryostat 2.0 Skip to main content
Welcome back to our series of hands-on introductions to using Cryostat 2.0. This article shows you how to preconfigure custom event templates for Java application monitoring with JDK Flight Recorder (JFR). First, you'll use the new Cryostat Operator and a Red Hat OpenShift ConfigMap
to create a custom event template, then you'll instruct the Cryostat Operator to use the ConfigMap
when deploying Cryostat. You can use the OpenShift console to interact with Cryostat or edit the YAML file for your Cryostat custom resource. We'll demonstrate both approaches.
Note: Cryostat is JDK Flight Recorder for Kubernetes or Red Hat OpenShift. The Red Hat build of Cryostat 2.0 is now widely available in technology preview. Cryostat 2.0 introduces many new features and improvements, such as automated rules, a better API response JSON format, custom targets, concurrent target JMX connections, WebSocket push notifications, and more. The Red Hat build includes the Cryostat Operator to simplify and automate Cryostat deployment on OpenShift.
Create a custom template and ConfigMap
Create a custom template and ConfigMap
With Cryostat, you can download existing template files directly from a Java virtual machine (JVM). Once you've downloaded a template file to your local machine, you can use the JDK Mission Control (JMC) Template Manager to easily edit the template to suit your needs.
After customizing the template file, it's fairly simple to create a ConfigMap
from it. This ConfigMap
stores the template file inside of the cluster where Cryostat will run. You can use oc
or kubectl
in the namespace where Cryostat is to be deployed. Here's the source if you use the former:
$ oc create configmap my-template --from-file=/path/to/custom.jfc
This command creates a ConfigMap
named my-template
from a file on your local machine, located at /path/to/custom.jfc
. The file will be placed inside the ConfigMap
under the custom.jfc
filename.
Add your ConfigMap to the Cryostat Operator
Add your ConfigMap to the Cryostat Operator
Once you've created a ConfigMap
, you only need to instruct the Cryostat Operator to use it when deploying Cryostat. You can do this when you create a Cryostat custom resource, or by updating an existing one. If you're installing Cryostat using the OpenShift console, select Event Templates under the Cryostat custom resource that you want to update. Choose Add Event Template. The Config Map Name drop-down list will display all ConfigMap
s in the local namespace. Select the ConfigMap
containing the event template you just created. For Filename, enter the name of the .jfc
file within the ConfigMap
. In Figure 1, we're using custom.jfc
, which we created in the previous section.
You can also work directly with the YAML for the Cryostat custom resource. The process is similar to what you did in the console. Add an eventTemplates
property to the spec
section, if one isn't already present. Then, add an array entry with configMapName
referencing the name of the ConfigMap
, and a filename
referencing the filename within the ConfigMap
. The YAML below mirrors what we did in the OpenShift console example in Figure 1.
apiVersion: operator.cryostat.io/v1beta1
kind: Cryostat
metadata:
name: cryostat-sample
spec:
eventTemplates:
- configMapName: custom-template
filename: my-template.jfc
Once you've saved your changes to the Cryostat custom resource, the Cryostat Operator will deploy Cryostat with this template preconfigured. Visiting the Cryostat web application will show that the template is present and available to use for creating new JDK flight recordings, as you can see in Figure 2.
Conclusion
In this article, you've learned how to preconfigure Cryostat with customized event templates using OpenShift ConfigMap
s. You can use customized templates to gather the specific data you need in your JDK flight recordings. Visit Cryostat.io and see the other articles in this series for further details:
Recommend
-
12
JFR 定位因为 SSL 导致 CPU Load 飚高的问题JFR 定位因为 SSL 导致 CPU Load 飚高的问题张哈希2天前 在某一时刻,某个微服务的某个实例 CPU 负载突然...
-
6
By Marcus Hirt and JP Bempel Since JDK 14 there is a new JFR kid on the block – JFR streaming.
-
10
JFR is Coming to OpenJDK 8! I recently realized that this isn’t common knowledge, so I thought I’d take the opportunity to talk about the JDK Flight Recorder coming to OpenJDK 8! The backport is a collaboration between Red H...
-
8
AuthorsErik Gahlin, Markus GrönlundOwnerErik GahlinTypeFeatureScopeJDKStatusClosed / DeliveredRelease14Componenthotspot / jfrDiscussionhotspot dash jfr dash dev at openjdk dot java dot netEffortMDurationSReviewed byKaren Kinnear, Mikael Vidstedt...
-
7
重新申请 TLAB 分配对象事件:jdk.ObjectAllocationOutsideTLAB 引入版本:Java 11 相关 ISSUES:
-
6
Java monitoring for custom targets with Cryostat Skip to main content By default, Cryostat automatically r...
-
5
JFR Event Sizes May 9, 2021 | tracingRSS For the last few years it has...
-
6
Manage JFR across instances with Cryostat and GraphQL Skip to main content
-
5
Continuous Profiling for Java applications Profiling a Java Rideshare App with Pyroscope Note: For documentation on Pyroscope's java integration visit our website for java...
-
11
Using AI to Create JFR Event Descriptions JFR (JDK Flight Recorder) is the default profiler for OpenJDK (see my other blog po...
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK