Skip to content
This repository has been archived by the owner on Jul 28, 2023. It is now read-only.

Commit

Permalink
Merge pull request #34 from ellen-lau/updateLogMon0.7
Browse files Browse the repository at this point in the history
Update Kabanero Logging/Monitoring guides for OCP 4.3, release 0.7.0
  • Loading branch information
jantley-ibm authored Apr 8, 2020
2 parents c90d7c1 + d206f3d commit 6a8b9e3
Show file tree
Hide file tree
Showing 2 changed files with 89 additions and 13 deletions.
8 changes: 4 additions & 4 deletions publish/app-logging-ocp-4.2/app-logging-ocp-4.2.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
---
permalink: /guides/app-logging-ocp-4-2/
layout: guide-markdown
title: Application Logging with Elasticsearch, Fluentd, and Kibana
title: Application Logging on Red Hat OpenShift Container Platform (RHOCP) 4.3 with Elasticsearch, Fluentd, and Kibana
duration: 30 minutes
releasedate: 2020-02-19
releasedate: 2020-03-26
description: Learn how to do application logging with Elasticsearch, Fluentd, and Kibana.
tags: ['logging', 'Elasticsearch', 'Fluentd', 'Kibana']
guide-category: basic
Expand Down Expand Up @@ -32,7 +32,7 @@ guide-category: basic
//
-->

**The following guide has been tested with Red Hat OpenShift Container Platform (RHOCP) 4.2/Kabanero 0.3.0.**
**The following guide has been tested with Red Hat OpenShift Container Platform (RHOCP) 4.2/Kabanero 0.3.0 and RHOCP 4.3/Kabanero 0.6.0.**

Pod processes running in Kubernetes frequently produce logs. To effectively manage this log data and ensure no loss of log data occurs when a pod terminates, a log aggregation tool should be deployed on the Kubernetes cluster. Log aggregation tools help users persist, search, and visualize the log data that is gathered from the pods across the cluster. Log aggregation tools in the market today include: EFK, LogDNA, Splunk, Datadog, IBM Operations Analytics, etc. When considering log aggregation tools, enterprises will make choices that are inclusive of their journey to cloud, both new cloud native applications running in Kubernetes and their existing traditional IT choices.

Expand All @@ -46,7 +46,7 @@ One choice for application logging with log aggregation, based on open source, i

## Install cluster logging

To install the cluster logging component, follow the OpenShift guide [Deploying cluster logging](https://docs.openshift.com/container-platform/4.2/logging/cluster-logging-deploying.html)
To install the cluster logging component, follow the OpenShift guide [Deploying cluster logging](https://docs.openshift.com/container-platform/4.3/logging/cluster-logging-deploying.html)

After the installation completes without any error, you can see the following pods that are running in the *openshift-logging* namespace. The exact number of pods running for each of the EFK components can vary depending on the configuration specified in the ClusterLogging Custom Resource (CR).

Expand Down
94 changes: 85 additions & 9 deletions publish/app-monitoring-ocp-4.2/app-monitoring-ocp-4.2.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,18 @@ permalink: /guides/app-monitoring-ocp4.2/
:projectid: ocp-app-monitoring
:page-layout: guide-multipane
:page-duration: 60 minutes
:page-releasedate: 2020-02-02
:page-releasedate: 2020-03-26
:page-guide-category: basic
:page-description: Learn how to monitor applications on RHOCP 4.2 with Prometheus and Grafana.
:page-tags: ['monitoring', 'prometheus', 'grafana']
= Application Monitoring on Red Hat OpenShift Container Platform (RHOCP) 4.2 with Prometheus and Grafana
= Application Monitoring on Red Hat OpenShift Container Platform (RHOCP) 4.3 with Prometheus and Grafana

== Introduction

__The following guide has been tested with RHOCP 4.2/Kabanero 0.3.0.__
__The following guide has been tested with RHOCP 4.2/Kabanero 0.3.0 and RHOCP 4.3/Kabanero 0.6.0.__


For application monitoring on RHOCP, you need to set up your own Prometheus and Grafana deployments. Both Prometheus and Grafana can be set up via Operator Lifecycle Manager (OLM).
For application monitoring on RHOCP, you need to set up your own Prometheus and Grafana deployments. Both Prometheus and Grafana can be set up via Operator Lifecycle Manager (OLM).

=== Deploy an Application with MP Metrics Endpoint
Prior to deploying Prometheus, ensure that there is a running application that has a service endpoint for outputting metrics in Prometheus format.
Expand Down Expand Up @@ -43,11 +43,11 @@ include::code/prometheus.yaml[]
----


The Prometheus Operator is an open-source project originating from CoreOS and exists as a part of their Kubernetes Operator framework. The Kubernetes Operator framework is the preferred way to deploy Prometheus on a Kubernetes system. When the Prometheus Operator is installed on the Kubernetes system, you no longer need to hand-configure the Prometheus configuration. Instead, you create CoreOS ServiceMonitor resources for each of the service endpoints that needs to be monitored: this makes daily maintenance of the Prometheus server a lot easier. An architecture overview of the Prometheus Operator is shown below:
The Prometheus Operator is an open-source project originating from CoreOS and exists as a part of their Kubernetes Operator framework. When the Prometheus Operator is installed on the Kubernetes system, you no longer need to hand-configure the Prometheus configuration. Instead, you create CoreOS ServiceMonitor resources for each of the service endpoints that needs to be monitored: this makes daily maintenance of the Prometheus server a lot easier. An architecture overview of the Prometheus Operator is shown below:

image::/img/guide/prometheusOperator.png[link="/img/guide/prometheusOperator.png" alt="Prometheus Operator"]

Using Operator Lifecycle Manager (OLM), Prometheus operator can be easily installed and configured in RHOCP Web Console.
Using Operator Lifecycle Manager (OLM), Prometheus operator can be easily installed and configured in RHOCP Web Console.

=== Install Prometheus Operator Using Operator Lifecycle Manager (OLM)

Expand All @@ -72,7 +72,7 @@ Refer to the `service_monitor.yaml` file
----
+

. Create a Service Account with Cluster role and Cluster role binding to ensure you have the permission to get nodes and pods in other namespaces at the cluster scope. Refer to [hotspot file=1]`service_account.yaml`. Create the YAML file and apply it.
. Create a Prometheus Service Account and Cluster Role, and define a Cluster Role Binding to bind the two together. This is to ensure Prometheus has cluster-wide access to the metrics endpoint on pods in other namespaces. Refer to [hotspot file=1]`service_account.yaml`. Create the YAML file and apply it.
+
[role=command]
----
Expand All @@ -82,7 +82,7 @@ oc apply -f service_account.yaml

. Click on Overview and create a Prometheus instance. A Prometheus resource can scrape the targets defined in the ServiceMonitor resource.

. Inside the Prometheus YAML file, make sure *metadata.namespace* is prometheus-operator. Ensure *spec.serviceAccountName* is the Service Account's name that you have applied in the previous step. You can set the match expression to select which Service Monitors you are interested in under *spec.serviceMonitorSelector.matchExpressions* as in [hotspot file=2]`prometheus.yaml` file.
. Inside the Prometheus YAML file, make sure *metadata.namespace* is prometheus-operator. Ensure *spec.serviceAccountName* is the Service Account's name that you have applied in the previous step. You can set the match expression to select which service monitors you are interested in under *spec.serviceMonitorSelector.matchExpressions* as in [hotspot file=2]`prometheus.yaml` file.
+
[role="code_command hotspot file=2", subs="quotes"]
----
Expand Down Expand Up @@ -190,11 +190,87 @@ Apply `grafana_dashboard.yaml` file to check
----
+

. Click on Networking > Routes and go to Grafana's location to see the template dashboard. You can now consume all the application metrics gathered by Prometheus on the Grafana dashboard.
. Click on Networking > Routes and go to Grafana's location to see the sample dashboard. You can now consume all the application metrics gathered by Prometheus on the Grafana dashboard.

image::/img/guide/template_grafana_dashboard.png[link="/img/guide/template_grafana_dashboard.png" alt="Template Dashboard"]

[start=10]

. When importing your own Grafana dashboard, your dashboard should be configured under *spec.json* in Grafana Dashboard YAML file. Make sure under *"__inputs"*, the name matches with your Grafana Data Source's *spec.datasources*. For example, inside [hotspot file=2]`grafana_dashboard.yaml` file, *name* is set to "Prometheus".


== Configure Prometheus Operator to Detect Service Monitors in Other Namespaces

By default, the Prometheus Operator only watches the namespace it currently resides in, so in order to get the Prometheus Operator to detect service monitors created in other namespaces, you must apply the following configuration changes.

. In your monitoring namespace - in this case, the monitoring namespace is `prometheus-operator` - edit the OperatorGroup to add your application's namespace, for example, `myapp`, to the list of targeted namesaces to be watched. This will change the *olm.targetNamespaces* variable that the Prometheus Operator uses for detecting namespaces to include your `myapp` namespace.
+
[role="command"]
----
oc edit operatorgroup
----
+

+
[source,role="no_copy"]
----
spec:
  targetNamespaces:
  - prometheus-operator
  - myapp
----
+

. Since we have changed the `prometheus-operator` namespace's OperatorGroup to monitor more than one namespace, the operators in this namespace must have the *MultiNamespace* installMode set to *true*. Prometheus Operator installed via OLM has the *MultiNamespace* installMode set to *false* by default, disabling monitoring for more than one namespace, so this must be changed to *true*.
+
[role="command"]
----
oc edit csv prometheusoperator.0.32.0
----
+

+
[source,role="no_copy"]
----
spec:
  installModes:
  - supported: true
    type: OwnNamespace
  - supported: true
    type: SingleNamespace
  - supported: true # this line should be true
    type: MultiNamespace
  - supported: false
    type: AllNamespaces
----
+

. The same goes for the Grafana Operator, the *MultiNamespace* installMode should be set to *true*; edit the operator using:
+
[role="command"]
----
oc edit csv grafana-operator.v2.0.0 
----
+

. Edit the Prometheus instance to add the *serviceMonitorNamespaceSelector* definition. The empty brackets *{}* allow Prometheus to scrape from *all* namespaces:
+
[role="command"]
----
oc edit prometheuses.monitoring.coreos.com prometheus
----
+

+
[source,role="no_copy"]
----
spec:
  serviceMonitorNamespaceSelector: {}
----
+

. Restart the Prometheus Operator and Grafana Operator pods to see the changes.

== Installation Complete

You now have the Prometheus and Grafana stack installed and configured to monitor your applications. Import custom dashboards and visit the Grafana route to see your metrics visualized.

0 comments on commit 6a8b9e3

Please sign in to comment.