-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
cb535d2
commit 7b41b2e
Showing
3 changed files
with
162 additions
and
1 deletion.
There are no files selected for viewing
67 changes: 67 additions & 0 deletions
67
.../manifests/configuring-cryostat-autoconfig_console.openshift.io_v1_consolequickstart.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
apiVersion: console.openshift.io/v1 | ||
kind: ConsoleQuickStart | ||
metadata: | ||
annotations: | ||
capability.openshift.io/name: Console | ||
name: configuring-cryostat-autoconfig | ||
spec: | ||
conclusion: Your Java application has now been configured to be detected by Cryostat. | ||
To profile your Java applications with Cryostat, please follow [this documentation](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/4/html/using_cryostat_to_manage_a_jfr_recording/index). | ||
description: Automatically configure your Java applications on OpenShift to be profiled | ||
and monitored using the Red Hat build of Cryostat and Cryostat Agent. | ||
displayName: Auto-configure Java applications with the Red Hat build of Cryostat | ||
durationMinutes: 10 | ||
icon:  | ||
introduction: |- | ||
Red Hat build of Cryostat is a container-native Java application based on JDK Flight Recorder (JFR). You can use it to monitor the performance of the Java Virtual Machine (JVM) for containerized workloads that run on an OpenShift cluster. | ||
- To enable Cryostat to gather, store, and analyze Java Flight Recorder (JFR) data about target applications that run on Java Virtual Machine (JVM)s, you must configure the applications so that Cryostat can detect and connect to them. | ||
- You can use Red Hat build of Cryostat Operator to automatically configure your target application to use the Cryostat Agent to register with a specific Cryostat instance and provide HTTP-based connectivity by following the **Auto-configure Java applications with the Red Hat build of Cryostat** quick start. | ||
- Alternatively, you can configure your Java applications to allow Java Management Extensions (JMX) connections and use an OpenShift Service for detection and JMX for connectivity. JMX is a standard feature on a JVM with which you can monitor and manage target applications that run on the JVM. You may enable and configure JMX when you start the target application JVM so that Red Hat build of Cryostat can communicate with your JVM over the network using built-in JDK functionality. Follow the **Configure JMX-based Java applications with the Red Hat build of Cryostat** quick start for instructions on that setup. | ||
- If you have not yet installed the Red Hat Build of Cryostat Operator, start with the **Get started with the Red Hat build of Cryostat** quick start. | ||
- **Note**: The quickstart uses a sample [Quarkus application](https://github.com/quarkusio/quarkus-quickstarts). You can deploy your own application or follow the **Get started with Quarkus using s2i** quick start. | ||
tasks: | ||
- description: | | ||
To enable Cryostat Agent instrumentation: | ||
1. In the main navigation, click the dropdown menu and select **Administrator**. | ||
1. In the navigation menu, click **Workloads > Deployments**. | ||
1. Click on the quarkus-quickstarts deployment name (or your application's deployment name). | ||
1. Click **YAML** | ||
Alternatively, | ||
1. In the main navigation, click the dropdown menu and select **Developer**. | ||
1. In the navigation menu, click **Topology**. | ||
1. Click on the quarkus-quickstarts deployment (or your application's deployment). | ||
1. Click **Actions > Edit Deployment**. | ||
1. Click **Configure via: > YAML view**. | ||
Then, | ||
1. In the text editor, add the following labels to the `.spec.template.metadata.labels` section: | ||
- **Name**: `cryostat.io/name` | ||
- **Value**: Set this to the name of your Cryostat Custom Resource instance. | ||
- **Name**: `cryostat.io/namespace` | ||
- **Value**: Set this to the installation namespace of your Cryostat Custom Resource instance. | ||
1. Click **Save.** | ||
review: | ||
failedTaskHelp: This task isn't verified yet. Try the task again, or [read more](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/3/html/getting_started_with_cryostat/configuring_java_applications#working_with_cryostat_agent) | ||
about this topic. | ||
instructions: | | ||
#### Click **Reload** at the bottom of the **YAML** tab. | ||
Do you see a the expected labels under the `.spec.template.metadata.labels`? | ||
title: Enable **Cryostat Agent instrumentation** on your Java Application | ||
- description: | | ||
View your Java application as a target in the Red Hat build of Cryostat web application: | ||
1. In the main navigation, click the dropdown menu and select **Developer**. | ||
1. In the navigation menu, click **Topology**. | ||
1. The external link icon on **cryostat-sample deployment** represents the route URL. | ||
1. Click the external link icon to open the URL and run the Cryostat web application in a new browser tab. | ||
1. Enter your Red Hat OpenShift credentials to log in to the Cryostat web application. | ||
1. In the web application, click **Recordings** in the navigation menu. | ||
1. View quarkus-quickstarts (or your deployed application) in the **Targets** list. | ||
review: | ||
failedTaskHelp: This task isn't verified yet. Try the task again, or [read more](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/4/html/getting_started_with_cryostat/configuring_java_applications) | ||
about this topic. | ||
instructions: |- | ||
#### Verify your Java application is running on Red Hat build of Cryostat web application: | ||
Did the Cryostat web application open in a separate browser window? | ||
title: View your Java Application as a target in Cryostat |
94 changes: 94 additions & 0 deletions
94
bundle/manifests/configuring-cryostat-jmx_console.openshift.io_v1_consolequickstart.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
apiVersion: console.openshift.io/v1 | ||
kind: ConsoleQuickStart | ||
metadata: | ||
annotations: | ||
capability.openshift.io/name: Console | ||
name: configuring-cryostat-jmx | ||
spec: | ||
conclusion: Your Java application has now been configured to be detected by Cryostat. | ||
To profile your Java applications with Cryostat, please follow [this documentation](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/4/html/using_cryostat_to_manage_a_jfr_recording/index). | ||
description: Configure your JMX-based Java applications on OpenShift to be profiled | ||
and monitored using the Red Hat build of Cryostat. | ||
displayName: Configure JMX-based Java applications with the Red Hat build of Cryostat | ||
durationMinutes: 10 | ||
icon:  | ||
introduction: |- | ||
Red Hat build of Cryostat is a container-native Java application based on JDK Flight Recorder (JFR). You can use it to monitor the performance of the Java Virtual Machine (JVM) for containerized workloads that run on an OpenShift cluster. | ||
- To enable Cryostat to gather, store, and analyze Java Flight Recorder (JFR) data about target applications that run on Java Virtual Machine (JVM)s, you must configure the applications so that Cryostat can detect and connect to them. | ||
- You can use Red Hat build of Cryostat Operator to automatically configure your target application to use the Cryostat Agent to register with a specific Cryostat instance and provide HTTP-based connectivity by following the **Auto-configure Java applications with the Red Hat build of Cryostat** quick start. | ||
- Alternatively, you can configure your Java applications to allow Java Management Extensions (JMX) connections and use an OpenShift Service for detection and JMX for connectivity. JMX is a standard feature on a JVM with which you can monitor and manage target applications that run on the JVM. You may enable and configure JMX when you start the target application JVM so that Red Hat build of Cryostat can communicate with your JVM over the network using built-in JDK functionality. This quick start will explain this JMX-based setup. | ||
- If you have not yet installed the Red Hat Build of Cryostat Operator, start with the **Get started with the Red Hat build of Cryostat** quick start. | ||
- **Note**: The quickstart uses a sample [Quarkus application](https://github.com/quarkusio/quarkus-quickstarts). You can deploy your own application or follow the **Get started with Quarkus using s2i** quick start. | ||
tasks: | ||
- description: | | ||
To enable remote JMX connections: | ||
1. In the main navigation, click the dropdown menu and select **Administrator**. | ||
1. In the navigation menu, click **Workloads > Deployments**. | ||
1. Click on the quarkus-quickstarts deployment name (or your application's deployment name). | ||
1. Click **Environment.** | ||
1. In the **Single values (env)** section, add the following environment variable: | ||
- **Name**: `JAVA_OPTS_APPEND` | ||
- **Value**: | ||
``` | ||
-Dcom.sun.management.jmxremote.port=9091 | ||
-Dcom.sun.management.jmxremote.authenticate=false | ||
-Dcom.sun.management.jmxremote.ssl=false | ||
``` | ||
Note: This method enables remote JMX without authentication. For details on configuring authentication with SSL/TLS for Remote JMX, see [Configuring Java applications](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/4/html/getting_started_with_cryostat/configuring_java_applications). | ||
1. Click **Save.** | ||
review: | ||
failedTaskHelp: This task isn't verified yet. Try the task again, or [read more](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/4/html/getting_started_with_cryostat/configuring_java_applications) | ||
about this topic. | ||
instructions: | | ||
#### Click **Reload** at the bottom of the **Environment** tab. | ||
Do you see a **single values entry** for **`JAVA_OPTS_APPEND`**? | ||
title: Enable **Remote Java Management Extensions (JMX) connections** on your | ||
Java Application | ||
- description: | | ||
To update Red Hat OpenShift Service with the remote JMX port: | ||
1. In the main navigation, click the dropdown menu and select **Administrator**. | ||
1. In the navigation menu, click **Networking > Services**. | ||
1. Click on the quarkus-quickstarts service name (or your application's service name). | ||
1. Click the “YAML” tab to open the YAML editor. | ||
1. In the **spec > ports** section, add a new port for jfr-jmx | ||
``` | ||
- name: jfr-jmx | ||
protocol: TCP | ||
port: 9091 | ||
targetPort: 9091 | ||
``` | ||
1. Click **Save**. | ||
review: | ||
failedTaskHelp: This task isn't verified yet. Try the task again, or [read more](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/4/html/getting_started_with_cryostat/configuring_java_applications) | ||
about this topic. | ||
instructions: | | ||
#### Verify that the service port is added to the sample resource: | ||
1. In the main navigation, click the dropdown menu and select **Developer**. | ||
1. In the navigation menu, click **Topology**. | ||
1. Click on the quarkus-quickstarts deployment name (or your application's service name). | ||
1. Click on the **Resources** tab. | ||
Do you see **Service port: jfr-jmx -> Pod port: 9091** in the quarkus-quickstarts service? | ||
title: Updating Red Hat OpenShift Service with the remote JMX port | ||
- description: | | ||
View your Java application as a target in the Red Hat build of Cryostat web application: | ||
1. In the main navigation, click the dropdown menu and select **Developer**. | ||
1. In the navigation menu, click **Topology**. | ||
1. The external link icon on **cryostat-sample deployment** represents the route URL. | ||
1. Click the external link icon to open the URL and run the Cryostat web application in a new browser tab. | ||
1. Enter your Red Hat OpenShift credentials to log in to the Cryostat web application. | ||
1. In the web application, click **Recordings** in the navigation menu. | ||
1. View quarkus-quickstarts (or your deployed application) in the **Targets** list. | ||
review: | ||
failedTaskHelp: This task isn't verified yet. Try the task again, or [read more](https://docs.redhat.com/en/documentation/red_hat_build_of_cryostat/4/html/getting_started_with_cryostat/configuring_java_applications) | ||
about this topic. | ||
instructions: |- | ||
#### Verify your Java application is running on Red Hat build of Cryostat web application: | ||
Did the Cryostat web application open in a separate browser window? | ||
title: View your Java Application as a target in Cryostat |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters