From e8e0bef0bd1c00bcc16d6a238a27c05263085a3b Mon Sep 17 00:00:00 2001 From: Elliott Baron Date: Fri, 24 Nov 2023 10:38:43 -0500 Subject: [PATCH] fix(openshift): update Quickstart text/formatting (#688) * fix(openshift): update Quickstart text/formatting * Update final task description * Add additional port verification step --- config/openshift/cryostat-quickstart.yaml | 187 +++++++++++++--------- 1 file changed, 110 insertions(+), 77 deletions(-) diff --git a/config/openshift/cryostat-quickstart.yaml b/config/openshift/cryostat-quickstart.yaml index 48b30716..67951887 100644 --- a/config/openshift/cryostat-quickstart.yaml +++ b/config/openshift/cryostat-quickstart.yaml @@ -7,86 +7,119 @@ metadata: spec: icon: >-  - title: Configure Java applications with the Red Hat build of Cryostat - conclusion: Your Java application has now been configured to be detected by Cryostat. To profile your Java applications with Cryostat, please follow this documentation. description: Configure your Java applications on OpenShift to be profiled and monitored using the Red Hat build of Cryostat. durationMinutes: 10 - displayName: Configuring Cryostat - 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. -
-- This requires you to 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 must enable and configure JMX when you start the JVM because Red Hat build of Cryostat requires the target applications to expose a JMX port, so that it can communicate with the target applications over this JMX port. Red Hat build of Cryostat starts and stops the JFR recordings and pulls the JFR data over the network, enabling it to store and analyze this JFR data. -
-
-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. -
-
-In this quick start, you will complete the following tasks: -
-1. Enable remote Java Management Extensions (JMX) connections on your Java application
-2. Update Red Hat OpenShift Services with the remote JMX port
-3. View your Java application as a target in the Red Hat build of Cryostat web application
-Note: The quickstart uses a sample [Quarkus application.](https://github.com/quarkusio/quarkus-quickstarts) You can deploy your own Quarkus application or follow the quarkus-with-s2i quick start.\ " + displayName: Configure Java applications with the Red Hat build of Cryostat + 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. + + - This requires you to 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 must enable and configure JMX when you start the JVM because Red Hat build of Cryostat requires the target applications to expose a JMX port, so that it can communicate with the target applications over this JMX port. Red Hat build of Cryostat starts and stops the JFR recordings and pulls the JFR data over the network, enabling it to store and analyze this JFR data. + + - 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 Quarkus 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.
-2. In the navigation menu, click **Workloads > Deployments.**
-3. Click on the quarkus-quickstarts deployment name (or your application’s deployment name).
-4. Click **Environment.**
-5. In the XXX window/panel, 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://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_configuing-java-applications_cryostat)

-6. Click **Save.**" - title: "Enable **Remote Java Management Extensions (JMX) connections** on your Java Application" - review: - failedTaskHelp: "This task isn’t verified yet. Try the task again." - instructions: |- - "Click **Reload** at the bottom of the **Environment** tab. - 1. Do you see a **single values entry** for **JAVA\_OPTS\_APPEND?**" - summary: - failed: This task isn’t verified yet. Try the task again. - success: You have enabled remote JMX connections. - - description: "To update Red Hat OpenShift Service with the remote JMX port:

In the main navigation, click the dropdown menu and select **Administrator.**
-2. In the navigation menu, click **Networking > Services.**
-3. Click on the quarkus-quickstarts service name (or your application’s service name).
-4. Click the “YAML” tab to open the YAML editor.
-5. In the **spec > ports** section, add a new port for jfr-jmx
-/code
-- name: jfr-jmx
- protocol: TCP
- port: 9091
- targetPort: 9091
-6. Click **Save**.
" - title: "Updating Red Hat OpenShift Service with the remote JMX port:" + - 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://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_configuing-java-applications_cryostat). + + 1. Click **Save.** + title: Enable **Remote Java Management Extensions (JMX) connections** on your Java Application review: - failedTaskHelp: "This task isn't verified yet. Try the task again, or read more 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.**
- 2. In the navigation menu, click **Topology.**
- 3. Click **Cryostat-sample pod > Resources.**
" - summary: - failed: "This task isn't verified yet. Try the task again, or [read more](https://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_configuing-java-applications_cryostat) about this topic." - success: "You have updated the 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. Click on the perspective switcher at the top of the navigation, and select **Developer.**
-2. In the navigation menu, click **Topology.**

The external link icon on **cryostat-sample deployment** represents the route URL. Click on the external link icon to open the URL and run the Cryostat web application in a new browser tab.
-3. Click the external link icon to open the URL and run the Cryostat web application in a new browser tab. -4. Enter your Red Hat OpenShift credentials to log in to the Cryostat web application.
-5. In the web application, click **Recordings** in the navigation menu.
-6. View quarkus-quickstarts (or your deployed application) in the **Targets** list.

-Your Java application has now been configured to be detected by Cryostat. To profile your Java applications with Cryostat, please follow [this documentation.](https://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_creating-recordings_assembly_configuing-java-applications)" - title: "View your Java Application as a target in Cryostat" + failedTaskHelp: >- + This task isn't verified yet. Try the task again, or [read + more](https://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_configuing-java-applications_cryostat) + about this topic. + instructions: > + #### Click **Reload** at the bottom of the **Environment** tab. + + Do you see a **single values entry** for **`JAVA_OPTS_APPEND`**? + - 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**. + title: Updating Red Hat OpenShift Service with the remote JMX port + review: + failedTaskHelp: >- + This task isn't verified yet. Try the task again, or [read + more](https://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_configuing-java-applications_cryostat) + 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? + - 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. + title: View your Java Application as a target in Cryostat review: - failedTaskHelp: "This task isn't verified yet. Try the task again, or read more about this topic." + failedTaskHelp: >- + This task isn't verified yet. Try the task again, or [read + more](https://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_configuing-java-applications_cryostat) + about this topic. instructions: |- - "Verify your Java application is running on Red Hat build of Cryostat web application:

- Did your Java application open in a separate browser window?" - conclusion: >- - "Red Hat build of Cryostat is now configured." + #### 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? + 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://access.redhat.com/documentation/en-us/red_hat_build_of_cryostat/2/html/getting_started_with_cryostat/assembly_creating-recordings_assembly_configuing-java-applications).