Prometheus is started to be the emerging solution to monitor OpenShift. We won’t discuss in this article how to set up Prometheus for OpenShift, because some articles already exist about this topic. You can check this git repository how to install it Prometheus on OpenShift with Grafana dashboards and Alert Manager enabled on how to install it Prometheus on OpenShift with Grafana dashboards and Alert Manager enabled.

When installed on OpenShift, Prometheus can run as a single pod and it will grab (or say scrap in the prometheus terminology) metrics from different providers (or exporters in the prometheus wording). In this git repository, we set up node-exporter as a provider from Prometheus to get metrics on nodes and have alerts and grafana dashboards to monitor them. It also comes with some basic alerts that checks node’s filesystem or CPU usage.

When you run OpenShift, it is very very valuable to monitor your pods restarts. Because, many restarts is often a sign of a malfunction. To do so, we deploy another exporter that exposes a convenient set of metrics from kubernetes API. Fortunately, there is a kubernetes project named kube-state-metrics which exposes these metrics.

The kube-state-metrics needs to be deployed as DeploymentConfig and exposed as a service. Then, annonate this service so it can be to be scraped by prometheus:

oc create -f - << EOF
apiVersion: v1
kind: DeploymentConfig
  namespace: monitoring
  name: kube-state-metrics
  replicas: 1
        name: kube-state-metrics
      - name: kube-state-metrics
        imagePullPolicy: IfNotPresent
        - containerPort: 8080
oc expose dc kube-state-metrics --port=8080
oc annotate svc kube-state-metrics'true'

Then, you can define the following alert, and you will be notified every time your pod restarts more than once in the last 5 minutes:

pod-restart.rules: |
  ALERT PodRestartingTooOften
    IF rate(kube_pod_container_status_restarts[2h]) * 7200 > 1
    FOR 1m
    LABELS {severity="page"}
    ANNOTATIONS {DESCRIPTION="Pod {{$labels.namespace}}/{{$labels.pod}} restarting more than once times during last 2 hours.",
    SUMMARY="Pod {{$labels.namespace}}/{{$labels.pod}} restarting more than once times during last 2 hours."}
Last modified: 4th August 2017



Write a Reply or Comment

Your email address will not be published.