Prometheus
Prometheus is a system for monitoring cloud native applications and is used by Verrazzano to monitor applications. Prometheus is used in Verrazzano to collect system performance metrics and metrics for applications deployed or managed by Verrazzano. Prometheus analyzes the metrics and provides visualization using Grafana.
Customize Prometheus configuration
Verrazzano installs Prometheus components, including Prometheus Operator and Prometheus, using the kube-prometheus-stack Helm chart. You can customize the installation configuration using Helm overrides specified in the Verrazzano custom resource. For example, the following Verrazzano custom resource overrides the number of Prometheus replicas.
apiVersion: install.verrazzano.io/v1beta1
kind: Verrazzano
metadata:
name: custom-prometheus
spec:
profile: prod
components:
prometheusOperator:
overrides:
- values:
prometheus:
prometheusSpec:
replicas: 3
To enable Alertmanager, use the following Verrazzano custom resource:
apiVersion: install.verrazzano.io/v1beta1
kind: Verrazzano
metadata:
name: custom-prometheus
spec:
profile: prod
components:
prometheusOperator:
overrides:
- values:
alertmanager:
enabled: true
alertmanagerSpec:
podMetadata:
annotations:
sidecar.istio.io/inject: "false"
For more information about setting component overrides, see Customizing the Chart Before Installing.
After you have enabled Alertmanager, you can deploy alert rules to get proactive alerts.
To create a TestAlertRule
, run the following command.
$ kubectl apply -f - <<EOF
apiVersion: monitoring.coreos.com/v1
kind: PrometheusRule
metadata:
labels:
release: prometheus-operator
name: prometheus-operator-test
namespace: verrazzano-monitoring
spec:
groups:
- name: test
rules:
- alert: TestAlertRule
annotations:
description: Test alert rule
runbook_url: test-runbook-url
summary: Test alert rule
expr: |-
prometheus_config_last_reload_successful{job="prometheus-operator-kube-p-prometheus",namespace="verrazzano-monitoring"} == 0
for: 10m
labels:
severity: critical
EOF
For more information, see Deploying Prometheus rules.
For instructions to customize persistent storage settings, see Customize Persistent Storage.
Configure data retention settings
Verrazzano configures Prometheus with a default data retention setting of 10 days. The rate of metrics data collected depends on many factors, including the number of monitors, the monitor scrape intervals, and the number of metrics returned by each monitor.
When using persistent storage for Prometheus, it is possible to consume all storage. If Prometheus uses all available persistent storage, then queries return no data and new metrics cannot be saved. You can customize the persistent storage settings, and change the data retention days and configure a maximum retention size. When configuring retention size, a good rule of thumb is to set the value to no more than 85 percent of the persistent storage size.
The following example configures Prometheus to store at most three days or 40 GB of metrics data.
apiVersion: install.verrazzano.io/v1beta1
kind: Verrazzano
metadata:
name: custom-prometheus
spec:
profile: prod
components:
prometheusOperator:
overrides:
- values:
prometheus:
prometheusSpec:
retention: 3d
retentionSize: 40GB
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.