mirror of https://git.rancher.io/charts
358 lines
15 KiB
YAML
358 lines
15 KiB
YAML
|
{{- /*
|
||
|
Generated from 'kube-apiserver.rules' group from https://raw.githubusercontent.com/prometheus-operator/kube-prometheus/master/manifests/kubernetes-prometheusRule.yaml
|
||
|
Do not change in-place! In order to change this file first read following link:
|
||
|
https://github.com/prometheus-community/helm-charts/tree/main/charts/kube-prometheus-stack/hack
|
||
|
*/ -}}
|
||
|
{{- $kubeTargetVersion := default .Capabilities.KubeVersion.GitVersion .Values.kubeTargetVersionOverride }}
|
||
|
{{- if and (semverCompare ">=1.14.0-0" $kubeTargetVersion) (semverCompare "<9.9.9-9" $kubeTargetVersion) .Values.defaultRules.create .Values.kubeApiServer.enabled .Values.defaultRules.rules.kubeApiserver }}
|
||
|
apiVersion: monitoring.coreos.com/v1
|
||
|
kind: PrometheusRule
|
||
|
metadata:
|
||
|
name: {{ printf "%s-%s" (include "kube-prometheus-stack.fullname" .) "kube-apiserver.rules" | trunc 63 | trimSuffix "-" }}
|
||
|
namespace: {{ template "kube-prometheus-stack.namespace" . }}
|
||
|
labels:
|
||
|
app: {{ template "kube-prometheus-stack.name" . }}
|
||
|
{{ include "kube-prometheus-stack.labels" . | indent 4 }}
|
||
|
{{- if .Values.defaultRules.labels }}
|
||
|
{{ toYaml .Values.defaultRules.labels | indent 4 }}
|
||
|
{{- end }}
|
||
|
{{- if .Values.defaultRules.annotations }}
|
||
|
annotations:
|
||
|
{{ toYaml .Values.defaultRules.annotations | indent 4 }}
|
||
|
{{- end }}
|
||
|
spec:
|
||
|
groups:
|
||
|
- name: kube-apiserver.rules
|
||
|
rules:
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"LIST|GET"}[1d]))
|
||
|
-
|
||
|
(
|
||
|
(
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope=~"resource|",le="0.1"}[1d]))
|
||
|
or
|
||
|
vector(0)
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="namespace",le="0.5"}[1d]))
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="cluster",le="5"}[1d]))
|
||
|
)
|
||
|
)
|
||
|
+
|
||
|
# errors
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET",code=~"5.."}[1d]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[1d]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: apiserver_request:burnrate1d
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"LIST|GET"}[1h]))
|
||
|
-
|
||
|
(
|
||
|
(
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope=~"resource|",le="0.1"}[1h]))
|
||
|
or
|
||
|
vector(0)
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="namespace",le="0.5"}[1h]))
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="cluster",le="5"}[1h]))
|
||
|
)
|
||
|
)
|
||
|
+
|
||
|
# errors
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET",code=~"5.."}[1h]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[1h]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: apiserver_request:burnrate1h
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"LIST|GET"}[2h]))
|
||
|
-
|
||
|
(
|
||
|
(
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope=~"resource|",le="0.1"}[2h]))
|
||
|
or
|
||
|
vector(0)
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="namespace",le="0.5"}[2h]))
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="cluster",le="5"}[2h]))
|
||
|
)
|
||
|
)
|
||
|
+
|
||
|
# errors
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET",code=~"5.."}[2h]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[2h]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: apiserver_request:burnrate2h
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"LIST|GET"}[30m]))
|
||
|
-
|
||
|
(
|
||
|
(
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope=~"resource|",le="0.1"}[30m]))
|
||
|
or
|
||
|
vector(0)
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="namespace",le="0.5"}[30m]))
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="cluster",le="5"}[30m]))
|
||
|
)
|
||
|
)
|
||
|
+
|
||
|
# errors
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET",code=~"5.."}[30m]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[30m]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: apiserver_request:burnrate30m
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"LIST|GET"}[3d]))
|
||
|
-
|
||
|
(
|
||
|
(
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope=~"resource|",le="0.1"}[3d]))
|
||
|
or
|
||
|
vector(0)
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="namespace",le="0.5"}[3d]))
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="cluster",le="5"}[3d]))
|
||
|
)
|
||
|
)
|
||
|
+
|
||
|
# errors
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET",code=~"5.."}[3d]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[3d]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: apiserver_request:burnrate3d
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"LIST|GET"}[5m]))
|
||
|
-
|
||
|
(
|
||
|
(
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope=~"resource|",le="0.1"}[5m]))
|
||
|
or
|
||
|
vector(0)
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="namespace",le="0.5"}[5m]))
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="cluster",le="5"}[5m]))
|
||
|
)
|
||
|
)
|
||
|
+
|
||
|
# errors
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET",code=~"5.."}[5m]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[5m]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: apiserver_request:burnrate5m
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"LIST|GET"}[6h]))
|
||
|
-
|
||
|
(
|
||
|
(
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope=~"resource|",le="0.1"}[6h]))
|
||
|
or
|
||
|
vector(0)
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="namespace",le="0.5"}[6h]))
|
||
|
+
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET",scope="cluster",le="5"}[6h]))
|
||
|
)
|
||
|
)
|
||
|
+
|
||
|
# errors
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET",code=~"5.."}[6h]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[6h]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: apiserver_request:burnrate6h
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[1d]))
|
||
|
-
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",le="1"}[1d]))
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",code=~"5.."}[1d]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[1d]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: apiserver_request:burnrate1d
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[1h]))
|
||
|
-
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",le="1"}[1h]))
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",code=~"5.."}[1h]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[1h]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: apiserver_request:burnrate1h
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[2h]))
|
||
|
-
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",le="1"}[2h]))
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",code=~"5.."}[2h]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[2h]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: apiserver_request:burnrate2h
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[30m]))
|
||
|
-
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",le="1"}[30m]))
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",code=~"5.."}[30m]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[30m]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: apiserver_request:burnrate30m
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[3d]))
|
||
|
-
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",le="1"}[3d]))
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",code=~"5.."}[3d]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[3d]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: apiserver_request:burnrate3d
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[5m]))
|
||
|
-
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",le="1"}[5m]))
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",code=~"5.."}[5m]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[5m]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: apiserver_request:burnrate5m
|
||
|
- expr: |-
|
||
|
(
|
||
|
(
|
||
|
# too slow
|
||
|
sum(rate(apiserver_request_duration_seconds_count{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[6h]))
|
||
|
-
|
||
|
sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",le="1"}[6h]))
|
||
|
)
|
||
|
+
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE",code=~"5.."}[6h]))
|
||
|
)
|
||
|
/
|
||
|
sum(rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[6h]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: apiserver_request:burnrate6h
|
||
|
- expr: sum by (code,resource) (rate(apiserver_request_total{job="apiserver",verb=~"LIST|GET"}[5m]))
|
||
|
labels:
|
||
|
verb: read
|
||
|
record: code_resource:apiserver_request_total:rate5m
|
||
|
- expr: sum by (code,resource) (rate(apiserver_request_total{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[5m]))
|
||
|
labels:
|
||
|
verb: write
|
||
|
record: code_resource:apiserver_request_total:rate5m
|
||
|
- expr: histogram_quantile(0.99, sum by (le, resource) (rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"LIST|GET"}[5m]))) > 0
|
||
|
labels:
|
||
|
quantile: '0.99'
|
||
|
verb: read
|
||
|
record: cluster_quantile:apiserver_request_duration_seconds:histogram_quantile
|
||
|
- expr: histogram_quantile(0.99, sum by (le, resource) (rate(apiserver_request_duration_seconds_bucket{job="apiserver",verb=~"POST|PUT|PATCH|DELETE"}[5m]))) > 0
|
||
|
labels:
|
||
|
quantile: '0.99'
|
||
|
verb: write
|
||
|
record: cluster_quantile:apiserver_request_duration_seconds:histogram_quantile
|
||
|
- expr: histogram_quantile(0.99, sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",subresource!="log",verb!~"LIST|WATCH|WATCHLIST|DELETECOLLECTION|PROXY|CONNECT"}[5m])) without(instance, pod))
|
||
|
labels:
|
||
|
quantile: '0.99'
|
||
|
record: cluster_quantile:apiserver_request_duration_seconds:histogram_quantile
|
||
|
- expr: histogram_quantile(0.9, sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",subresource!="log",verb!~"LIST|WATCH|WATCHLIST|DELETECOLLECTION|PROXY|CONNECT"}[5m])) without(instance, pod))
|
||
|
labels:
|
||
|
quantile: '0.9'
|
||
|
record: cluster_quantile:apiserver_request_duration_seconds:histogram_quantile
|
||
|
- expr: histogram_quantile(0.5, sum(rate(apiserver_request_duration_seconds_bucket{job="apiserver",subresource!="log",verb!~"LIST|WATCH|WATCHLIST|DELETECOLLECTION|PROXY|CONNECT"}[5m])) without(instance, pod))
|
||
|
labels:
|
||
|
quantile: '0.5'
|
||
|
record: cluster_quantile:apiserver_request_duration_seconds:histogram_quantile
|
||
|
{{- end }}
|