You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
There are some required values that will need to be used with this chart. The basic structure of the values file is:
cluster: {} # Cluster configuration, including the cluster namedestinations: [] # List of destinations where telemetry data will be sent# Features to enable, which determines what data to collectclusterMetrics: {}clusterEvents: {}# etc...
...
# Telemetry collector definitionsalloy-metrics: {}alloy-singleton: {}
Here is more detail about the different sections:
Cluster
This section defines the name of your cluster, which will be set as labels to all telemetry data.
This section defines the destinations for your telemetry data. You can configure multiple destinations for logs,
metrics, and traces. Here are the supported destination types:
The type of controller to use for the Alloy Logs instance.
alloy-logs.enabled
bool
false
Deploy the Alloy instance for collecting log data.
alloy-logs.extraConfig
string
""
Extra Alloy configuration to be added to the configuration file.
alloy-logs.liveDebugging.enabled
bool
false
Enable live debugging for the Alloy instance. Requires stability level to be set to "experimental".
alloy-logs.logging.format
string
"logfmt"
Format to use for writing Alloy log lines.
alloy-logs.logging.level
string
"info"
Level at which Alloy log lines should be written.
alloy-logs.remoteConfig.auth.password
string
""
The password to use for the remote config server.
alloy-logs.remoteConfig.auth.passwordFrom
string
""
Raw config for accessing the password.
alloy-logs.remoteConfig.auth.passwordKey
string
"password"
The key for storing the username in the secret.
alloy-logs.remoteConfig.auth.type
string
"none"
The type of authentication to use for the remote config server.
alloy-logs.remoteConfig.auth.username
string
""
The username to use for the remote config server.
alloy-logs.remoteConfig.auth.usernameFrom
string
""
Raw config for accessing the username.
alloy-logs.remoteConfig.auth.usernameKey
string
"username"
The key for storing the username in the secret.
alloy-logs.remoteConfig.enabled
bool
false
Enable fetching configuration from a remote config server.
alloy-logs.remoteConfig.secret.create
bool
true
Whether to create a secret for the remote config server.
alloy-logs.remoteConfig.secret.embed
bool
false
If true, skip secret creation and embed the credentials directly into the configuration.
alloy-logs.remoteConfig.secret.name
string
""
The name of the secret to create.
alloy-logs.remoteConfig.secret.namespace
string
""
The namespace for the secret.
alloy-logs.remoteConfig.url
string
""
The URL of the remote config server.
Collectors - Alloy Metrics
Key
Type
Default
Description
alloy-metrics.controller.replicas
int
1
The number of replicas for the Alloy Metrics instance.
alloy-metrics.controller.type
string
"statefulset"
The type of controller to use for the Alloy Metrics instance.
alloy-metrics.enabled
bool
false
Deploy the Alloy instance for collecting metrics.
alloy-metrics.extraConfig
string
""
Extra Alloy configuration to be added to the configuration file.
alloy-metrics.liveDebugging.enabled
bool
false
Enable live debugging for the Alloy instance. Requires stability level to be set to "experimental".
alloy-metrics.logging.format
string
"logfmt"
Format to use for writing Alloy log lines.
alloy-metrics.logging.level
string
"info"
Level at which Alloy log lines should be written.
alloy-metrics.remoteConfig.auth.password
string
""
The password to use for the remote config server.
alloy-metrics.remoteConfig.auth.passwordFrom
string
""
Raw config for accessing the password.
alloy-metrics.remoteConfig.auth.passwordKey
string
"password"
The key for storing the password in the secret.
alloy-metrics.remoteConfig.auth.type
string
"none"
The type of authentication to use for the remote config server.
alloy-metrics.remoteConfig.auth.username
string
""
The username to use for the remote config server.
alloy-metrics.remoteConfig.auth.usernameFrom
string
""
Raw config for accessing the password.
alloy-metrics.remoteConfig.auth.usernameKey
string
"username"
The key for storing the username in the secret.
alloy-metrics.remoteConfig.enabled
bool
false
Enable fetching configuration from a remote config server.
alloy-metrics.remoteConfig.extraAttributes
object
{}
Attributes to be added to this collector when requesting configuration.
alloy-metrics.remoteConfig.id
string
<cluster>-<namespace>-<pod-name>
The unique identifier for this Alloy instance.
alloy-metrics.remoteConfig.pollFrequency
string
"5m"
The frequency at which to poll the remote config server for updates.
alloy-metrics.remoteConfig.secret.create
bool
true
Whether to create a secret for the remote config server.
alloy-metrics.remoteConfig.secret.embed
bool
false
If true, skip secret creation and embed the credentials directly into the configuration.
alloy-metrics.remoteConfig.secret.name
string
""
The name of the secret to create.
alloy-metrics.remoteConfig.secret.namespace
string
""
The namespace for the secret.
alloy-metrics.remoteConfig.url
string
""
The URL of the remote config server.
Collectors - Alloy Profiles
Key
Type
Default
Description
alloy-profiles.controller.type
string
"daemonset"
The type of controller to use for the Alloy Profiles instance.
alloy-profiles.enabled
bool
false
Deploy the Alloy instance for gathering profiles.
alloy-profiles.extraConfig
string
""
Extra Alloy configuration to be added to the configuration file.
alloy-profiles.liveDebugging.enabled
bool
false
Enable live debugging for the Alloy instance. Requires stability level to be set to "experimental".
alloy-profiles.logging.format
string
"logfmt"
Format to use for writing Alloy log lines.
alloy-profiles.logging.level
string
"info"
Level at which Alloy log lines should be written.
alloy-profiles.remoteConfig.auth.password
string
""
The password to use for the remote config server.
alloy-profiles.remoteConfig.auth.passwordFrom
string
""
Raw config for accessing the password.
alloy-profiles.remoteConfig.auth.passwordKey
string
"password"
The key for storing the password in the secret.
alloy-profiles.remoteConfig.auth.type
string
"none"
The type of authentication to use for the remote config server.
alloy-profiles.remoteConfig.auth.username
string
""
The username to use for the remote config server.
alloy-profiles.remoteConfig.auth.usernameFrom
string
""
Raw config for accessing the username.
alloy-profiles.remoteConfig.auth.usernameKey
string
"username"
The key for storing the username in the secret.
alloy-profiles.remoteConfig.enabled
bool
false
Enable fetching configuration from a remote config server.
alloy-profiles.remoteConfig.secret.create
bool
true
Whether to create a secret for the remote config server.
alloy-profiles.remoteConfig.secret.embed
bool
false
If true, skip secret creation and embed the credentials directly into the configuration.
alloy-profiles.remoteConfig.secret.name
string
""
The name of the secret to create.
alloy-profiles.remoteConfig.secret.namespace
string
""
The namespace for the secret.
alloy-profiles.remoteConfig.url
string
""
The URL of the remote config server.
Collectors - Alloy Receiver
Key
Type
Default
Description
alloy-receiver.alloy.extraPorts
list
[]
The ports to expose for the Alloy receiver.
alloy-receiver.controller.type
string
"daemonset"
The type of controller to use for the Alloy Receiver instance.
alloy-receiver.enabled
bool
false
Deploy the Alloy instance for opening receivers to collect application data.
alloy-receiver.extraConfig
string
""
Extra Alloy configuration to be added to the configuration file.
alloy-receiver.liveDebugging.enabled
bool
false
Enable live debugging for the Alloy instance. Requires stability level to be set to "experimental".
alloy-receiver.logging.format
string
"logfmt"
Format to use for writing Alloy log lines.
alloy-receiver.logging.level
string
"info"
Level at which Alloy log lines should be written.
alloy-receiver.remoteConfig.auth.password
string
""
The password to use for the remote config server.
alloy-receiver.remoteConfig.auth.passwordFrom
string
""
Raw config for accessing the password.
alloy-receiver.remoteConfig.auth.passwordKey
string
"password"
The key for storing the password in the secret.
alloy-receiver.remoteConfig.auth.type
string
"none"
The type of authentication to use for the remote config server.
alloy-receiver.remoteConfig.auth.username
string
""
The username to use for the remote config server.
alloy-receiver.remoteConfig.auth.usernameFrom
string
""
Raw config for accessing the username.
alloy-receiver.remoteConfig.auth.usernameKey
string
"username"
The key for storing the username in the secret.
alloy-receiver.remoteConfig.enabled
bool
false
Enable fetching configuration from a remote config server.
alloy-receiver.remoteConfig.secret.create
bool
true
Whether to create a secret for the remote config server.
alloy-receiver.remoteConfig.secret.embed
bool
false
If true, skip secret creation and embed the credentials directly into the configuration.
alloy-receiver.remoteConfig.secret.name
string
""
The name of the secret to create.
alloy-receiver.remoteConfig.secret.namespace
string
""
The namespace for the secret.
alloy-receiver.remoteConfig.url
string
""
The URL of the remote config server.
Collectors - Alloy Singleton
Key
Type
Default
Description
alloy-singleton.controller.replicas
int
1
The number of replicas for the Alloy Singleton instance. This should remain a single instance to avoid duplicate data.
alloy-singleton.controller.type
string
"deployment"
The type of controller to use for the Alloy Singleton instance.
alloy-singleton.enabled
bool
false
Deploy the Alloy instance for data sources required to be deployed on a single replica.
alloy-singleton.extraConfig
string
""
Extra Alloy configuration to be added to the configuration file.
alloy-singleton.liveDebugging.enabled
bool
false
Enable live debugging for the Alloy instance. Requires stability level to be set to "experimental".
alloy-singleton.logging.format
string
"logfmt"
Format to use for writing Alloy log lines.
alloy-singleton.logging.level
string
"info"
Level at which Alloy log lines should be written.
alloy-singleton.remoteConfig.auth.password
string
""
The password to use for the remote config server.
alloy-singleton.remoteConfig.auth.passwordFrom
string
""
Raw config for accessing the password.
alloy-singleton.remoteConfig.auth.passwordKey
string
"password"
The key for storing the password in the secret.
alloy-singleton.remoteConfig.auth.type
string
"none"
The type of authentication to use for the remote config server.
alloy-singleton.remoteConfig.auth.username
string
""
The username to use for the remote config server.
alloy-singleton.remoteConfig.auth.usernameFrom
string
""
Raw config for accessing the username.
alloy-singleton.remoteConfig.auth.usernameKey
string
"username"
The key for storing the username in the secret.
alloy-singleton.remoteConfig.enabled
bool
false
Enable fetching configuration from a remote config server.
alloy-singleton.remoteConfig.secret.create
bool
true
Whether to create a secret for the remote config server.
alloy-singleton.remoteConfig.secret.embed
bool
false
If true, skip secret creation and embed the credentials directly into the configuration.
alloy-singleton.remoteConfig.secret.name
string
""
The name of the secret to create.
alloy-singleton.remoteConfig.secret.namespace
string
""
The namespace for the secret.
alloy-singleton.remoteConfig.url
string
""
The URL of the remote config server.
Features - Annotation Autodiscovery
Key
Type
Default
Description
annotationAutodiscovery
object
Disabled
Annotation Autodiscovery enables gathering metrics from Kubernetes Pods and Services discovered by special annotations. Requires a destination that supports metrics. To see the valid options, please see the Annotation Autodiscovery feature documentation.
annotationAutodiscovery.destinations
list
[]
The destinations where cluster metrics will be sent. If empty, all metrics-capable destinations will be used.
annotationAutodiscovery.enabled
bool
false
Enable gathering metrics from Kubernetes Pods and Services discovered by special annotations.
The destinations where cluster events will be sent. If empty, all logs-capable destinations will be used.
clusterEvents.enabled
bool
false
Enable gathering Kubernetes Cluster events.
Features - Cluster Metrics
Key
Type
Default
Description
clusterMetrics
object
Disabled
Cluster Monitoring enables observability and monitoring for your Kubernetes Cluster itself. Requires a destination that supports metrics. To see the valid options, please see the Cluster Monitoring feature documentation.
clusterMetrics.destinations
list
[]
The destinations where cluster metrics will be sent. If empty, all metrics-capable destinations will be used.
clusterMetrics.enabled
bool
false
Enable gathering Kubernetes Cluster metrics.
Destinations
Key
Type
Default
Description
destinations
list
[]
The list of destinations where telemetry data will be sent. See the destinations documentation for more information.
Global Settings
Key
Type
Default
Description
global.alloyModules.branch
string
"main"
If using git, the branch of the git repository to use.
global.alloyModules.source
string
"configMap"
The source of the Alloy modules. The valid options are "configMap" or "git"
global.maxCacheSize
int
100000
Sets the max_cache_size for every prometheus.relabel component. (docs) This should be at least 2x-5x your largest scrape target or samples appended rate.
global.platform
string
""
The specific platform for this cluster. Will enable compatibility for some platforms. Supported options: (empty) or "openshift".
global.scrapeInterval
string
"60s"
How frequently to scrape metrics.
Features - Service Integrations
Key
Type
Default
Description
integrations
object
No integrations enabled
Service Integrations enables gathering telemetry data for common services and applications deployed to Kubernetes. To see the valid options, please see the Service Integrations documentation.
integrations.destinations
list
[]
The destinations where integration metrics will be sent. If empty, all metrics-capable destinations will be used.
Features - Node Logs
Key
Type
Default
Description
nodeLogs
object
Disabled
Node logs. Requires a destination that supports logs. To see the valid options, please see the Node Logs feature documentation.
nodeLogs.destinations
list
[]
The destinations where logs will be sent. If empty, all logs-capable destinations will be used.
nodeLogs.enabled
bool
false
Enable gathering Kubernetes Cluster Node logs.
Features - Pod Logs
Key
Type
Default
Description
podLogs
object
Disabled
Pod logs. Requires a destination that supports logs. To see the valid options, please see the Pod Logs feature documentation.
podLogs.destinations
list
[]
The destinations where logs will be sent. If empty, all logs-capable destinations will be used.
podLogs.enabled
bool
false
Enable gathering Kubernetes Pod logs.
Features - Profiling
Key
Type
Default
Description
profiling
object
Disabled
Profiling enables gathering profiles from applications. Requires a destination that supports profiles. To see the valid options, please see the Profiling feature documentation.
profiling.destinations
list
[]
The destinations where profiles will be sent. If empty, all profiles-capable destinations will be used.
profiling.enabled
bool
false
Enable gathering profiles from applications.
Features - Prometheus Operator Objects
Key
Type
Default
Description
prometheusOperatorObjects
object
Disabled
Prometheus Operator Objects enables the gathering of metrics from objects like Probes, PodMonitors, and ServiceMonitors. Requires a destination that supports metrics. To see the valid options, please see the Prometheus Operator Objects feature documentation.
prometheusOperatorObjects.destinations
list
[]
The destinations where metrics will be sent. If empty, all metrics-capable destinations will be used.
prometheusOperatorObjects.enabled
bool
false
Enable gathering metrics from Prometheus Operator Objects.
Self-reporting creates a single metric and log that reports anonymized information about how this Helm chart was configured. It reports features enabled, destinations types used, and alloy instances enabled. It does not report any actual telemetry data, credentials or configuration, or send any data to any destination other than the ones configured above.
selfReporting.destinations
list
[]
The destinations where self-report metrics will be sent. If empty, all metrics-capable destinations will be used.
selfReporting.enabled
bool
true
Enable Self-reporting.
selfReporting.scrapeInterval
string
"1h"
How frequently to generate self-report metrics. This does utilize the global scrapeInterval setting.