This is a cache of https://docs.okd.io/4.11/scalability_and_performance/scaling-cluster-monitoring-operator.html. It is a snapshot of the page at 2025-01-19T20:44:31.425+0000.
Scaling the Cluster Monitoring Operator | Scalability and performance | OKD 4.11
×

OKD exposes metrics that the Cluster Monitoring Operator collects and stores in the prometheus-based monitoring stack. As an administrator, you can view dashboards for system resources, containers, and components metrics in the OKD web console by navigating to ObserveDashboards.

prometheus database storage requirements

Red Hat performed various tests for different scale sizes.

The prometheus storage requirements below are not prescriptive and should be used as a reference. Higher resource consumption might be observed in your cluster depending on workload activity and resource density, including the number of pods, containers, routes, or other resources exposing metrics collected by prometheus.

Table 1. prometheus Database storage requirements based on number of nodes/pods in the cluster
Number of Nodes Number of pods (2 containers per pod) prometheus storage growth per day prometheus storage growth per 15 days Network (per tsdb chunk)

50

1800

6.3 GB

94 GB

16 MB

100

3600

13 GB

195 GB

26 MB

150

5400

19 GB

283 GB

36 MB

200

7200

25 GB

375 GB

46 MB

Approximately 20 percent of the expected size was added as overhead to ensure that the storage requirements do not exceed the calculated value.

The above calculation is for the default OKD Cluster Monitoring Operator.

CPU utilization has minor impact. The ratio is approximately 1 core out of 40 per 50 nodes and 1800 pods.

Recommendations for OKD

  • Use at least two infrastructure (infra) nodes.

  • Use at least three openshift-container-storage nodes with non-volatile memory express (SSD or NVMe) drives.

Configuring cluster monitoring

You can increase the storage capacity for the prometheus component in the cluster monitoring stack.

Procedure

To increase the storage capacity for prometheus:

  1. Create a YAML configuration file, cluster-monitoring-config.yaml. For example:

    apiVersion: v1
    kind: ConfigMap
    data:
      config.yaml: |
        prometheusK8s:
          retention: {{prometheus_RETENTION_PERIOD}} (1)
          nodeSelector:
            node-role.kubernetes.io/infra: ""
          volumeClaimTemplate:
            spec:
              storageClassName: {{STORAGE_CLASS}} (2)
              resources:
                requests:
                  storage: {{prometheus_STORAGE_SIZE}} (3)
        alertmanagerMain:
          nodeSelector:
            node-role.kubernetes.io/infra: ""
          volumeClaimTemplate:
            spec:
              storageClassName: {{STORAGE_CLASS}} (2)
              resources:
                requests:
                  storage: {{ALERTMANAGER_STORAGE_SIZE}} (4)
    metadata:
      name: cluster-monitoring-config
      namespace: openshift-monitoring
    1 The default value of prometheus retention is prometheus_RETENTION_PERIOD=15d. Units are measured in time using one of these suffixes: s, m, h, d.
    2 The storage class for your cluster.
    3 A typical value is prometheus_STORAGE_SIZE=2000Gi. Storage values can be a plain integer or a fixed-point integer using one of these suffixes: E, P, T, G, M, K. You can also use the power-of-two equivalents: Ei, Pi, Ti, Gi, Mi, Ki.
    4 A typical value is ALERTMANAGER_STORAGE_SIZE=20Gi. Storage values can be a plain integer or a fixed-point integer using one of these suffixes: E, P, T, G, M, K. You can also use the power-of-two equivalents: Ei, Pi, Ti, Gi, Mi, Ki.
  2. Add values for the retention period, storage class, and storage sizes.

  3. Save the file.

  4. Apply the changes by running:

    $ oc create -f cluster-monitoring-config.yaml