first commit
This commit is contained in:
18
argocd/applications/monitoring-crds.yaml
Normal file
18
argocd/applications/monitoring-crds.yaml
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: monitoring-crds
|
||||||
|
namespace: argocd
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: 'https://gitea.vhn-demo.duckdns.org/hoang/monitoring.git'
|
||||||
|
path: k8s/base/crds
|
||||||
|
targetRevision: main
|
||||||
|
destination:
|
||||||
|
server: 'https://kubernetes.default.svc'
|
||||||
|
namespace: argocd
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: true
|
||||||
|
selfHeel: true
|
||||||
60
argocd/applications/monitoring.yaml
Normal file
60
argocd/applications/monitoring.yaml
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
apiVersion: argoproj.io/v1alpha1
|
||||||
|
kind: Application
|
||||||
|
metadata:
|
||||||
|
name: monitoring
|
||||||
|
namespace: argocd
|
||||||
|
spec:
|
||||||
|
project: default
|
||||||
|
source:
|
||||||
|
repoURL: https://prometheus-community.github.io/helm-charts
|
||||||
|
chart: kube-prometheus-stack
|
||||||
|
targetRevision: 58.0.0
|
||||||
|
helm:
|
||||||
|
values: |
|
||||||
|
# Deaktiviere die automatische Installation der CRDs durch das Helm-Chart
|
||||||
|
# Das Helm-Chart hat eine Option dafür:
|
||||||
|
prometheusOperator:
|
||||||
|
createCustomResource: false
|
||||||
|
alertmanager:
|
||||||
|
config:
|
||||||
|
global:
|
||||||
|
smtp_smarthost: 'smtp.dein-provider.de:587'
|
||||||
|
smtp_from: 'alertmanager@dein-cluster.de'
|
||||||
|
smtp_auth_username: 'dein-user'
|
||||||
|
smtp_auth_password_file: '/etc/alertmanager/secrets/smtp_password'
|
||||||
|
receivers:
|
||||||
|
- name: 'teams-channel'
|
||||||
|
webhook_configs:
|
||||||
|
- url: 'https://webhook.office.com/webhookb2/...'
|
||||||
|
- name: 'email-admin'
|
||||||
|
email_configs:
|
||||||
|
- to: 'admin@example.com'
|
||||||
|
send_resolved: true
|
||||||
|
- name: 'sms-service'
|
||||||
|
webhook_configs:
|
||||||
|
- url: 'https://api.twilio.com/...'
|
||||||
|
http_config:
|
||||||
|
basic_auth:
|
||||||
|
username: 'AC_SID'
|
||||||
|
password_file: '/etc/alertmanager/secrets/twilio_token'
|
||||||
|
route:
|
||||||
|
receiver: 'teams-channel'
|
||||||
|
routes:
|
||||||
|
- receiver: 'email-admin'
|
||||||
|
match:
|
||||||
|
severity: critical
|
||||||
|
alertmanagerSpec:
|
||||||
|
secrets:
|
||||||
|
- alertmanager-secrets
|
||||||
|
destination:
|
||||||
|
server: 'https://kubernetes.default.svc'
|
||||||
|
namespace: monitoring
|
||||||
|
syncPolicy:
|
||||||
|
automated:
|
||||||
|
prune: false
|
||||||
|
selfHeel: false
|
||||||
|
syncOptions:
|
||||||
|
- CreateNamespace=true
|
||||||
|
- ServerSideApply=true
|
||||||
|
dependsOn:
|
||||||
|
- name: monitoring-crds
|
||||||
10013
k8s/base/crds/alertmanagers.yaml
Normal file
10013
k8s/base/crds/alertmanagers.yaml
Normal file
File diff suppressed because it is too large
Load Diff
6
k8s/base/crds/kustomization.yaml
Normal file
6
k8s/base/crds/kustomization.yaml
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
resources:
|
||||||
|
- alertmanagers.yaml
|
||||||
|
- podmonitors.yaml
|
||||||
|
- prometheuses.yaml
|
||||||
|
- prometheusrules.yaml
|
||||||
|
- servicemonitors.yaml
|
||||||
1398
k8s/base/crds/podmonitors.yaml
Normal file
1398
k8s/base/crds/podmonitors.yaml
Normal file
File diff suppressed because it is too large
Load Diff
13831
k8s/base/crds/prometheuses.yaml
Normal file
13831
k8s/base/crds/prometheuses.yaml
Normal file
File diff suppressed because it is too large
Load Diff
266
k8s/base/crds/prometheusrules.yaml
Normal file
266
k8s/base/crds/prometheusrules.yaml
Normal file
@@ -0,0 +1,266 @@
|
|||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
controller-gen.kubebuilder.io/version: v0.20.1
|
||||||
|
operator.prometheus.io/version: 0.90.1
|
||||||
|
name: prometheusrules.monitoring.coreos.com
|
||||||
|
spec:
|
||||||
|
group: monitoring.coreos.com
|
||||||
|
names:
|
||||||
|
categories:
|
||||||
|
- prometheus-operator
|
||||||
|
kind: PrometheusRule
|
||||||
|
listKind: PrometheusRuleList
|
||||||
|
plural: prometheusrules
|
||||||
|
shortNames:
|
||||||
|
- promrule
|
||||||
|
singular: prometheusrule
|
||||||
|
scope: Namespaced
|
||||||
|
versions:
|
||||||
|
- name: v1
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
description: |-
|
||||||
|
The `PrometheusRule` custom resource definition (CRD) defines [alerting](https://prometheus.io/docs/prometheus/latest/configuration/alerting_rules/) and [recording](https://prometheus.io/docs/prometheus/latest/configuration/recording_rules/) rules to be evaluated by `Prometheus` or `ThanosRuler` objects.
|
||||||
|
|
||||||
|
`Prometheus` and `ThanosRuler` objects select `PrometheusRule` objects using label and namespace selectors.
|
||||||
|
properties:
|
||||||
|
apiVersion:
|
||||||
|
description: |-
|
||||||
|
APIVersion defines the versioned schema of this representation of an object.
|
||||||
|
Servers should convert recognized schemas to the latest internal value, and
|
||||||
|
may reject unrecognized values.
|
||||||
|
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: |-
|
||||||
|
Kind is a string value representing the REST resource this object represents.
|
||||||
|
Servers may infer this from the endpoint the client submits requests to.
|
||||||
|
Cannot be updated.
|
||||||
|
In CamelCase.
|
||||||
|
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds
|
||||||
|
type: string
|
||||||
|
metadata:
|
||||||
|
type: object
|
||||||
|
spec:
|
||||||
|
description: spec defines the specification of desired alerting rule definitions
|
||||||
|
for Prometheus.
|
||||||
|
properties:
|
||||||
|
groups:
|
||||||
|
description: groups defines the content of Prometheus rule file
|
||||||
|
items:
|
||||||
|
description: RuleGroup is a list of sequentially evaluated recording
|
||||||
|
and alerting rules.
|
||||||
|
properties:
|
||||||
|
interval:
|
||||||
|
description: interval defines how often rules in the group are
|
||||||
|
evaluated.
|
||||||
|
pattern: ^(0|(([0-9]+)y)?(([0-9]+)w)?(([0-9]+)d)?(([0-9]+)h)?(([0-9]+)m)?(([0-9]+)s)?(([0-9]+)ms)?)$
|
||||||
|
type: string
|
||||||
|
labels:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
description: |-
|
||||||
|
labels define the labels to add or overwrite before storing the result for its rules.
|
||||||
|
The labels defined at the rule level take precedence.
|
||||||
|
|
||||||
|
It requires Prometheus >= 3.0.0.
|
||||||
|
The field is ignored for Thanos Ruler.
|
||||||
|
type: object
|
||||||
|
limit:
|
||||||
|
description: |-
|
||||||
|
limit defines the number of alerts an alerting rule and series a recording
|
||||||
|
rule can produce.
|
||||||
|
Limit is supported starting with Prometheus >= 2.31 and Thanos Ruler >= 0.24.
|
||||||
|
type: integer
|
||||||
|
name:
|
||||||
|
description: name defines the name of the rule group.
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
partial_response_strategy:
|
||||||
|
description: |-
|
||||||
|
partial_response_strategy is only used by ThanosRuler and will
|
||||||
|
be ignored by Prometheus instances.
|
||||||
|
More info: https://github.com/thanos-io/thanos/blob/main/docs/components/rule.md#partial-response
|
||||||
|
pattern: ^(?i)(abort|warn)?$
|
||||||
|
type: string
|
||||||
|
query_offset:
|
||||||
|
description: |-
|
||||||
|
query_offset defines the offset the rule evaluation timestamp of this particular group by the specified duration into the past.
|
||||||
|
|
||||||
|
It requires Prometheus >= v2.53.0.
|
||||||
|
It is not supported for ThanosRuler.
|
||||||
|
pattern: ^(0|(([0-9]+)y)?(([0-9]+)w)?(([0-9]+)d)?(([0-9]+)h)?(([0-9]+)m)?(([0-9]+)s)?(([0-9]+)ms)?)$
|
||||||
|
type: string
|
||||||
|
rules:
|
||||||
|
description: rules defines the list of alerting and recording
|
||||||
|
rules.
|
||||||
|
items:
|
||||||
|
description: |-
|
||||||
|
Rule describes an alerting or recording rule
|
||||||
|
See Prometheus documentation: [alerting](https://www.prometheus.io/docs/prometheus/latest/configuration/alerting_rules/) or [recording](https://www.prometheus.io/docs/prometheus/latest/configuration/recording_rules/#recording-rules) rule
|
||||||
|
properties:
|
||||||
|
alert:
|
||||||
|
description: |-
|
||||||
|
alert defines the name of the alert. Must be a valid label value.
|
||||||
|
Only one of `record` and `alert` must be set.
|
||||||
|
type: string
|
||||||
|
annotations:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
description: |-
|
||||||
|
annotations defines annotations to add to each alert.
|
||||||
|
Only valid for alerting rules.
|
||||||
|
type: object
|
||||||
|
expr:
|
||||||
|
anyOf:
|
||||||
|
- type: integer
|
||||||
|
- type: string
|
||||||
|
description: expr defines the PromQL expression to evaluate.
|
||||||
|
x-kubernetes-int-or-string: true
|
||||||
|
for:
|
||||||
|
description: for defines how alerts are considered firing
|
||||||
|
once they have been returned for this long.
|
||||||
|
pattern: ^(0|(([0-9]+)y)?(([0-9]+)w)?(([0-9]+)d)?(([0-9]+)h)?(([0-9]+)m)?(([0-9]+)s)?(([0-9]+)ms)?)$
|
||||||
|
type: string
|
||||||
|
keep_firing_for:
|
||||||
|
description: keep_firing_for defines how long an alert
|
||||||
|
will continue firing after the condition that triggered
|
||||||
|
it has cleared.
|
||||||
|
minLength: 1
|
||||||
|
pattern: ^(0|(([0-9]+)y)?(([0-9]+)w)?(([0-9]+)d)?(([0-9]+)h)?(([0-9]+)m)?(([0-9]+)s)?(([0-9]+)ms)?)$
|
||||||
|
type: string
|
||||||
|
labels:
|
||||||
|
additionalProperties:
|
||||||
|
type: string
|
||||||
|
description: labels defines labels to add or overwrite.
|
||||||
|
type: object
|
||||||
|
record:
|
||||||
|
description: |-
|
||||||
|
record defines the name of the time series to output to. Must be a valid metric name.
|
||||||
|
Only one of `record` and `alert` must be set.
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- expr
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
x-kubernetes-list-map-keys:
|
||||||
|
- name
|
||||||
|
x-kubernetes-list-type: map
|
||||||
|
type: object
|
||||||
|
status:
|
||||||
|
description: |-
|
||||||
|
status defines the status subresource. It is under active development and is updated only when the
|
||||||
|
"StatusForConfigurationResources" feature gate is enabled.
|
||||||
|
|
||||||
|
Most recent observed status of the PrometheusRule. Read-only.
|
||||||
|
More info:
|
||||||
|
https://github.com/kubernetes/community/blob/master/contributors/devel/sig-architecture/api-conventions.md#spec-and-status
|
||||||
|
properties:
|
||||||
|
bindings:
|
||||||
|
description: bindings defines the list of workload resources (Prometheus,
|
||||||
|
PrometheusAgent, ThanosRuler or Alertmanager) which select the configuration
|
||||||
|
resource.
|
||||||
|
items:
|
||||||
|
description: WorkloadBinding is a link between a configuration resource
|
||||||
|
and a workload resource.
|
||||||
|
properties:
|
||||||
|
conditions:
|
||||||
|
description: conditions defines the current state of the configuration
|
||||||
|
resource when bound to the referenced Workload object.
|
||||||
|
items:
|
||||||
|
description: ConfigResourceCondition describes the status
|
||||||
|
of configuration resources linked to Prometheus, PrometheusAgent,
|
||||||
|
Alertmanager or ThanosRuler.
|
||||||
|
properties:
|
||||||
|
lastTransitionTime:
|
||||||
|
description: lastTransitionTime defines the time of the
|
||||||
|
last update to the current status property.
|
||||||
|
format: date-time
|
||||||
|
type: string
|
||||||
|
message:
|
||||||
|
description: message defines the human-readable message
|
||||||
|
indicating details for the condition's last transition.
|
||||||
|
type: string
|
||||||
|
observedGeneration:
|
||||||
|
description: |-
|
||||||
|
observedGeneration defines the .metadata.generation that the
|
||||||
|
condition was set based upon. For instance, if `.metadata.generation` is
|
||||||
|
currently 12, but the `.status.conditions[].observedGeneration` is 9, the
|
||||||
|
condition is out of date with respect to the current state of the object.
|
||||||
|
format: int64
|
||||||
|
type: integer
|
||||||
|
reason:
|
||||||
|
description: reason for the condition's last transition.
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
description: status of the condition.
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
type:
|
||||||
|
description: |-
|
||||||
|
type of the condition being reported.
|
||||||
|
Currently, only "Accepted" is supported.
|
||||||
|
enum:
|
||||||
|
- Accepted
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- lastTransitionTime
|
||||||
|
- status
|
||||||
|
- type
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
x-kubernetes-list-map-keys:
|
||||||
|
- type
|
||||||
|
x-kubernetes-list-type: map
|
||||||
|
group:
|
||||||
|
description: group defines the group of the referenced resource.
|
||||||
|
enum:
|
||||||
|
- monitoring.coreos.com
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: name defines the name of the referenced object.
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: namespace defines the namespace of the referenced
|
||||||
|
object.
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
resource:
|
||||||
|
description: resource defines the type of resource being referenced
|
||||||
|
(e.g. Prometheus, PrometheusAgent, ThanosRuler or Alertmanager).
|
||||||
|
enum:
|
||||||
|
- prometheuses
|
||||||
|
- prometheusagents
|
||||||
|
- thanosrulers
|
||||||
|
- alertmanagers
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
- resource
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
x-kubernetes-list-map-keys:
|
||||||
|
- group
|
||||||
|
- resource
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
x-kubernetes-list-type: map
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- spec
|
||||||
|
type: object
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
subresources:
|
||||||
|
status: {}
|
||||||
1412
k8s/base/crds/servicemonitors.yaml
Normal file
1412
k8s/base/crds/servicemonitors.yaml
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user