Disable install crds
This commit is contained in:
parent
4f18336f89
commit
8cde902454
@ -20,4 +20,10 @@ spec:
|
||||
prune: true
|
||||
selfHeal: true
|
||||
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
|
||||
|
||||
# ========================
|
||||
# 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
|
||||
# ========================
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user