1# Default values for Traefik
2# This is a YAML-formatted file.
3# Declare variables to be passed into templates
5image: # @schema additionalProperties: false
6 # -- Traefik image host registry
8 # -- Traefik image repository
9 repository: chainguard-private/traefik
10 # -- defaults to appVersion. It's used for version checking, even prefixed with experimental- or latest-.
11 # To pin by digest, prefer `image.digest`. A `<version>@<digest>` combo is also accepted here; in that case the digest is what Kubernetes verifies and the version is informational (and can drift from the underlying image).
12 tag: latest@sha256:a1d046ceb7669fc10bb53d509b21a4f8835e69db8b510195de29fa582aa5f08b # @schema type:[string, null]
13 # -- Traefik image digest (e.g. `sha256:abc...`). When set, takes precedence over `tag`. Set `versionOverride` alongside it so the chart's version-checking logic knows the version (it cannot be derived from the digest).
14 digest: # @schema type:[string, null]; pattern:^sha256:[a-f0-9]{64}$
15 # -- Traefik image pull policy
16 pullPolicy: IfNotPresent
17# -- Add additional label to all resources
20 # -- Enable deployment
22 # -- Deployment or DaemonSet
24 # -- Number of pods of the deployment (only applies when kind == Deployment)
26 # -- Number of old history to retain to allow rollback (If not set, default Kubernetes value is set to 10)
27 revisionHistoryLimit: # @schema type:[integer, null];minimum:0
28 # -- Amount of time (in seconds) before Kubernetes will send the SIGKILL signal if Traefik does not shut down
29 terminationGracePeriodSeconds: 60
30 # -- The minimum number of seconds Traefik needs to be up and running before the DaemonSet/Deployment controller considers it available
32 ## -- Override the liveness/readiness port. This is useful to integrate traefik
33 ## with an external Load Balancer that performs healthchecks.
34 ## Default: ports.traefik.port
35 healthchecksPort: # @schema type:[integer, null];minimum:0
36 ## -- Override the liveness/readiness host. Useful for getting ping to respond on non-default entryPoint.
37 ## Default: ports.traefik.hostIP if set, otherwise Pod IP
39 ## -- Override the liveness/readiness scheme. Useful for getting ping to
40 ## respond on websecure entryPoint.
41 healthchecksScheme: # @schema enum:[HTTP, HTTPS, null]; type:[string, null]; default: HTTP
42 ## -- Override the readiness path.
45 # -- Override the liveness path.
48 # -- Additional deployment annotations (e.g. for jaeger-operator sidecar injection)
50 # -- Additional deployment labels (e.g. for filtering deployment by custom labels)
52 # -- Additional pod annotations (e.g. for mesh injection or prometheus scraping)
53 # It supports templating. One can set it with values like traefik/name: '{{ template "traefik.name" . }}'
55 # -- Additional Pod labels (e.g. for filtering Pod by custom labels)
56 # It supports templating. One can set it with values like traefik/name: '{{ template "traefik.name" . }}'
58 # -- Additional containers (e.g. for metric offloading sidecars)
59 additionalContainers: []
60 # https://docs.datadoghq.com/developers/dogstatsd/unix_socket/?tab=host
62 # image: alpine/socat:1.0.5
63 # args: ["-s", "-u", "udp-recv:8125", "unix-sendto:/socket/socket"]
67 # -- Additional volumes available for use with initContainers and additionalContainers
71 # path: /var/run/statsd-exporter
72 # -- Additional initContainers (e.g. for setting file permission as shown below)
74 # The "volume-permissions" init container is required if you run into permission issues.
75 # Related issue: https://github.com/traefik/traefik-helm-chart/issues/396
76 # - name: volume-permissions
77 # image: busybox:latest
78 # command: ["sh", "-c", "touch /data/acme.json; chmod -v 600 /data/acme.json"]
82 # -- Use process namespace sharing
83 shareProcessNamespace: false
84 # @schema type: [boolean, null]
85 # -- Whether to use the host user namespace. Setting this to false enables user namespaces,
86 # which can improve security by isolating the pod's users from the host.
87 # See https://kubernetes.io/docs/concepts/workloads/pods/user-namespaces/
88 # @default -- unset (inherits cluster default)
90 # -- Custom pod DNS policy. Apply if `hostNetwork: true`
92 # -- Custom pod [DNS config](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.30/#poddnsconfig-v1-core)
94 # -- Custom [host aliases](https://kubernetes.io/docs/tasks/network/customize-hosts-file-for-pods/)
96 # -- Pull secret for fetching traefik container image
98 # -- Pod lifecycle actions
109 # -- Set a runtimeClassName on pod
111 # -- Percentage of memory limit to set for GOMEMLIMIT, set as decimal (0.9 = 90%, 0.95 = 95% etc). Only takes effect when resources.limits.memory is set. Set to 0 to disable (e.g. when using VPA or setting it via env)
112 goMemLimitPercentage: 0.9
113# -- [Pod Disruption Budget](https://kubernetes.io/docs/reference/kubernetes-api/policy-resources/pod-disruption-budget-v1/)
114# @default -- See _values.yaml_
115podDisruptionBudget: # @schema additionalProperties: false
117 maxUnavailable: # @schema type:[string, integer, null];minimum:0
118 minAvailable: # @schema type:[string, integer, null];minimum:0
119ingressClass: # @schema additionalProperties: false
120 # -- Create a default IngressClass for Traefik
124core: # @schema additionalProperties: false
125 # -- Can be used to use globally v2 router syntax. Deprecated since v3.4 /!\.
126 # See https://doc.traefik.io/traefik/v3.0/migration/v2-to-v3/#new-v3-syntax-notable-changes
127 defaultRuleSyntax: ""
128# Traefik experimental features
130 # -- Defines whether all plugins must be loaded successfully for Traefik to start
131 abortOnPluginFailure: false
133 # -- Enables the FastProxy implementation.
135 # -- Enable debug mode for the FastProxy implementation.
138 # -- Enable traefik experimental GatewayClass CRD
140 # -- Enable experimental plugins
142 # -- Enable experimental local plugins
144 # -- Enable OTLP logging experimental feature.
146 # -- Enable Knative provider experimental feature.
149 # -- When providers.kubernetesGateway.enabled, deploy a default gateway
151 # -- Set a custom name to gateway
153 # -- By default, Gateway is created in the same `Namespace` as Traefik.
155 # -- Additional gateway annotations (e.g. for cert-manager.io/issuer)
157 # -- [Infrastructure](https://kubernetes.io/blog/2023/11/28/gateway-api-ga/#gateway-infrastructure-labels)
159 # -- Configure this Gateway as a [Default Gateway](https://kubernetes.io/blog/2025/11/06/gateway-api-v1-4/#introducing-default-gateways)
160 # by setting the `defaultScope` field (e.g. `All` or `Namespace`).
161 defaultScope: null # @schema enum:["All", "None", null]; type:[string, null]; default: null
164 # -- Port is the network port. Multiple listeners may use the same port, subject to the Listener compatibility rules.
165 # The port must match a port declared in ports section.
167 # -- Optional hostname. See [Hostname](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1.Hostname)
169 # Specify expected protocol on this listener. See [ProtocolType](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1.ProtocolType)
171 # -- (object) Routes are restricted to namespace of the gateway [by default](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1.FromNamespaces
172 namespacePolicy: # @schema type:[object, null]
173 # websecure listener is disabled by default because certificateRefs needs to be added,
174 # or you may specify TLS protocol with Passthrough mode and add "--providers.kubernetesGateway.experimentalChannel=true" in additionalArguments section.
176 # # -- Port is the network port. Multiple listeners may use the same port, subject to the Listener compatibility rules.
177 # # The port must match a port declared in ports section.
179 # # -- Optional hostname. See [Hostname](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1.Hostname)
181 # # Specify expected protocol on this listener See [ProtocolType](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1.ProtocolType)
183 # # -- Routes are restricted to namespace of the gateway [by default](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1.FromNamespaces)
185 # # -- Add certificates for TLS or HTTPS protocols. See [GatewayTLSConfig](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io%2fv1.GatewayTLSConfig)
187 # # -- TLS behavior for the TLS session initiated by the client. See [TLSModeType](https://gateway-api.sigs.k8s.io/reference/spec/#gateway.networking.k8s.io/v1.TLSModeType).
189gatewayClass: # @schema additionalProperties: false
190 # -- When providers.kubernetesGateway.enabled and gateway.enabled, deploy a default gatewayClass
192 # -- Set a custom name to GatewayClass
194 # -- Additional gatewayClass labels (e.g. for filtering gateway objects by custom labels)
196api: # @schema additionalProperties: false
197 # -- Enable the dashboard
199 # -- Custom name for the dashboard (v3.7+).
200 dashboardName: "" # @schema type:[string, null]
201 # -- Disable the advertisement from the dashboard.
202 disableDashboardAd: # @schema type:[boolean, null]
203 # -- Enable the insecure API (HTTP)
204 insecure: # @schema type:[boolean, null]
205 # -- Enable the debug API
206 debug: # @schema type:[boolean, null]
207 # -- Configure API basePath
208 basePath: "" # @schema type:[string, null]; default: "/"
209# -- Only dashboard & healthcheck IngressRoute are supported.
210# It's recommended to create workloads CR outside of this Chart.
211# @default -- See _values.yaml_
214 # -- Create an IngressRoute for the dashboard
216 # -- Additional ingressRoute annotations (e.g. for kubernetes.io/ingress.class)
218 # -- Additional ingressRoute labels (e.g. for filtering IngressRoute by custom labels)
220 # -- The router match rule used for the dashboard ingressRoute
221 matchRule: PathPrefix(`/dashboard`) || PathPrefix(`/api`)
222 # -- The internal service used for the dashboard ingressRoute
223 # @default -- api@internal
227 # -- Specify the allowed entrypoints to use for the dashboard ingress route, (e.g. traefik, web, websecure).
228 # By default, it's using traefik entrypoint, which is not exposed.
229 # /!\ Do not expose your dashboard without any protection over the internet /!\
230 entryPoints: ["traefik"]
231 # -- Additional ingressRoute middlewares (e.g. for authentication)
233 # -- TLS options (e.g. secret containing certificate)
236 # -- Create an IngressRoute for the healthcheck probe
238 # -- Additional ingressRoute annotations (e.g. for kubernetes.io/ingress.class)
240 # -- Additional ingressRoute labels (e.g. for filtering IngressRoute by custom labels)
242 # -- The router match rule used for the healthcheck ingressRoute
243 matchRule: PathPrefix(`/ping`)
244 # -- The internal service used for the healthcheck ingressRoute
245 # @default -- ping@internal
247 - name: ping@internal
249 # -- Specify the allowed entrypoints to use for the healthcheck ingress route, (e.g. traefik, web, websecure).
250 # By default, it's using traefik entrypoint, which is not exposed.
251 entryPoints: ["traefik"]
252 # -- Additional ingressRoute middlewares (e.g. for authentication)
254 # -- TLS options (e.g. secret containing certificate)
256updateStrategy: # @schema additionalProperties: false
257 # -- Customize updateStrategy of Deployment or DaemonSet
260 maxUnavailable: 0 # @schema type:[integer, string, null]
261 maxSurge: 1 # @schema type:[integer, string, null]
262readinessProbe: # @schema additionalProperties: false
263 # -- The number of consecutive failures allowed before considering the probe as failed.
265 # -- The number of seconds to wait before starting the first probe.
266 initialDelaySeconds: 2
267 # -- The number of seconds to wait between consecutive probes.
269 # -- The minimum consecutive successes required to consider the probe successful.
271 # -- The number of seconds to wait for a probe response before considering it as failed.
273livenessProbe: # @schema additionalProperties: false
274 # -- The number of consecutive failures allowed before considering the probe as failed.
276 # -- The number of seconds to wait before starting the first probe.
277 initialDelaySeconds: 2
278 # -- The number of seconds to wait between consecutive probes.
280 # -- The minimum consecutive successes required to consider the probe successful.
282 # -- The number of seconds to wait for a probe response before considering it as failed.
284# -- Define [Startup Probe](https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/#define-startup-probes)
286# @schema additionalProperties: false
288 # -- Defines the routing precedence between providers. See [upstream documentation](https://doc.traefik.io/traefik/reference/install-configuration/providers/overview/#routing-precedence) for the default order.
290 # @schema additionalProperties: false
292 # -- Load Kubernetes IngressRoute provider
294 # -- Allows IngressRoute to reference resources in namespace other than theirs
295 allowCrossNamespace: false
296 # -- Allows to reference ExternalName services in IngressRoute
297 allowExternalNameServices: false
298 # -- Allows to return 503 when there are no endpoints available
299 allowEmptyServices: true
300 # -- List of namespaces from which IngressRoute, IngressRouteTCP, IngressRouteUDP, and TraefikService are allowed to declare cross-provider references. Requires traefik v3.7.1+.
301 crossProviderNamespaces: []
302 # -- When the parameter is set, only resources containing an annotation with the same value are processed. Otherwise, resources missing the annotation, having an empty value, or the value traefik are processed. It will also set required annotation on Dashboard and Healthcheck IngressRoute when enabled.
304 # -- See [upstream documentation](https://doc.traefik.io/traefik/reference/install-configuration/providers/kubernetes/kubernetes-ingress/#opt-providers-kubernetesIngress-labelselector)
306 # -- Array of namespaces to watch. If left empty, Traefik watches all namespaces. . When using `rbac.namespaced`, it will watch helm release namespace and namespaces listed in this array.
308 # -- Defines whether to use Native Kubernetes load-balancing mode by default.
309 nativeLBByDefault: false
310 # @schema additionalProperties: false
312 # -- Load Kubernetes Ingress provider
314 # -- Allows to reference ExternalName services in Ingress
315 allowExternalNameServices: false
316 # -- Allows to return 503 when there are no endpoints available
317 allowEmptyServices: true
318 # -- List of namespaces from which Ingresses or Services are allowed to declare Middlewares, TLSOptions, or ServersTransport references. Requires traefik v3.7.1+.
319 crossProviderNamespaces: []
320 # -- Only for Traefik v3.0, Deprecated since v3.1. See [upstream documentation](https://doc.traefik.io/traefik/v3.0/providers/kubernetes-ingress/#disableingressclasslookup)
321 disableIngressClassLookup: false
322 # -- When ingressClass is set, only Ingresses containing an annotation with the same value are processed. Otherwise, Ingresses missing the annotation, having an empty value, or the value traefik are processed.
323 ingressClass: # @schema type:[string, null]
324 labelSelector: # @schema type:[string, null]
325 # -- Array of namespaces to watch. If left empty, Traefik watches all namespaces. . When using `rbac.namespaced`, it will watch helm release namespace and namespaces listed in this array.
327 # IP used for Kubernetes Ingress endpoints
329 # -- Enable [publishedService](https://doc.traefik.io/traefik/reference/install-configuration/providers/kubernetes/kubernetes-ingress/#ingressendpointpublishedservice),
330 # usually with the Service provided by this Chart. It's possible to use it with an external Service using pathOverride.
332 # -- Override path of Kubernetes Service used to copy status from. Format: namespace/servicename.
333 # Default to Service deployed with this Chart.
335 # @schema additionalProperties: false
337 # -- Hostname used for Kubernetes Ingress endpoints
338 hostname: "" # @schema type:[string, null]
339 # -- IP used for Kubernetes Ingress endpoints
340 ip: "" # @schema type:[string, null]
341 # -- Defines whether to use Native Kubernetes load-balancing mode by default.
342 nativeLBByDefault: false
343 # -- Defines whether to make prefix matching strictly comply with the Kubernetes Ingress specification.
344 strictPrefixMatching: false
345 # @schema additionalProperties: false
347 # -- Enable Traefik Gateway provider for Gateway API
349 # -- List of namespaces from which Gateway API routes are allowed to declare TraefikService backendRef references. Requires traefik v3.7.1+.
350 crossProviderNamespaces: []
351 # -- Toggles support for the Experimental Channel resources (Gateway API release channels documentation).
352 # This option currently enables support for TCPRoute and TLSRoute.
353 experimentalChannel: false
354 # -- Array of namespaces to watch. If left empty, Traefik watches all namespaces. kubernetesGateway provider requires ClusterRole and as a consequence `rbac.namespaced` is not supported.
356 # -- A label selector can be defined to filter on specific GatewayClass objects only.
358 # -- Defines whether to use Native Kubernetes load-balancing mode by default.
359 nativeLBByDefault: false
361 # -- This IP will get copied to the Gateway status.addresses, and currently only supports one IP value (IPv4 or IPv6).
363 # -- This Hostname will get copied to the Gateway status.addresses.
366 # -- The Kubernetes service to copy status addresses from. When using third parties tools like External-DNS, this option can be used to copy the service loadbalancer.status (containing the service's endpoints IPs) to the gateways. Default to Service of this Chart.
370 # @schema additionalProperties: false
372 # -- Create a file provider
374 # -- Allows Traefik to automatically watch for file changes
376 # -- File content (YAML format, go template supported) (see https://doc.traefik.io/traefik/reference/install-configuration/providers/others/file/)
378 # @schema additionalProperties: false
379 kubernetesIngressNGINX:
380 # -- Enable Kubernetes Ingress NGINX provider
382 # -- Ingress Class Controller value this controller satisfies
383 controllerClass: "k8s.io/ingress-nginx"
384 # -- Name of the ingress class this controller satisfies
385 ingressClass: "nginx"
386 # -- Define if Ingress Controller should watch for Ingress Class by Name together with Controller Class
387 ingressClassByName: false
388 # -- Define if Ingress Controller should also watch for Ingresses without an IngressClass or the annotation specified
389 watchIngressWithoutClass: false
390 # -- Single namespace the controller watches for updates to Kubernetes objects. Mutually exclusive with watchNamespaceSelector.
392 # -- Select namespaces the controller watches for updates to Kubernetes objects. Mutually exclusive with watchNamespace.
393 watchNamespaceSelector: ""
395 # -- Service fronting the Ingress controller. Takes the form 'namespace/name'
398 # -- Customized address (or addresses, separated by comma) to set as the load-balancer status of Ingress objects this controller satisfies
399 publishStatusAddress: ""
400 # -- Service used to serve HTTP requests not matching any known server name (catch-all). Takes the form 'namespace/name'
401 defaultBackendService: ""
402 # -- Disable support for Services of type ExternalName
403 disableSvcExternalName: false
404 # -- Ingress refresh throttle duration
406 # -- Kubernetes certificate authority file path (not needed for in-cluster client)
408 # -- Kubernetes server endpoint (required for external cluster client)
410 # -- Kubernetes bearer token (not needed for in-cluster client). It accepts either a token value or a file path to the token
412 # -- Defines whether to enable request buffering (default: false)
413 proxyRequestBuffering: null # @schema type:[boolean, null]
414 # -- Default buffer size for reading client request body in bytes (default: 16384)
415 clientBodyBufferSize: # @schema type:[integer, null]
416 # -- Default maximum size of a client request body in bytes (default: 1048576)
417 proxyBodySize: # @schema type:[integer, null]
418 # -- Defines whether to enable response buffering (default: false)
419 proxyBuffering: null # @schema type:[boolean, null]
420 # -- Default buffer size for reading the response body in bytes (default: 8192)
421 proxyBufferSize: # @schema type:[integer, null]
422 # -- Default number of buffers for reading a response (default: 4)
423 proxyBuffersNumber: # @schema type:[integer, null]
424 # -- Amount of time to wait until a connection to a server can be established. Unitless, in seconds (default: 60)
425 proxyConnectTimeout: # @schema type:[integer, null]
426 # -- Amount of time between two successive read operations. Unitless, in seconds (default: 60)
427 proxyReadTimeout: # @schema type:[integer, null]
428 # -- Amount of time between two successive write operations. Unitless, in seconds (default: 60)
429 proxySendTimeout: # @schema type:[integer, null]
430 # -- Defines in which cases a request should be retried (default: "error timeout")
431 proxyNextUpstream: ""
432 # -- Limits the number of possible tries if the backend server does not reply (default: 3)
433 proxyNextUpstreamTries: # @schema type:[integer, null]
434 # -- Limits the total elapsed time to retry the request. Unitless, in seconds (default: 0)
435 proxyNextUpstreamTimeout: # @schema type:[integer, null]
436 # -- Defines which HTTP status codes should result in calling the default backend to return an error page
438 # -- Defines the idle timeout for keep-alive connections to upstream servers. Unitless, in seconds (default: 60)
439 upstreamKeepaliveTimeout: # @schema type:[integer, null]
440 # -- Allow Ingress to reference resources (e.g. ConfigMaps, Secrets) in different namespaces (default: false)
441 allowCrossNamespaceResources: null # @schema type:[boolean, null]
442 # -- List of allowed response headers inside the custom headers annotations
443 globalAllowedResponseHeaders: []
444 # -- URL to the service that provides authentication for all the locations. Per ingress auth-url annotation has precedence over this option.
446 # -- When set, the strategy is applied to every generated IPAllowList middleware.
447 # @default -- See below
449 # -- Number of trusted proxy hops to skip when extracting the client IP from the X-Forwarded-For header. 0 disables depth-based extraction. (default: 0)
451 # -- List of IPs to exclude when scanning the X-Forwarded-For header to find the client IP.
453 # -- IPv6 subnet size used to group IPv6 addresses when checking the allow list. 0 disables subnet grouping.
455 # -- Enables parsing and adding -snippet annotations/directives (default: false)
456 allowSnippetAnnotations: null # @schema type:[boolean, null]
457 # -- Defines whether to reject the entire ingress when any path contains regex characters and pathType is Prefix or Exact (default: true)
458 strictValidatePathType: null # @schema type:[boolean, null]
459 # -- Defines the EntryPoint to use for HTTP requests
460 httpEntryPoint: "web"
461 # -- Defines the EntryPoint to use for HTTPS requests
462 httpsEntryPoint: "websecure"
463 # @schema additionalProperties: false
465 # -- Enable ModSec engine. Requires Traefik Hub >= v3.20.0-ea.8.
467 # -- Enable OWASP Core Rules.
468 owaspCoreRules: false
469 # -- Custom ModSec rules snippet.
471 # @schema additionalProperties: false
473 # -- Enable Knative provider
475 # -- Array of namespaces to watch. If left empty, Traefik watches all namespaces. . When using `rbac.namespaced`, it will watch helm release namespace and namespaces listed in this array.
477 # -- Allow filtering Knative Ingress objects
479# -- Add volumes to the traefik pod. The volume name will be passed to tpl.
480# This can be used to mount a cert pair or a configmap that holds a config.toml file.
481# After the volume has been mounted, add the configs into traefik by using the `additionalArguments` list below, eg:
482# `additionalArguments:
483# - "--providers.file.filename=/config/dynamic.toml"
485# - "--ping.entrypoint=web"`
490# - name: '{{ printf "%s-configs" .Release.Name }}'
491# mountPath: "/config"
494# -- Additional volumeMounts to add to the Traefik container
495additionalVolumeMounts: []
496# -- For instance when using a logshipper for access logs
497# - name: traefik-logs
498# mountPath: /var/log/traefik
502 # -- Set [logs format](https://doc.traefik.io/traefik/reference/install-configuration/observability/logs-and-accesslogs/#opt-log-format)
503 format: # @schema enum:["common", "json", null]; type:[string, null]; default: "common"
504 # By default, the level is set to INFO.
505 # -- Alternative logging levels are TRACE, DEBUG, INFO, WARN, ERROR, FATAL, and PANIC.
506 level: "INFO" # @schema enum:[TRACE,DEBUG,INFO,WARN,ERROR,FATAL,PANIC]; default: "INFO"
507 # -- To write the logs into a log file, use the filePath option.
509 # -- When set to true and format is common, it disables the colorized output.
512 # -- Set to true in order to enable OpenTelemetry on logs. Note that experimental.otlpLogs needs to be enabled.
514 # -- Service name used in OTLP backend. Default: traefik.
515 serviceName: # @schema type:[string, null]
517 # -- Set to true in order to send logs to the OpenTelemetry Collector using HTTP.
519 # -- Format: <scheme>://<host>:<port><path>. Default: https://localhost:4318/v1/logs
521 # -- Additional headers sent with logs by the reporter to the OpenTelemetry Collector.
523 ## Defines the TLS configuration used by the reporter to send logs to the OpenTelemetry Collector.
525 # -- The path to the certificate authority, it defaults to the system bundle.
527 # -- The path to the public certificate. When using this option, setting the key option is required.
529 # -- The path to the private key. When using this option, setting the cert option is required.
531 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
532 insecureSkipVerify: # @schema type:[boolean, null]
534 # -- Set to true in order to send logs to the OpenTelemetry Collector using gRPC
536 # -- Format: <host>:<port>. Default: "localhost:4317"
538 # -- Allows reporter to send logs to the OpenTelemetry Collector without using a secured protocol.
540 ## Defines the TLS configuration used by the reporter to send logs to the OpenTelemetry Collector.
542 # -- The path to the certificate authority, it defaults to the system bundle.
544 # -- The path to the public certificate. When using this option, setting the key option is required.
546 # -- The path to the private key. When using this option, setting the cert option is required.
548 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
549 insecureSkipVerify: # @schema type:[boolean, null]
550 # -- Defines additional resource attributes to be sent to the collector.
551 resourceAttributes: {}
553 # -- To enable access logs
555 # -- Set [access log format](https://doc.traefik.io/traefik/reference/install-configuration/observability/logs-and-accesslogs/#opt-accesslog-format)
556 format: # @schema enum:["common", "genericCLF", "json", null]; type:[string, null]; default: "common"
557 # filePath: "/var/log/traefik/access.log
558 # -- Set [bufferingSize](https://doc.traefik.io/traefik/reference/install-configuration/observability/logs-and-accesslogs/#opt-accesslog-bufferingSize)
559 bufferingSize: # @schema type:[integer, null]
560 # -- Set [timezone](https://doc.traefik.io/traefik/reference/install-configuration/observability/logs-and-accesslogs/#time-zones)
562 # -- Set [filtering](https://doc.traefik.io/traefik/observe/logs-and-access-logs/#access-log-filters)
563 # @default -- See below
564 filters: # @schema additionalProperties: false
565 # -- Set statusCodes, to limit the access logs to requests with a status codes in the specified range
567 # -- Set retryAttempts, to keep the access logs when at least one retry has happened
569 # -- Set minDuration, to keep access logs when requests take longer than the specified duration
571 # -- Enables accessLogs for internal resources. Default: false.
573 # -- Enables access log output alongside OTLP (v3.7+).
577 # -- Set default mode for fields.names
578 defaultmode: keep # @schema enum:[keep, drop, redact]; default: keep
579 # -- Names of the fields to limit.
582 # -- [Limit logged fields or headers](https://doc.traefik.io/traefik/observe/logs-and-access-logs/#log-fields-customization)
583 defaultmode: drop # @schema enum:[keep, drop, redact]; default: drop
586 # -- Set to true in order to enable OpenTelemetry on access logs. Note that experimental.otlpLogs needs to be enabled.
588 # -- Service name used in OTLP backend. Default: traefik.
589 serviceName: # @schema type:[string, null]
591 # -- Set to true in order to send access logs to the OpenTelemetry Collector using HTTP.
593 # -- Format: <scheme>://<host>:<port><path>. Default: https://localhost:4318/v1/logs
595 # -- Additional headers sent with access logs by the reporter to the OpenTelemetry Collector.
597 ## Defines the TLS configuration used by the reporter to send access logs to the OpenTelemetry Collector.
599 # -- The path to the certificate authority, it defaults to the system bundle.
601 # -- The path to the public certificate. When using this option, setting the key option is required.
603 # -- The path to the private key. When using this option, setting the cert option is required.
605 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
606 insecureSkipVerify: # @schema type:[boolean, null]
608 # -- Set to true in order to send access logs to the OpenTelemetry Collector using gRPC
610 # -- Format: <host>:<port>. Default: "localhost:4317"
612 # -- Allows reporter to send access logs to the OpenTelemetry Collector without using a secured protocol.
614 ## Defines the TLS configuration used by the reporter to send access logs to the OpenTelemetry Collector.
616 # -- The path to the certificate authority, it defaults to the system bundle.
618 # -- The path to the public certificate. When using this option, setting the key option is required.
620 # -- The path to the private key. When using this option, setting the cert option is required.
622 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
623 insecureSkipVerify: # @schema type:[boolean, null]
624 # -- Defines additional resource attributes to be sent to the collector.
625 resourceAttributes: {}
627 # -- Enable metrics for internal resources. Default: false
629 ## Prometheus is enabled by default.
630 ## It can be disabled by setting "prometheus: null"
632 # -- Entry point used to expose metrics.
634 # -- Enable metrics on entry points. Default: true
635 addEntryPointsLabels: # @schema type:[boolean, null]
636 # -- Enable metrics on routers. Default: false
637 addRoutersLabels: # @schema type:[boolean, null]
638 # -- Enable metrics on services. Default: true
639 addServicesLabels: # @schema type:[boolean, null]
640 # -- Buckets for latency metrics. Default="0.1,0.3,1.2,5.0"
642 # -- When manualRouting is true, it disables the default internal router in
643 ## order to allow creating a custom router for prometheus@internal service.
645 # -- Add HTTP header labels to metrics. See EXAMPLES.md or upstream doc for usage.
646 headerLabels: {} # @schema type:[object, null]
648 # -- Create a dedicated metrics service to use with ServiceMonitor
652 # -- When set to true, it won't check if Prometheus Operator CRDs are deployed
653 disableAPICheck: # @schema type:[boolean, null]
655 # -- Enable optional CR for Prometheus Operator. See EXAMPLES.md for more details.
657 apiVersion: "monitoring.coreos.com/v1"
658 metricRelabelings: []
664 honorTimestamps: false
666 followRedirects: false
669 namespaceSelector: {}
671 # -- Enable optional CR for Prometheus Operator. See EXAMPLES.md for more details.
673 apiVersion: "monitoring.coreos.com/v1"
677 # ## Address instructs exporter to send metrics to datadog-agent at this address.
678 # address: "127.0.0.1:8125"
679 # ## The interval used by the exporter to push metrics to datadog-agent. Default=10s
680 # # pushInterval: 30s
681 # ## The prefix to use for metrics collection. Default="traefik"
683 # ## Enable metrics on entry points. Default=true
684 # # addEntryPointsLabels: false
685 # ## Enable metrics on routers. Default=false
686 # # addRoutersLabels: true
687 # ## Enable metrics on services. Default=true
688 # # addServicesLabels: false
690 # ## Address instructs exporter to send metrics to influxdb v2 at this address.
691 # address: localhost:8086
692 # ## Token with which to connect to InfluxDB v2.
694 # ## Organisation where metrics will be stored.
696 # ## Bucket where metrics will be stored.
698 # ## The interval used by the exporter to push metrics to influxdb. Default=10s
699 # # pushInterval: 30s
700 # ## Additional labels (influxdb tags) on all metrics.
701 # # additionalLabels:
704 # ## Enable metrics on entry points. Default=true
705 # # addEntryPointsLabels: false
706 # ## Enable metrics on routers. Default=false
707 # # addRoutersLabels: true
708 # ## Enable metrics on services. Default=true
709 # # addServicesLabels: false
711 # ## Address instructs exporter to send metrics to statsd at this address.
712 # address: localhost:8125
713 # ## The interval used by the exporter to push metrics to influxdb. Default=10s
714 # # pushInterval: 30s
715 # ## The prefix to use for metrics collection. Default="traefik"
717 # ## Enable metrics on entry points. Default=true
718 # # addEntryPointsLabels: false
719 # ## Enable metrics on routers. Default=false
720 # # addRoutersLabels: true
721 # ## Enable metrics on services. Default=true
722 # # addServicesLabels: false
724 # -- Set to true in order to enable the OpenTelemetry metrics
726 # -- Enable metrics on entry points. Default: true
727 addEntryPointsLabels: # @schema type:[boolean, null]
728 # -- Enable metrics on routers. Default: false
729 addRoutersLabels: # @schema type:[boolean, null]
730 # -- Enable metrics on services. Default: true
731 addServicesLabels: # @schema type:[boolean, null]
732 # -- Explicit boundaries for Histogram data points. Default: [.005, .01, .025, .05, .1, .25, .5, 1, 2.5, 5, 10]
733 explicitBoundaries: []
734 # -- Interval at which metrics are sent to the OpenTelemetry Collector. Default: 10s
736 # -- Service name used in OTLP backend. Default: traefik.
737 serviceName: # @schema type:[string, null]
739 # -- Set to true in order to send metrics to the OpenTelemetry Collector using HTTP.
741 # -- Format: <scheme>://<host>:<port><path>. Default: https://localhost:4318/v1/metrics
743 # -- Additional headers sent with metrics by the reporter to the OpenTelemetry Collector.
745 ## Defines the TLS configuration used by the reporter to send metrics to the OpenTelemetry Collector.
747 # -- The path to the certificate authority, it defaults to the system bundle.
749 # -- The path to the public certificate. When using this option, setting the key option is required.
751 # -- The path to the private key. When using this option, setting the cert option is required.
753 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
754 insecureSkipVerify: # @schema type:[boolean, null]
756 # -- Set to true in order to send metrics to the OpenTelemetry Collector using gRPC
758 # -- Format: <host>:<port>. Default: "localhost:4317"
760 # -- Allows reporter to send metrics to the OpenTelemetry Collector without using a secured protocol.
762 ## Defines the TLS configuration used by the reporter to send metrics to the OpenTelemetry Collector.
764 # -- The path to the certificate authority, it defaults to the system bundle.
766 # -- The path to the public certificate. When using this option, setting the key option is required.
768 # -- The path to the private key. When using this option, setting the cert option is required.
770 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
771 insecureSkipVerify: # @schema type:[boolean, null]
772 # -- Defines additional resource attributes to be sent to the collector.
773 resourceAttributes: {}
775 # -- Enable OCSP stapling support.
776 # See https://doc.traefik.io/traefik/reference/install-configuration/tls/ocsp/
778 # -- Defines the OCSP responder URLs to use instead of the one provided by the certificate.
779 responderOverrides: {}
781# -- https://doc.traefik.io/traefik/reference/install-configuration/observability/tracing/
782# @default -- See _values.yaml_
783tracing: # @schema additionalProperties: false
784 # -- Enables tracing for internal resources. Default: false.
786 # -- Service name used in selected backend. Default: traefik.
787 serviceName: # @schema type:[string, null]
788 # -- Defines additional resource attributes to be sent to the collector.
789 resourceAttributes: {}
790 # -- Defines the list of request headers to add as attributes. It applies to client and server kind spans.
791 capturedRequestHeaders: []
792 # -- Defines the list of response headers to add as attributes. It applies to client and server kind spans.
793 capturedResponseHeaders: []
794 # -- By default, all query parameters are redacted. Defines the list of query parameters to not redact.
796 # -- The proportion of requests to trace, specified between 0.0 and 1.0. Default: 1.0.
797 sampleRate: # @schema type:[number, null]; minimum:0; maximum:1
799 # -- See https://doc.traefik.io/traefik/reference/install-configuration/observability/tracing/#configuration-options
802 # -- Set to true in order to send metrics to the OpenTelemetry Collector using HTTP.
804 # -- Format: <scheme>://<host>:<port><path>. Default: https://localhost:4318/v1/tracing
806 # -- Additional headers sent with metrics by the reporter to the OpenTelemetry Collector.
808 ## Defines the TLS configuration used by the reporter to send metrics to the OpenTelemetry Collector.
810 # -- The path to the certificate authority, it defaults to the system bundle.
812 # -- The path to the public certificate. When using this option, setting the key option is required.
814 # -- The path to the private key. When using this option, setting the cert option is required.
816 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
817 insecureSkipVerify: # @schema type:[boolean, null]
819 # -- Set to true in order to send metrics to the OpenTelemetry Collector using gRPC
821 # -- Format: <host>:<port>. Default: "localhost:4317"
823 # -- Allows reporter to send metrics to the OpenTelemetry Collector without using a secured protocol.
825 ## Defines the TLS configuration used by the reporter to send metrics to the OpenTelemetry Collector.
827 # -- The path to the certificate authority, it defaults to the system bundle.
829 # -- The path to the public certificate. When using this option, setting the key option is required.
831 # -- The path to the private key. When using this option, setting the cert option is required.
833 # -- When set to true, the TLS connection accepts any certificate presented by the server regardless of the hostnames it covers.
834 insecureSkipVerify: # @schema type:[boolean, null]
836 checkNewVersion: true
837 # -- Please take time to consider whether or not you wish to share anonymous data with us
838 # See https://doc.traefik.io/traefik/contributing/data-collection/
839 sendAnonymousUsage: false
840 # -- Disable appending RemoteAddr to X-Forwarded-For header globally (v3.7+).
841 notAppendXForwardedFor: false
842 # -- Required for Azure Marketplace integration.
843 # See https://learn.microsoft.com/en-us/partner-center/marketplace-offers/azure-container-technical-assets-kubernetes?tabs=linux,linux2#update-the-helm-chart
844 # @default -- See _values.yaml_
849 image: chainguard-private/traefik
850 tag: latest@sha256:a1d046ceb7669fc10bb53d509b21a4f8835e69db8b510195de29fa582aa5f08b
853 image: chainguard-private/traefik
854 tag: latest@sha256:a1d046ceb7669fc10bb53d509b21a4f8835e69db8b510195de29fa582aa5f08b
856# -- Additional arguments to be passed at Traefik's binary
857# See [CLI Reference](https://docs.traefik.io/reference/static-configuration/cli/)
858# Use curly braces to pass values: `helm install --set="additionalArguments={--providers.kubernetesingress.ingressclass=traefik-internal,--log.level=DEBUG}"`
859additionalArguments: []
860# - "--providers.kubernetesingress.ingressclass=traefik-internal"
861# - "--log.level=DEBUG"
863# -- Additional Environment variables to be passed to Traefik's binary
865# -- Environment variables to be passed to Traefik's binary from configMaps or secrets
867# @schema mergeProperties: true
869 # @schema additionalProperties: false
872 # -- Use hostPort if set.
873 hostPort: # @schema type:[integer, null]; minimum:0
874 # -- Use hostIP if set. If not set, Kubernetes will default to 0.0.0.0, which
875 # means it's listening on all your interfaces and all your IPs. You may want
876 # to set this value if you need traefik to listen on specific interface
878 hostIP: # @schema type:[string, null]
879 # Defines whether the port is exposed if service.type is LoadBalancer or
882 # -- You SHOULD NOT expose the traefik port on production deployments.
883 # If you want to access it from outside your cluster,
884 # use `kubectl port-forward` or create a secure ingress
887 # -- The exposed port for this service
889 # -- The port protocol (TCP/UDP)
891 observability: # @schema additionalProperties: false
892 # -- Defines whether a router attached to this EntryPoint produces metrics by default.
893 metrics: # @schema type:[boolean, null]; default: true
894 # -- Defines whether a router attached to this EntryPoint produces access-logs by default.
895 accessLogs: # @schema type:[boolean, null]; default: true
896 # -- Defines whether a router attached to this EntryPoint produces traces by default.
897 tracing: # @schema type:[boolean, null]; default: true
898 # -- Defines the tracing verbosity level for routers attached to this EntryPoint.
899 traceVerbosity: # @schema enum:[minimal, detailed, null]; type:[string, null]; default: minimal
901 ## -- Enable this entrypoint as a default entrypoint. When a service doesn't explicitly set an entrypoint it will only use this entrypoint.
902 asDefault: # @schema type: [boolean, null]; default: null
905 # containerPort: 8000
909 ## -- Different target traefik port on the cluster, useful for IP type LB
910 targetPort: # @schema type:[string, integer, null]; minimum:0
911 # The port protocol (TCP/UDP)
913 # -- See [upstream documentation](https://kubernetes.io/docs/concepts/services-networking/service/#type-nodeport)
914 nodePort: # @schema type:[integer, null]; minimum:0
915 # -- See [upstream documentation](https://doc.traefik.io/traefik/reference/install-configuration/entrypoints/#allowacmebypass)
916 allowACMEByPass: false
919 # -- Port Redirections
920 # Added in 2.2, one can make permanent redirects via entrypoints.
921 # Same sets of parameters: to, scheme, permanent and priority.
922 # https://doc.traefik.io/traefik/reference/install-configuration/entrypoints/#configuration-example
925 # -- Trust forwarded headers information (X-Forwarded-*).
928 # -- Disable appending RemoteAddr to X-Forwarded-For header (v3.7+).
929 notAppendXForwardedFor: false
931 # -- Enable the Proxy Protocol header parsing for the entry point
934 # -- Set transport settings for the entrypoint
938 readTimeout: # @schema type:[string, integer, null]
939 writeTimeout: # @schema type:[string, integer, null]
940 idleTimeout: # @schema type:[string, integer, null]
942 requestAcceptGraceTimeout: # @schema type:[string, integer, null]
943 graceTimeOut: # @schema type:[string, integer, null]
944 keepAliveMaxRequests: # @schema type:[integer, null]; minimum:0
945 keepAliveMaxTime: # @schema type:[string, integer, null]
946 # -- Enable this port as an uplink for multi cluster.
947 # ⚠️ This feature is experimental and requires Traefik Hub with a specific subscription.
948 uplink: # @schema type: [boolean, null]; default: null
949 observability: # @schema additionalProperties: false
950 # -- Enables metrics for this entryPoint.
951 metrics: # @schema type:[boolean, null]; default: true
952 # -- Enables access-logs for this entryPoint.
953 accessLogs: # @schema type:[boolean, null]; default: true
954 # -- Enables tracing for this entryPoint.
955 tracing: # @schema type:[boolean, null]; default: true
956 # -- Defines the tracing verbosity level for this entryPoint.
957 traceVerbosity: # @schema enum:[minimal, detailed, null]; type:[string, null]; default: minimal
959 ## -- Enable this entrypoint as a default entrypoint. When a service doesn't explicitly set an entrypoint it will only use this entrypoint.
962 hostPort: # @schema type:[integer, null]; minimum:0
963 containerPort: # @schema type:[integer, null]; minimum:0
967 ## -- Different target traefik port on the cluster, useful for IP type LB
968 targetPort: # @schema type:[string, integer, null]; minimum:0
969 ## -- The port protocol (TCP/UDP)
971 # -- See [upstream documentation](https://kubernetes.io/docs/concepts/services-networking/service/#type-nodeport)
972 nodePort: # @schema type:[integer, null]; minimum:0
973 # -- See [upstream documentation](https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol)
974 appProtocol: # @schema type:[string, null]
975 # -- See [upstream documentation](https://doc.traefik.io/traefik/reference/install-configuration/entrypoints/#allowacmebypass)
976 allowACMEByPass: false
978 # -- See [upstream documentation](https://doc.traefik.io/traefik/security/request-path/#encoded-character-filtering)
980 encodedCharacters: # @schema additionalProperties: false
981 allowEncodedSlash: # @schema type:[boolean, null]
982 allowEncodedBackSlash: # @schema type:[boolean, null]
983 allowEncodedNullCharacter: # @schema type:[boolean, null]
984 allowEncodedSemicolon: # @schema type:[boolean, null]
985 allowEncodedPercent: # @schema type:[boolean, null]
986 allowEncodedQuestionMark: # @schema type:[boolean, null]
987 allowEncodedHash: # @schema type:[boolean, null]
988 # -- Maximum size of request headers in bytes. Default: 1048576 (1 MB)
989 maxHeaderBytes: # @schema type:[integer, null]; minimum:0
990 # -- See [upstream documentation](https://doc.traefik.io/traefik/reference/install-configuration/entrypoints/#httpmiddlewares)
991 middlewares: [] # @schema type: [array, null]
992 # -- See [upstream documentation](https://doc.traefik.io/traefik/security/request-path/#path-sanitization)
993 sanitizePath: # @schema type:[boolean, null]
995 # -- See [upstream documentation](https://doc.traefik.io/traefik/reference/install-configuration/entrypoints/#opt-http-tls)
1002 ## -- Enable HTTP/3 on the entrypoint
1003 ## Enabling it will also enable http3 experimental feature
1004 ## https://doc.traefik.io/traefik/reference/install-configuration/entrypoints/#opt-http3
1005 ## There are known limitations when trying to listen on same ports for
1006 ## TCP & UDP (Http3). There is a workaround in this chart using dual Service.
1007 ## https://github.com/kubernetes/kubernetes/issues/47249#issuecomment-587960741
1009 advertisedPort: # @schema type:[integer, null]; minimum:0
1011 # -- Trust forwarded headers information (X-Forwarded-*).
1014 # -- Disable appending RemoteAddr to X-Forwarded-For header (v3.7+).
1015 notAppendXForwardedFor: false
1017 # -- Enable the Proxy Protocol header parsing for the entry point
1023 readTimeout: # @schema type:[string, integer, null]
1024 writeTimeout: # @schema type:[string, integer, null]
1025 idleTimeout: # @schema type:[string, integer, null]
1027 requestAcceptGraceTimeout: # @schema type:[string, integer, null]
1028 graceTimeOut: # @schema type:[string, integer, null]
1029 keepAliveMaxRequests: # @schema type:[integer, null]; minimum:0
1030 keepAliveMaxTime: # @schema type:[string, integer, null]
1031 observability: # @schema additionalProperties: false
1032 # -- Enables metrics for this entryPoint.
1033 metrics: # @schema type:[boolean, null]; default: true
1034 # -- Enables access-logs for this entryPoint.
1035 accessLogs: # @schema type:[boolean, null]; default: true
1036 # -- Enables tracing for this entryPoint.
1037 tracing: # @schema type:[boolean, null]; default: true
1038 # -- Defines the tracing verbosity level for this entryPoint.
1039 traceVerbosity: # @schema enum:[minimal, detailed, null]; type:[string, null]; default: minimal
1041 # -- When using hostNetwork, use another port to avoid conflict with node exporter:
1042 # https://github.com/prometheus/prometheus/wiki/Default-port-allocations
1044 # -- You may not want to expose the metrics port on production deployments.
1045 # If you want to access it from outside your cluster,
1046 # use `kubectl port-forward` or create a secure ingress
1049 # -- The exposed port for this service
1051 # -- The port protocol (TCP/UDP)
1053 observability: # @schema additionalProperties: false
1054 # -- Enables metrics for this entryPoint.
1055 metrics: # @schema type:[boolean, null]; default: true
1056 # -- Enables access-logs for this entryPoint.
1057 accessLogs: # @schema type:[boolean, null]; default: true
1058 # -- Enables tracing for this entryPoint.
1059 tracing: # @schema type:[boolean, null]; default: true
1060 # -- Defines the tracing verbosity level for this entryPoint.
1061 traceVerbosity: # @schema enum:[minimal, detailed, null]; type:[string, null]; default: minimal
1062# -- TLS Options are created as [TLSOption CRDs](https://doc.traefik.io/traefik/reference/routing-configuration/kubernetes/crd/tls/tlsoption/)
1063# When using `labelSelector`, you'll need to set labels on tlsOption accordingly.
1064# See EXAMPLE.md for details.
1066# -- TLS Store are created as [TLSStore CRDs](https://doc.traefik.io/traefik/reference/routing-configuration/kubernetes/crd/tls/tlsstore/).
1067# This is useful if you want to set a default certificate. See EXAMPLE.md for details.
1071 # -- Override the default Service name. Useful for adopting an existing Service (e.g., during migration from another ingress controller).
1072 nameOverride: "" # @schema type:[string, null]
1073 ## -- Single service is using `MixedProtocolLBService` feature gate.
1074 ## -- When set to false, it will create two Service, one for TCP and one for UDP.
1076 # -- Additional annotations applied to both TCP and UDP services (e.g. for cloud provider specific config)
1078 # -- Additional annotations for TCP service only
1080 # -- Additional annotations for UDP service only
1082 # -- Additional service labels (e.g. for filtering Service by custom labels)
1084 # -- Additional entries here will be added to the Service [spec](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.35/#servicespec-v1-core).
1085 # Cannot contain selector or ports entries.
1088 # -- Can be used to create multiple Service.
1089 # See EXAMPLES.md for more details.
1090 additionalServices: {}
1091autoscaling: # @schema additionalProperties: false
1092 # -- Create HorizontalPodAutoscaler object.
1093 # See EXAMPLES.md for more details.
1095 # -- minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down. It defaults to 1 pod.
1096 minReplicas: # @schema type:[integer, null]; minimum:0
1097 # -- maxReplicas is the upper limit for the number of pods that can be set by the autoscaler; cannot be smaller than MinReplicas.
1098 maxReplicas: # @schema type:[integer, null]; minimum:0
1099 # -- metrics contains the specifications for which to use to calculate the desired replica count (the maximum replica count across all metrics will be used).
1101 # -- behavior configures the scaling behavior of the target in both Up and Down directions (scaleUp and scaleDown fields respectively).
1103 # -- scaleTargetRef points to the target resource to scale, and is used for the pods for which metrics should be collected, as well as to actually change the replica count.
1104 # @default -- Traefik Deployment
1108 name: "{{ template \"traefik.fullname\" . }}"
1110 # -- Enable persistence using Persistent Volume Claims
1111 # ref: http://kubernetes.io/docs/user-guide/persistent-volumes/.
1112 # It can be used to store TLS certificates along with `certificatesResolvers.<name>.acme.storage` option
1116 accessMode: ReadWriteOnce
1118 storageClass: # @schema type:[string, null]
1122 # -- Only mount a subpath of the Volume into the pod
1124# -- Certificates resolvers configuration.
1125# Ref: https://doc.traefik.io/traefik/reference/install-configuration/tls/certificate-resolvers/acme/
1126# See EXAMPLES.md for more details.
1127certificatesResolvers: {}
1128# -- If hostNetwork is true, runs traefik in the host network namespace
1129# To prevent unschedulable pods due to port collisions, if hostNetwork=true
1130# and replicas>1, a pod anti-affinity is recommended and will be set if the
1131# affinity is left as default.
1133rbac: # @schema additionalProperties: false
1134 # -- Whether Role Based Access Control objects like roles and rolebindings should be created
1136 # -- When set to true: <br />
1137 # 1. It switches respectively the use of `ClusterRole` and `ClusterRoleBinding` to `Role` and `RoleBinding`.<br />
1138 # 2. It adds `disableClusterScopeResources` on Ingress and CRD (Kubernetes) providers<br />
1139 # **NOTE**: `IngressClass`, `NodePortLB` and **Gateway** provider cannot be used with namespaced RBAC. <br />
1140 # See [upstream documentation](https://doc.traefik.io/traefik/reference/install-configuration/providers/kubernetes/kubernetes-ingress/#opt-providers-kubernetesIngress-disableClusterScopeResources) for more details.
1142 # -- Enable user-facing roles
1143 # https://kubernetes.io/docs/reference/access-authn-authz/rbac/#user-facing-roles
1145# -- The service account the pods will use to interact with the Kubernetes API
1146serviceAccount: # @schema additionalProperties: false
1147 # If set, an existing service account is used
1148 # If not set, a service account is created automatically using the fullname template
1150# -- Additional serviceAccount annotations (e.g. for oidc authentication)
1151serviceAccountAnnotations: {}
1152# -- [Resources](https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/) for `traefik` container.
1154# -- This example pod anti-affinity forces the scheduler to put traefik pods
1155# -- on nodes where no other traefik pods are scheduled.
1156# It should be used when hostNetwork: true to prevent port conflicts
1159# requiredDuringSchedulingIgnoredDuringExecution:
1162# app.kubernetes.io/name: '{{ template "traefik.name" . }}'
1163# app.kubernetes.io/instance: '{{ .Release.Name }}-{{ include "traefik.namespace" . }}'
1164# topologyKey: kubernetes.io/hostname
1166# -- nodeSelector is the simplest recommended form of node selection constraint.
1168# -- Tolerations allow the scheduler to schedule pods with matching taints.
1170# -- You can use topology spread constraints to control
1171# how Pods are spread across your cluster among failure-domains.
1172topologySpreadConstraints: []
1173# This example topologySpreadConstraints forces the scheduler to put traefik pods
1174# on nodes where no other traefik pods are scheduled.
1177# app.kubernetes.io/name: '{{ template "traefik.name" . }}'
1179# topologyKey: kubernetes.io/hostname
1180# whenUnsatisfiable: DoNotSchedule
1182# -- [Pod Priority and Preemption](https://kubernetes.io/docs/concepts/scheduling-eviction/pod-priority-preemption/)
1183priorityClassName: ""
1184# -- [SecurityContext](https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#security-context-1)
1185# @default -- See _values.yaml_
1187 allowPrivilegeEscalation: false
1190 readOnlyRootFilesystem: true
1191# -- [Pod Security Context](https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/pod-v1/#security-context)
1192# @default -- See _values.yaml_
1198 type: RuntimeDefault
1200# -- Extra objects to deploy (value evaluated as a template)
1202# In some cases, it can avoid the need for additional, extended or adhoc deployments.
1203# See #595 for more details and traefik/tests/values/extra.yaml for example.
1205# -- This field overrides the default Release Namespace for Helm.
1206# It will not affect optional CRDs such as `ServiceMonitor` and `PrometheusRules`
1207namespaceOverride: ""
1208# -- This field overrides the default app.kubernetes.io/instance label for all Objects.
1209instanceLabelOverride: ""
1210# -- This field overrides the default version extracted from image.tag. Required when pinning by `image.digest`, since the version cannot be derived from a digest.
1212# -- overrides the app.kubernetes.io/name label
1214# -- Overrides the resource name for templates (i.e deployment, service, etc..)
1216# Traefik Hub configuration. See https://doc.traefik.io/traefik-hub/
1217hub: # @schema additionalProperties: false
1218 # -- Name of `Secret` with key 'token' set to a valid license token.
1219 # It enables API Gateway.
1221 # -- Mount path for token secret.
1222 tokenMountPath: "/etc/secrets"
1223 # -- Disables all external network connections.
1224 offline: # @schema type:[boolean, null]
1225 # -- By default, Traefik Hub provider watches all namespaces. When using `rbac.namespaced`, it will watch helm release namespace and namespaces listed in this array.
1226 namespaces: [] # @schema required:true
1228 # -- Set to true in order to enable API Management. Requires a valid license token.
1231 # -- WebHook admission server listen address. Default: "0.0.0.0:9943".
1233 # -- Certificate name of the WebHook admission server. Default: "hub-agent-cert".
1234 secretName: "hub-agent-cert"
1235 # -- By default, this chart handles directly the tls certificate required for the admission webhook. It's possible to disable this behavior and handle it outside of the chart. See EXAMPLES.md for more details.
1236 selfManagedCertificate: false
1237 # -- Set custom certificate for the WebHook admission server. The certificate should be specified with _tls.crt_ and _tls.key_ in base64 encoding.
1238 customWebhookCertificate: {}
1239 # -- Set it to false if you need to disable Traefik Hub pod restart when mutating webhook certificate is updated. It's done with a label update.
1240 restartOnCertificateChange: true
1241 # -- Set custom annotations.
1244 # -- When set to true, it will only accept paths and methods that are explicitly defined in its OpenAPI specification
1245 validateRequestMethodAndPath: false
1247 # -- Set to true in order to enable AI MCP Gateway. Requires a valid license token.
1249 # -- Hard limit for the size of request bodies inspected by the gateway. Accepts a plain integer representing **bytes**. The default value is `1048576` (1 MiB).
1250 maxRequestBodySize: # @schema type:[integer, null]; minimum:0
1252 # -- Set to true in order to enable AI Gateway. Requires a valid license token.
1254 # -- Hard limit for the size of request bodies inspected by the gateway. Accepts a plain integer representing **bytes**. The default value is `1048576` (1 MiB).
1255 maxRequestBodySize: # @schema type:[integer, null]; minimum:0
1257 consulCatalogEnterprise:
1258 # -- Enable Consul Catalog Enterprise backend with default settings.
1260 # -- Use local agent caching for catalog reads.
1262 # -- Enable Consul Connect support.
1264 # -- Consider every service as Connect capable by default.
1265 connectByDefault: false
1266 # -- Constraints is an expression that Traefik matches against the container's labels
1269 defaultRule: "Host(`{{ normalize .Name }}`)"
1271 # -- The address of the Consul server
1273 # -- Data center to use. If not provided, the default agent data center is used
1275 # -- WaitTime limits how long a Watch will block. If not provided, the agent default
1276 endpointWaitTime: # @schema type:[integer, null]
1278 # -- Basic Auth password
1280 # -- Basic Auth username
1282 # -- The URI scheme for the Consul server
1289 # -- TLS insecure skip verify
1290 insecureSkipVerify: false
1293 # -- Token is used to provide a per-request ACL token which overrides the agent's
1295 # -- Expose containers by default.
1296 exposedByDefault: true
1297 # -- Sets the namespaces used to discover services (Consul Enterprise only).
1299 # -- Sets the partition used to discover services (Consul Enterprise only).
1301 # -- Prefix for consul service tags.
1303 # -- Interval for checking Consul API.
1305 # -- Forces the read to be fully consistent.
1306 requireConsistent: false
1307 # -- Name of the Traefik service in Consul Catalog (needs to be registered via the
1308 serviceName: "traefik"
1309 # -- Use stale consistency for catalog reads.
1311 # -- A list of service health statuses to allow taking traffic.
1312 strictChecks: "passing, warning"
1313 # -- Watch Consul API events.
1316 # -- Enable Microcks provider.
1319 # -- Microcks API client ID.
1321 # -- Microcks API client secret.
1323 # -- Microcks API endpoint.
1325 # -- Microcks API token.
1327 # -- Microcks API endpoint.
1329 # -- Polling interval for Microcks API.
1331 # -- Polling timeout for Microcks API.
1338 # -- TLS insecure skip verify
1339 insecureSkipVerify: false
1343 # -- Enable Multi-cluster provider.
1345 # -- Polling interval for Multi-cluster.
1347 # -- Polling timeout for Multi-cluster.
1349 # @schema mergeProperties: true
1350 # -- Child cluster configurations, keyed by a unique name.
1353 # @schema additionalProperties: false
1355 # -- URL of the child cluster's uplink entrypoint.
1357 # -- TLS and transport configuration for connecting to this child.
1360 # @schema type:[boolean, null]
1361 # -- Disable TLS certificate verification. **Not recommended for production.**
1364 # -- Server name used for SNI and certificate verification.
1368 # @schema type:[integer, null]
1369 # -- Maximum idle connections per host.
1371 maxIdleConnsPerHost:
1372 # @schema type:[boolean, null]
1373 # -- Disable HTTP/2 for connections to this child.
1376 # -- Minimum TLS version (e.g. `VersionTLS12`, `VersionTLS13`).
1378 # -- Maximum TLS version (e.g. `VersionTLS12`, `VersionTLS13`).
1380 # -- List of supported cipher suites for TLS versions up to 1.2.
1382 # -- URI used to match against SAN URIs during the server's certificate verification.
1385 # @schema type:[string, integer, null]
1386 # -- Timeout for establishing connections.
1389 # @schema type:[string, integer, null]
1390 # -- Timeout for reading response headers.
1392 responseHeaderTimeout:
1393 # @schema type:[string, integer, null]
1394 # -- Timeout for idle connections.
1397 # @schema type:[string, integer, null]
1398 # -- Timeout for HTTP/2 server ping frames.
1401 # @schema type:[string, integer, null]
1402 # -- Timeout for HTTP/2 connection idle reads.
1405 # @schema type:[string, integer, null]
1406 # -- Timeout for reading the request body.
1409 # @schema type:[string, integer, null]
1410 # -- Timeout for writing the response.
1415 # @schema type:[string, integer, null]
1416 # -- SPIFFE trust domain.
1418 # @schema additionalProperties: false
1419 nutanixPrismCentral:
1420 # -- Enable Nutanix Prism Central provider.
1422 # -- Prism Central endpoint.
1424 # -- Prism Central username.
1426 # -- Prism Central password.
1428 # -- Prism Central API key.
1430 # -- Base configuration file path.
1432 # -- Polling interval for Nutanix Prism Central API.
1434 # -- Polling timeout for Nutanix Prism Central API.
1436 # -- Category key used to derive the service name.
1437 serviceNameCategoryKey: "TraefikServiceName"
1438 # -- Filter VMs by VPCs. List of `{ uuid: "<vpc-uuid>" }` entries.
1447 # -- TLS insecure skip verify
1448 insecureSkipVerify: false
1450 # -- Enable Redis Cluster. Default: true.
1451 cluster: # @schema type:[boolean, null]
1452 # -- Database used to store information. Default: "0".
1453 database: # @schema type:[string, null]
1454 # -- Endpoints of the Redis instances to connect to. Default: "".
1456 # -- The username to use when connecting to Redis endpoints. Default: "".
1458 # -- The password to use when connecting to Redis endpoints. Default: "".
1461 # -- Name of the set of main nodes to use for main selection. Required when using Sentinel. Default: "".
1463 # -- Username to use for sentinel authentication (can be different from endpoint username). Default: "".
1465 # -- Password to use for sentinel authentication (can be different from endpoint password). Default: "".
1467 # -- Timeout applied on connection with redis. Default: "0s".
1470 # -- Path to the certificate authority used for the secured connection.
1472 # -- Path to the public certificate used for the secure connection.
1474 # -- Path to the private key used for the secure connection.
1476 # -- When insecureSkipVerify is set to true, the TLS connection accepts any certificate presented by the server. Default: false.
1477 insecureSkipVerify: false
1478 # Enable export of error logs to the platform. Default: true.
1479 sendlogs: # @schema type:[boolean, null]
1481 additionalTraceHeaders:
1482 # -- Tracing headers to duplicate.
1483 # To configure the following, tracing.otlp.enabled needs to be set to true.
1484 # @default -- See below
1487 # -- Name of the header that will contain the parent-id header copy.
1489 # -- Name of the header that will contain the trace-id copy.
1491 # -- Name of the header that will contain the traceparent copy.
1493 # -- Name of the header that will contain the tracestate copy.
1495 # Define private plugin sources
1498# -- Required for OCI Marketplace integration.
1499# See https://docs.public.content.oci.oraclecloud.com/en-us/iaas/Content/Marketplace/understanding-helm-charts.htm
1500# @default -- See _values.yaml_
1502 # -- Enable specific values for Oracle Cloud Infrastructure
1504 # -- It needs to be an ocir repo
1508 image: chainguard-private/traefik
1509 tag: latest@sha256:a1d046ceb7669fc10bb53d509b21a4f8835e69db8b510195de29fa582aa5f08b
1511 image: chainguard-private/traefik
1512 tag: latest@sha256:a1d046ceb7669fc10bb53d509b21a4f8835e69db8b510195de29fa582aa5f08b
1513# -- Required for IBM Cloud Marketplace integration.
1514# Injected by IBM Cloud Catalog when deploying via IBM Cloud Schematics. This value is not used by the chart.
1515offering_version: "" # @schema type:[string, null]
1516# -- Allow the Helm chart to be used as optional subchart.
1517enabled: true # @schema type:boolean; const:true