1# -- Overrides the chart's name. Used to change the infix in the resource names.
3# -- Overrides the chart's namespace.
5# -- Overrides the chart's computed fullname. Used to change the full prefix of
8## Global properties for image pulling override the values defined under `image.registry` and `configReloader.image.registry`.
9## If you want to override only one image registry, use the specific fields but if you want to override them all, use `global.image.registry`
12 # -- Global image registry to use if it needs to be overridden for some specific use cases (e.g local registries, custom images, ...)
14 # -- Optional set of global image pull secrets.
16 # -- Global image pull policy to apply to all containers. Overrides `image.pullPolicy` and `configReloader.image.pullPolicy`.
18 # -- Security context to apply to the Grafana Alloy pod.
19 podSecurityContext: {}
21 # -- Whether to install CRDs for monitoring.
23## Various Alloy settings. For backwards compatibility with the grafana-agent
24## chart, this field may also be called "agent". Naming this field "agent" is
25## deprecated and will be removed in a future release.
28 # -- Create a new ConfigMap for the config file.
30 # -- Content to assign to the new ConfigMap. This is passed into `tpl` allowing for templating from values.
32 # -- Name of existing ConfigMap to use. Used when create is false.
34 # -- Key in ConfigMap to get config from.
37 # -- Deploy Alloy in a cluster to allow for load distribution.
39 # -- Name for the Alloy cluster. Used for differentiating between clusters.
41 # -- Name for the port used for clustering, useful if running inside an Istio Mesh
43 # -- Minimum stability level of components and behavior to enable. Must be
44 # one of "experimental", "public-preview", or "generally-available".
45 stabilityLevel: "generally-available"
46 # -- Path to where Grafana Alloy stores data (for example, the Write-Ahead Log).
47 # By default, data is lost between reboots.
48 storagePath: /tmp/alloy
49 # -- Enables Grafana Alloy container's http server port.
50 enableHttpServerPort: true
51 # -- Address to listen for traffic on. 0.0.0.0 exposes the UI to other
54 # -- Port to listen for traffic on.
56 # -- Scheme is needed for readiness probes. If enabling tls in your configs, set to "HTTPS"
58 # -- Initial delay for readiness probe.
59 initialDelaySeconds: 10
60 # -- Timeout for readiness probe.
62 # -- Base path where the UI is exposed.
64 # -- Enables sending Grafana Labs anonymous usage stats to help improve Grafana
67 # -- Extra environment variables to pass to the Alloy container.
69 # -- Maps all the keys on a ConfigMap or Secret as environment variables. https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.24/#envfromsource-v1-core
71 # -- Extra args to pass to `alloy run`: https://grafana.com/docs/alloy/latest/reference/cli/run/
73 # -- Extra ports to expose on the Alloy container.
74 # If `service.type` is `NodePort`, each item may set `nodePort` to choose the Service NodePort for that port.
83 # -- Host aliases to add to the Alloy container.
87 # - "company.grafana.net"
90 # -- Mount /var/log from the host into the container for log collection.
92 # -- Mount /var/lib/docker/containers from the host into the container for log
94 dockercontainers: false
95 # -- Extra volume mounts to add into the Grafana Alloy container. Does not
96 # affect the watch container.
98 # -- Security context to apply to the Grafana Alloy container.
100 # -- Resource requests and limits to apply to the Grafana Alloy container.
102 # -- Set lifecycle hooks for the Grafana Alloy container.
110 # -- Set livenessProbe for the Grafana Alloy container.
113 # -- Grafana Alloy image registry (defaults to docker.io)
115 # -- Grafana Alloy image repository.
116 repository: chainguard-private/grafana-alloy
117 # -- (string) Grafana Alloy image tag. When empty, the Chart's appVersion is
120 # -- Grafana Alloy image's SHA256 digest (either in format "sha256:XYZ" or "XYZ"). When set, will override `image.tag`.
121 digest: sha256:7adcd4256712a990af3dad0eb2b78b05b20605c8eb261853493531e1eec25857
122 # -- Grafana Alloy image pull policy.
123 pullPolicy: IfNotPresent
124 # -- Optional set of image pull secrets.
127 # -- Whether to create RBAC resources for Alloy.
129 # -- If set, only create Roles and RoleBindings in the given list of namespaces, rather than ClusterRoles and
130 # ClusterRoleBindings. If not using ClusterRoles, bear in mind that Alloy will not be able to discover cluster-scoped
131 # resources such as Nodes.
133 # -- The rules to create for the ClusterRole or Role objects.
135 # -- Rules required for the `discovery.kubernetes` component.
136 - apiGroups: ["", "discovery.k8s.io", "networking.k8s.io"]
137 resources: ["endpoints", "endpointslices", "ingresses", "pods", "services"]
138 verbs: ["get", "list", "watch"]
139 # -- Rules required for the `loki.source.kubernetes` component.
141 resources: ["pods", "pods/log", "namespaces"]
142 verbs: ["get", "list", "watch"]
143 # -- Rules required for the `loki.source.podlogs` component.
144 - apiGroups: ["monitoring.grafana.com"]
145 resources: ["podlogs"]
146 verbs: ["get", "list", "watch"]
147 # -- Rules required for the `mimir.rules.kubernetes` component.
148 - apiGroups: ["monitoring.coreos.com"]
149 resources: ["prometheusrules"]
150 verbs: ["get", "list", "watch"]
151 # -- Rules required for the `mimir.alerts.kubernetes` component.
152 - apiGroups: ["monitoring.coreos.com"]
153 resources: ["alertmanagerconfigs"]
154 verbs: ["get", "list", "watch"]
155 # -- Rules required for the `prometheus.operator.*` components.
156 - apiGroups: ["monitoring.coreos.com"]
157 resources: ["podmonitors", "servicemonitors", "probes", "scrapeconfigs"]
158 verbs: ["get", "list", "watch"]
159 # -- Rules required for the `loki.source.kubernetes_events` component.
161 resources: ["events"]
162 verbs: ["get", "list", "watch"]
163 # -- Rules required for the `remote.kubernetes.*` components.
165 resources: ["configmaps", "secrets"]
166 verbs: ["get", "list", "watch"]
167 # -- Rules required for the `otelcol.processor.k8sattributes` component.
168 - apiGroups: ["apps", "extensions"]
169 resources: ["replicasets"]
170 verbs: ["get", "list", "watch"]
171 # -- The rules to create for the ClusterRole objects.
173 # -- Rules required for the Nodes role in the `discovery.kubernetes` component.
176 verbs: ["get", "list", "watch"]
177 # -- Rules required for the `discovery.kubelet` component.
179 resources: ["nodes/pods"]
180 verbs: ["get", "list", "watch"]
181 # -- Rules required accessing metric endpoints on the Node (e.g. Kubelet, cAdvisor, etc...).
183 resources: ["nodes/metrics"]
184 verbs: ["get", "list", "watch"]
185 # -- Rules required for accessing metrics endpoint.
186 - nonResourceURLs: ["/metrics"]
189 # -- Whether to create a service account for the Grafana Alloy deployment.
191 # -- Additional labels to add to the created service account.
193 # -- Annotations to add to the created service account.
195 # -- The name of the existing service account to use when
196 # serviceAccount.create is false.
198 # Whether the Alloy pod should automatically mount the service account token.
199 automountServiceAccountToken: true
200# Options for the extra controller used for config reloading.
202 # -- Enables automatically reloading when the Alloy config changes.
205 # -- Config reloader image registry (defaults to docker.io)
207 # -- Repository to get config reloader image from.
208 repository: chainguard-private/prometheus-config-reloader
209 # -- Tag of image to use for config reloading.
211 # -- SHA256 digest of image to use for config reloading (either in format "sha256:XYZ" or "XYZ"). When set, will override `configReloader.image.tag`
212 digest: sha256:31e1e672a0f85742826d390870b4f8e522f174306a29a5053a1980a0244afc2a
213 # -- Config reloader image pull policy.
214 pullPolicy: IfNotPresent
215 # -- Override the args passed to the container.
217 # -- Resource requests and limits to apply to the config reloader container.
222 # -- Security context to apply to the Grafana configReloader container.
225 # -- Type of controller to use for deploying Grafana Alloy in the cluster.
226 # Must be one of 'daemonset', 'deployment', or 'statefulset'.
228 # -- Number of pods to deploy. Ignored when controller.type is 'daemonset'.
230 # -- Extra labels to add to the controller.
232 # -- Annotations to add to controller.
234 # -- Whether to deploy pods in parallel. Only used when controller.type is
236 parallelRollout: true
237 # -- How many additional seconds to wait before considering a pod ready.
239 # -- Configures Pods to use the host network. When set to true, the ports that will be used must be specified.
241 # -- Configures Pods to use the host PID namespace.
243 # -- Configures the DNS policy for the pod. https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-policy
244 dnsPolicy: ClusterFirst
245 # -- Termination grace period in seconds for the Grafana Alloy pods.
246 # The default value used by Kubernetes if unspecifed is 30 seconds.
247 terminationGracePeriodSeconds: null
248 # -- The maximum number of revisions that will be maintained in the Controllers's revision history. The history consists of all revisions not represented by a currently applied reversion.
249 revisionHistoryLimit: 10
250 # -- Update strategy for updating deployed Pods.
252 # -- nodeSelector to apply to Grafana Alloy pods.
254 # -- Tolerations to apply to Grafana Alloy pods.
256 # -- Topology Spread Constraints to apply to Grafana Alloy pods.
257 topologySpreadConstraints: []
258 # -- priorityClassName to apply to Grafana Alloy pods.
259 priorityClassName: ''
260 # -- Extra pod annotations to add.
262 # -- Extra pod labels to add.
264 # -- PodDisruptionBudget configuration.
266 # -- Whether to create a PodDisruptionBudget for the controller.
268 # -- Minimum number of pods that must be available during a disruption.
269 # Note: Only one of minAvailable or maxUnavailable should be set.
271 # -- Maximum number of pods that can be unavailable during a disruption.
272 # Note: Only one of minAvailable or maxUnavailable should be set.
274 # -- Whether to enable automatic deletion of stale PVCs due to a scale down operation, when controller.type is 'statefulset'.
275 enableStatefulSetAutoDeletePVC: false
277 # -- Creates a HorizontalPodAutoscaler for controller type deployment.
278 # Deprecated: Please use controller.autoscaling.horizontal instead
280 # -- The lower limit for the number of replicas to which the autoscaler can scale down.
282 # -- The upper limit for the number of replicas to which the autoscaler can scale up.
284 # -- Average CPU utilization across all relevant pods, a percentage of the requested value of the resource for the pods. Setting `targetCPUUtilizationPercentage` to 0 will disable CPU scaling.
285 targetCPUUtilizationPercentage: 0
286 # -- Average Memory utilization across all relevant pods, a percentage of the requested value of the resource for the pods. Setting `targetMemoryUtilizationPercentage` to 0 will disable Memory scaling.
287 targetMemoryUtilizationPercentage: 80
289 # -- List of policies to determine the scale-down behavior.
294 # -- Determines which of the provided scaling-down policies to apply if multiple are specified.
296 # -- The duration that the autoscaling mechanism should look back on to make decisions about scaling down.
297 stabilizationWindowSeconds: 300
299 # -- List of policies to determine the scale-up behavior.
304 # -- Determines which of the provided scaling-up policies to apply if multiple are specified.
306 # -- The duration that the autoscaling mechanism should look back on to make decisions about scaling up.
307 stabilizationWindowSeconds: 0
308 # -- Configures the Horizontal Pod Autoscaler for the controller.
310 # -- Enables the Horizontal Pod Autoscaler for the controller.
312 # -- The lower limit for the number of replicas to which the autoscaler can scale down.
314 # -- The upper limit for the number of replicas to which the autoscaler can scale up.
316 # -- Average CPU utilization across all relevant pods, a percentage of the requested value of the resource for the pods. Setting `targetCPUUtilizationPercentage` to 0 will disable CPU scaling.
317 targetCPUUtilizationPercentage: 0
318 # -- Average Memory utilization across all relevant pods, a percentage of the requested value of the resource for the pods. Setting `targetMemoryUtilizationPercentage` to 0 will disable Memory scaling.
319 targetMemoryUtilizationPercentage: 80
321 # -- List of policies to determine the scale-down behavior.
326 # -- Determines which of the provided scaling-down policies to apply if multiple are specified.
328 # -- The duration that the autoscaling mechanism should look back on to make decisions about scaling down.
329 stabilizationWindowSeconds: 300
331 # -- List of policies to determine the scale-up behavior.
336 # -- Determines which of the provided scaling-up policies to apply if multiple are specified.
338 # -- The duration that the autoscaling mechanism should look back on to make decisions about scaling up.
339 stabilizationWindowSeconds: 0
340 # -- Configures the Vertical Pod Autoscaler for the controller.
342 # -- Enables the Vertical Pod Autoscaler for the controller.
344 # -- List of recommenders to use for the Vertical Pod Autoscaler.
345 # Recommenders are responsible for generating recommendation for the object.
346 # List should be empty (then the default recommender will generate the recommendation)
347 # or contain exactly one recommender.
350 # - name: custom-recommender-performance
352 # -- Configures the resource policy for the Vertical Pod Autoscaler.
354 # -- Configures the container policies for the Vertical Pod Autoscaler.
356 - containerName: alloy
357 # -- The controlled resources for the Vertical Pod Autoscaler.
361 # -- The controlled values for the Vertical Pod Autoscaler. Needs to be either RequestsOnly or RequestsAndLimits.
362 controlledValues: "RequestsAndLimits"
363 # -- The maximum allowed values for the pods.
367 # -- Defines the min allowed resources for the pod
371 # -- Configures the update policy for the Vertical Pod Autoscaler.
373 # -- Specifies minimal number of replicas which need to be alive for VPA Updater to attempt pod eviction
375 # -- Specifies whether recommended updates are applied when a Pod is started and whether recommended updates
376 # are applied during the life of a Pod. Possible values are "Off", "Initial", "Recreate", and "Auto".
378 # -- Affinity configuration for pods.
381 # -- Extra volumes to add to the Grafana Alloy pod.
383 # -- volumeClaimTemplates to add when controller.type is 'statefulset'.
384 volumeClaimTemplates: []
385 ## -- Additional init containers to run.
386 ## ref: https://kubernetes.io/docs/concepts/workloads/pods/init-containers/
389 # -- Additional containers to run alongside the Alloy container and initContainers.
397 # Default allow all traffic because Alloy is so configurable
398 # It is recommended to change this before deploying to production
399 # To disable each policyType, set value to `null`
405 # -- Creates a Service for the controller's pods.
409 # -- NodePort port. Only takes effect when `service.type: NodePort`
411 # -- Cluster IP, can be set to None, empty "" or an IP address
413 # -- Value for internal traffic policy. 'Cluster' or 'Local'
414 internalTrafficPolicy: Cluster
416 # cloud.google.com/load-balancer-type: Internal
419 # -- Additional labels for the service monitor.
421 # -- Scrape interval. If not set, the Prometheus default scrape interval is used.
423 # -- MetricRelabelConfigs to apply to samples after scraping, but before ingestion.
424 # ref: https://github.com/prometheus-operator/prometheus-operator/blob/main/Documentation/api.md#relabelconfig
425 metricRelabelings: []
427 # regex: 'kube_(daemonset|deployment|pod|namespace|node|statefulset).+'
428 # sourceLabels: [__name__]
430 # -- Customize tls parameters for the service monitor
432 # -- RelabelConfigs to apply to samples before scraping
433 # ref: https://github.com/prometheus-operator/prometheus-operator/blob/main/Documentation/api.md#relabelconfig
435 # - sourceLabels: [__meta_kubernetes_pod_node_name]
438 # targetLabel: nodename
442 # -- Enables ingress for Alloy (Faro port)
444 # For Kubernetes >= 1.18 you should specify the ingress-controller via the field ingressClassName
445 # See https://kubernetes.io/blog/2020/04/02/improvements-to-the-ingress-api-in-kubernetes-1.18/#specifying-the-class-of-an-ingress
446 # ingressClassName: nginx
447 # Values can be templated
449 # kubernetes.io/ingress.class: nginx
450 # kubernetes.io/tls-acme: "true"
454 # pathType is only for k8s >= 1.1=
457 - chart-example.local
458 ## Extra paths to prepend to every host configuration. This is useful when working with annotation based services.
462 # serviceName: ssl-redirect
463 # servicePort: use-annotation
471 # name: use-annotation
474 # - secretName: chart-example-tls
476 # - chart-example.local
477# -- Extra k8s manifests to deploy
484# PROMETHEUS_HOST: 'https://prometheus-us-central1.grafana.net/api/prom/push'
485# PROMETHEUS_USERNAME: '123456'