doc: sync prometheus rules with prometheus-operator version

(and remove non-etcd specific FdExhaustionClose)
https://github.com/coreos/prometheus-operator/blob/master/helm/exporter-kube-etcd/templates/etcd3.rules.yaml
sync etcd alert rules with libsonnet

Signed-off-by: Dmitry Verkhoturov <paskal.07@gmail.com>
This commit is contained in:
Dmitry Verkhoturov 2018-11-08 15:15:04 +03:00
parent abb57363ba
commit 358cc1a8fa
2 changed files with 111 additions and 79 deletions

View File

@ -149,33 +149,45 @@
}, },
}, },
{ {
record: 'instance:fd_utilization', alert: 'EtcdHighNumberOfFailedHTTPRequests',
expr: 'process_open_fds / process_max_fds',
},
{
alert: 'FdExhaustionClose',
expr: ||| expr: |||
predict_linear(instance:fd_utilization{%(etcd_selector)s}[1h], 3600 * 4) > 1 sum(rate(etcd_http_failed_total{%(etcd_selector)s}[5m])) BY (method) / sum(rate(etcd_http_received_total{%(etcd_selector)s}[5m]))
BY (method) > 0.01
||| % $._config, ||| % $._config,
'for': '10m', 'for': '10m',
labels: { labels: {
severity: 'warning', severity: 'warning',
}, },
annotations: { annotations: {
message: '{{ $labels.job }} instance {{ $labels.instance }} will exhaust its file descriptors soon', message: '{{ $value }}% of requests for {{ $labels.method }} failed on etcd instance {{ $labels.instance }}',
}, },
}, },
{ {
alert: 'FdExhaustionClose', alert: 'EtcdHighNumberOfFailedHTTPRequests',
expr: ||| expr: |||
predict_linear(instance:fd_utilization{%(etcd_selector)s}[10m], 3600) > 1 sum(rate(etcd_http_failed_total{%(etcd_selector)s}[5m])) BY (method) / sum(rate(etcd_http_received_total{%(etcd_selector)s}[5m]))
BY (method) > 0.05
||| % $._config, ||| % $._config,
'for': '10m', 'for': '10m',
labels: { labels: {
severity: 'critical', severity: 'critical',
}, },
annotations: { annotations: {
description: '{{ $labels.job }} instance {{ $labels.instance }} will exhaust its file descriptors soon', message: '{{ $value }}% of requests for {{ $labels.method }} failed on etcd instance {{ $labels.instance }}.',
},
},
{
alert: 'EtcdHTTPRequestsSlow',
expr: |||
histogram_quantile(0.99, rate(etcd_http_successful_duration_seconds_bucket[5m]))
> 0.15
||| % $._config,
'for': '10m',
labels: {
severity: 'warning',
},
annotations: {
message: 'Etcd instance {{ $labels.instance }} HTTP requests to {{ $labels.method }} are slow.',
}, },
}, },
], ],

View File

@ -1,113 +1,133 @@
groups: groups:
- name: etcd3_alert.rules - name: etcd
rules: rules:
- alert: InsufficientMembers - alert: EtcdInsufficientMembers
expr: count(up{job="etcd"} == 0) > (count(up{job="etcd"}) / 2 - 1) annotations:
message: 'Etcd cluster "{{ $labels.job }}": insufficient members ({{ $value
}}).'
expr: |
sum(up{job=~".*etcd.*"} == bool 1) by (job) < ((count(up{job=~".*etcd.*"}) by (job) + 1) / 2)
for: 3m for: 3m
labels: labels:
severity: critical severity: critical
- alert: EtcdNoLeader
annotations: annotations:
description: If one more etcd member goes down the cluster will be unavailable message: 'Etcd cluster "{{ $labels.job }}": member {{ $labels.instance }} has
summary: etcd cluster insufficient members no leader.'
- alert: NoLeader expr: |
expr: etcd_server_has_leader{job="etcd"} == 0 etcd_server_has_leader{job=~".*etcd.*"} == 0
for: 1m for: 1m
labels: labels:
severity: critical severity: critical
- alert: EtcdHighNumberOfLeaderChanges
annotations: annotations:
description: etcd member {{ $labels.instance }} has no leader message: 'Etcd cluster "{{ $labels.job }}": instance {{ $labels.instance }}
summary: etcd member has no leader has seen {{ $value }} leader changes within the last hour.'
- alert: HighNumberOfLeaderChanges expr: |
expr: increase(etcd_server_leader_changes_seen_total{job="etcd"}[1h]) > 3 rate(etcd_server_leader_changes_seen_total{job=~".*etcd.*"}[15m]) > 3
for: 15m
labels: labels:
severity: warning severity: warning
- alert: EtcdHighNumberOfFailedGRPCRequests
annotations: annotations:
description: etcd instance {{ $labels.instance }} has seen {{ $value }} leader message: 'Etcd cluster "{{ $labels.job }}": {{ $value }}% of requests for {{
changes within the last hour $labels.grpc_method }} failed on etcd instance {{ $labels.instance }}.'
summary: a high number of leader changes within the etcd cluster are happening expr: |
- alert: HighNumberOfFailedGRPCRequests 100 * sum(rate(grpc_server_handled_total{job=~".*etcd.*", grpc_code!="OK"}[5m])) BY (job, instance, grpc_service, grpc_method)
expr: 100 * (sum(rate(grpc_server_handled_total{grpc_code!="OK",job="etcd"}[5m])) BY (grpc_service, grpc_method) /
/ sum(rate(grpc_server_handled_total{job="etcd"}[5m])) BY (grpc_service, grpc_method)) > 1 sum(rate(grpc_server_handled_total{job=~".*etcd.*"}[5m])) BY (job, instance, grpc_service, grpc_method)
> 1
for: 10m for: 10m
labels: labels:
severity: warning severity: warning
- alert: EtcdHighNumberOfFailedGRPCRequests
annotations: annotations:
description: '{{ $value }}% of requests for {{ $labels.grpc_method }} failed message: 'Etcd cluster "{{ $labels.job }}": {{ $value }}% of requests for {{
on etcd instance {{ $labels.instance }}' $labels.grpc_method }} failed on etcd instance {{ $labels.instance }}.'
summary: a high number of gRPC requests are failing expr: |
- alert: HighNumberOfFailedGRPCRequests 100 * sum(rate(grpc_server_handled_total{job=~".*etcd.*", grpc_code!="OK"}[5m])) BY (job, instance, grpc_service, grpc_method)
expr: 100 * (sum(rate(grpc_server_handled_total{grpc_code!="OK",job="etcd"}[5m])) BY (grpc_service, grpc_method) /
/ sum(rate(grpc_server_handled_total{job="etcd"}[5m])) BY (grpc_service, grpc_method)) > 5 sum(rate(grpc_server_handled_total{job=~".*etcd.*"}[5m])) BY (job, instance, grpc_service, grpc_method)
> 5
for: 5m for: 5m
labels: labels:
severity: critical severity: critical
- alert: EtcdGRPCRequestsSlow
annotations: annotations:
description: '{{ $value }}% of requests for {{ $labels.grpc_method }} failed message: 'Etcd cluster "{{ $labels.job }}": gRPC requests to {{ $labels.grpc_method
on etcd instance {{ $labels.instance }}' }} are taking {{ $value }}s on etcd instance {{ $labels.instance }}.'
summary: a high number of gRPC requests are failing expr: |
- alert: GRPCRequestsSlow histogram_quantile(0.99, sum(rate(grpc_server_handling_seconds_bucket{job=~".*etcd.*", grpc_type="unary"}[5m])) by (job, instance, grpc_service, grpc_method, le))
expr: histogram_quantile(0.99, sum(rate(grpc_server_handling_seconds_bucket{job="etcd",grpc_type="unary"}[5m])) by (grpc_service, grpc_method, le))
> 0.15 > 0.15
for: 10m for: 10m
labels: labels:
severity: critical severity: critical
annotations:
description: on etcd instance {{ $labels.instance }} gRPC requests to {{ $labels.grpc_method
}} are slow
summary: slow gRPC requests
- record: instance:fd_utilization
expr: process_open_fds / process_max_fds
- alert: FdExhaustionClose
expr: predict_linear(instance:fd_utilization[1h], 3600 * 4) > 1
for: 10m
labels:
severity: warning
annotations:
description: '{{ $labels.job }} instance {{ $labels.instance }} will exhaust
its file descriptors soon'
summary: file descriptors soon exhausted
- alert: FdExhaustionClose
expr: predict_linear(instance:fd_utilization[10m], 3600) > 1
for: 10m
labels:
severity: critical
annotations:
description: '{{ $labels.job }} instance {{ $labels.instance }} will exhaust
its file descriptors soon'
summary: file descriptors soon exhausted
- alert: EtcdMemberCommunicationSlow - alert: EtcdMemberCommunicationSlow
expr: histogram_quantile(0.99, rate(etcd_network_peer_round_trip_time_seconds_bucket[5m])) annotations:
message: 'Etcd cluster "{{ $labels.job }}": member communication with {{ $labels.To
}} is taking {{ $value }}s on etcd instance {{ $labels.instance }}.'
expr: |
histogram_quantile(0.99, rate(etcd_network_peer_round_trip_time_seconds_bucket{job=~".*etcd.*"}[5m]))
> 0.15 > 0.15
for: 10m for: 10m
labels: labels:
severity: warning severity: warning
- alert: EtcdHighNumberOfFailedProposals
annotations: annotations:
description: etcd instance {{ $labels.instance }} member communication with message: 'Etcd cluster "{{ $labels.job }}": {{ $value }} proposal failures within
{{ $labels.To }} is slow the last hour on etcd instance {{ $labels.instance }}.'
summary: etcd member communication is slow expr: |
- alert: HighNumberOfFailedProposals rate(etcd_server_proposals_failed_total{job=~".*etcd.*"}[15m]) > 5
expr: increase(etcd_server_proposals_failed_total{job="etcd"}[1h]) > 5 for: 15m
labels: labels:
severity: warning severity: warning
- alert: EtcdHighFsyncDurations
annotations: annotations:
description: etcd instance {{ $labels.instance }} has seen {{ $value }} proposal message: 'Etcd cluster "{{ $labels.job }}": 99th percentile fync durations are
failures within the last hour {{ $value }}s on etcd instance {{ $labels.instance }}.'
summary: a high number of proposals within the etcd cluster are failing expr: |
- alert: HighFsyncDurations histogram_quantile(0.99, rate(etcd_disk_wal_fsync_duration_seconds_bucket{job=~".*etcd.*"}[5m]))
expr: histogram_quantile(0.99, rate(etcd_disk_wal_fsync_duration_seconds_bucket[5m]))
> 0.5 > 0.5
for: 10m for: 10m
labels: labels:
severity: warning severity: warning
- alert: EtcdHighCommitDurations
annotations: annotations:
description: etcd instance {{ $labels.instance }} fync durations are high message: 'Etcd cluster "{{ $labels.job }}": 99th percentile commit durations
summary: high fsync durations {{ $value }}s on etcd instance {{ $labels.instance }}.'
- alert: HighCommitDurations expr: |
expr: histogram_quantile(0.99, rate(etcd_disk_backend_commit_duration_seconds_bucket[5m])) histogram_quantile(0.99, rate(etcd_disk_backend_commit_duration_seconds_bucket{job=~".*etcd.*"}[5m]))
> 0.25 > 0.25
for: 10m for: 10m
labels: labels:
severity: warning severity: warning
- alert: EtcdHighNumberOfFailedHTTPRequests
annotations: annotations:
description: etcd instance {{ $labels.instance }} commit durations are high message: '{{ $value }}% of requests for {{ $labels.method }} failed on etcd
summary: high commit durations instance {{ $labels.instance }}'
expr: |
sum(rate(etcd_http_failed_total{job=~".*etcd.*"}[5m])) BY (method) / sum(rate(etcd_http_received_total{job=~".*etcd.*"}[5m]))
BY (method) > 0.01
for: 10m
labels:
severity: warning
- alert: EtcdHighNumberOfFailedHTTPRequests
annotations:
message: '{{ $value }}% of requests for {{ $labels.method }} failed on etcd
instance {{ $labels.instance }}.'
expr: |
sum(rate(etcd_http_failed_total{job=~".*etcd.*"}[5m])) BY (method) / sum(rate(etcd_http_received_total{job=~".*etcd.*"}[5m]))
BY (method) > 0.05
for: 10m
labels:
severity: critical
- alert: EtcdHTTPRequestsSlow
annotations:
message: Etcd instance {{ $labels.instance }} HTTP requests to {{ $labels.method
}} are slow.
expr: |
histogram_quantile(0.99, rate(etcd_http_successful_duration_seconds_bucket[5m]))
> 0.15
for: 10m
labels:
severity: warning