Disable install crds
This commit is contained in:
parent
4f18336f89
commit
8cde902454
@ -21,3 +21,9 @@ spec:
|
|||||||
selfHeal: true
|
selfHeal: true
|
||||||
syncOptions:
|
syncOptions:
|
||||||
- CreateNamespace=true
|
- CreateNamespace=true
|
||||||
|
retry:
|
||||||
|
limit: 5
|
||||||
|
backoff:
|
||||||
|
duration: 5s
|
||||||
|
factor: 2
|
||||||
|
maxDuration: 3m
|
||||||
46
crds/prometheus-operator/README.md
Normal file
46
crds/prometheus-operator/README.md
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
# Prometheus Operator CRDs
|
||||||
|
|
||||||
|
This directory contains the CustomResourceDefinitions (CRDs) for the Prometheus Operator.
|
||||||
|
|
||||||
|
## Why Separate CRDs?
|
||||||
|
|
||||||
|
These CRDs are managed separately from the main `kube-prometheus-stack` Helm chart to avoid:
|
||||||
|
|
||||||
|
1. **Large Annotation Error**: Helm stores the full manifest in annotations, which can exceed Kubernetes' 262144-byte limit for CRDs
|
||||||
|
2. **CRD Installation Race Conditions**: Ensures CRDs are installed before any resources that depend on them
|
||||||
|
|
||||||
|
## Deployment Method
|
||||||
|
|
||||||
|
These CRDs are **manually deployed** using kubectl server-side apply:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
kubectl apply --server-side=true --force-conflicts -f manifests/prometheus-operator-crds/
|
||||||
|
```
|
||||||
|
|
||||||
|
**Note**: Server-side apply is required to bypass the annotation size limit that affects large CRDs.
|
||||||
|
|
||||||
|
## CRDs Included
|
||||||
|
|
||||||
|
- `crd-alertmanagerconfigs.yaml` - AlertmanagerConfig resources
|
||||||
|
- `crd-alertmanagers.yaml` - Alertmanager resources
|
||||||
|
- `crd-podmonitors.yaml` - PodMonitor resources
|
||||||
|
- `crd-probes.yaml` - Probe resources
|
||||||
|
- `crd-prometheusagents.yaml` - PrometheusAgent resources
|
||||||
|
- `crd-prometheuses.yaml` - Prometheus resources
|
||||||
|
- `crd-prometheusrules.yaml` - PrometheusRule resources
|
||||||
|
- `crd-scrapeconfigs.yaml` - ScrapeConfig resources
|
||||||
|
- `crd-servicemonitors.yaml` - ServiceMonitor resources
|
||||||
|
- `crd-thanosrulers.yaml` - ThanosRuler resources
|
||||||
|
|
||||||
|
## Updating CRDs
|
||||||
|
|
||||||
|
When updating the `kube-prometheus-stack` chart version:
|
||||||
|
|
||||||
|
1. Copy the new CRDs from `charts/kube-prometheus-stack/charts/crds/crds/` to this directory
|
||||||
|
2. Reapply them: `kubectl apply --server-side=true --force-conflicts -f manifests/prometheus-operator-crds/`
|
||||||
|
3. Then update the main stack via ArgoCD
|
||||||
|
|
||||||
|
## Related Configuration
|
||||||
|
|
||||||
|
- Main stack values: `manifests/kube-prometheus-stack/values.yaml` has `crds.enabled: false`
|
||||||
|
- Main ArgoCD app: `argocd-apps/kube-prometheus-stack.yaml`
|
||||||
12334
crds/prometheus-operator/crd-alertmanagerconfigs.yaml
Normal file
12334
crds/prometheus-operator/crd-alertmanagerconfigs.yaml
Normal file
File diff suppressed because it is too large
Load Diff
9983
crds/prometheus-operator/crd-alertmanagers.yaml
Normal file
9983
crds/prometheus-operator/crd-alertmanagers.yaml
Normal file
File diff suppressed because it is too large
Load Diff
1399
crds/prometheus-operator/crd-podmonitors.yaml
Normal file
1399
crds/prometheus-operator/crd-podmonitors.yaml
Normal file
File diff suppressed because it is too large
Load Diff
1416
crds/prometheus-operator/crd-probes.yaml
Normal file
1416
crds/prometheus-operator/crd-probes.yaml
Normal file
File diff suppressed because it is too large
Load Diff
11449
crds/prometheus-operator/crd-prometheusagents.yaml
Normal file
11449
crds/prometheus-operator/crd-prometheusagents.yaml
Normal file
File diff suppressed because it is too large
Load Diff
13720
crds/prometheus-operator/crd-prometheuses.yaml
Normal file
13720
crds/prometheus-operator/crd-prometheuses.yaml
Normal file
File diff suppressed because it is too large
Load Diff
267
crds/prometheus-operator/crd-prometheusrules.yaml
Normal file
267
crds/prometheus-operator/crd-prometheusrules.yaml
Normal file
@ -0,0 +1,267 @@
|
|||||||
|
# https://raw.githubusercontent.com/prometheus-operator/prometheus-operator/v0.90.1/example/prometheus-operator-crd/monitoring.coreos.com_prometheusrules.yaml
|
||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
controller-gen.kubebuilder.io/version: v0.19.0
|
||||||
|
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: {}
|
||||||
12909
crds/prometheus-operator/crd-scrapeconfigs.yaml
Normal file
12909
crds/prometheus-operator/crd-scrapeconfigs.yaml
Normal file
File diff suppressed because it is too large
Load Diff
1413
crds/prometheus-operator/crd-servicemonitors.yaml
Normal file
1413
crds/prometheus-operator/crd-servicemonitors.yaml
Normal file
File diff suppressed because it is too large
Load Diff
9754
crds/prometheus-operator/crd-thanosrulers.yaml
Normal file
9754
crds/prometheus-operator/crd-thanosrulers.yaml
Normal file
File diff suppressed because it is too large
Load Diff
@ -1,5 +1,13 @@
|
|||||||
fullnameOverride: monitoring-stack
|
fullnameOverride: monitoring-stack
|
||||||
|
|
||||||
|
# ========================
|
||||||
|
# CRDs
|
||||||
|
# ========================
|
||||||
|
# CRDs are managed separately by the prometheus-operator-crds ArgoCD application
|
||||||
|
# to avoid the "metadata.annotations: Too long" error when Helm manages them
|
||||||
|
crds:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
# ========================
|
# ========================
|
||||||
# PROMETHEUS
|
# PROMETHEUS
|
||||||
# ========================
|
# ========================
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user