1# Default values for longhorn.
2# This is a YAML-formatted file.
3# Declare variables to be passed into your templates.
5 # -- Global override for container image registry.
6 imageRegistry: "docker.io"
7 # -- Global override for image pull secrets for container registry.
9 # -- Set container timezone (TZ env) for all Longhorn workloads. Leave empty to use container default.
11 # -- Toleration for nodes allowed to run user-deployed components such as Longhorn Manager, Longhorn UI, and Longhorn Driver Deployer.
13 # -- Node selector for nodes allowed to run user-deployed components such as Longhorn Manager, Longhorn UI, and Longhorn Driver Deployer.
16 # -- Default system registry.
17 systemDefaultRegistry: ""
19 # -- Setting that allows Longhorn to run on a Rancher Windows cluster.
21 # -- Toleration for Linux nodes that can run user-deployed Longhorn components.
27 # -- Node selector for Linux nodes that can run user-deployed Longhorn components.
29 kubernetes.io/os: "linux"
31 # -- Toleration for system-managed Longhorn components.
32 taintToleration: cattle.io/os=linux:NoSchedule
33 # -- Node selector for system-managed Longhorn components.
34 systemManagedComponentsNodeSelector: kubernetes.io/os:linux
36 # -- Setting that allows you to enable network policies that control access to Longhorn pods.
38 # -- Distribution that determines the policy for allowing access for an ingress. (Options: "k3s", "rke2", "rke1")
43 # -- Registry for the Longhorn Engine image.
44 registry: chainreg.biz
45 # -- Repository for the Longhorn Engine image.
46 repository: chainguard-private/longhorn-engine
47 # -- Tag for the Longhorn Engine image.
48 tag: latest@sha256:1f4b81e31e7797b80939b99d84b85ca206cad0b23bc4c2af8c94a95ed2a8de51
50 # -- Registry for the Longhorn Manager image.
51 registry: chainreg.biz
52 # -- Repository for the Longhorn Manager image.
53 repository: chainguard-private/longhorn-manager
54 # -- Tag for the Longhorn Manager image.
55 tag: latest@sha256:3e0502e42a8c285a06a28f882050b64ae181f7cf7635a9cacf70d69ff8e335f0
57 # -- Registry for the Longhorn UI image.
58 registry: chainreg.biz
59 # -- Repository for the Longhorn UI image.
60 repository: chainguard-private/longhorn-ui
61 # -- Tag for the Longhorn UI image.
62 tag: latest@sha256:79aa0f1a80998666b68dc01720bfac4c6a9c7060e490ac13c2850bedc27e7d5c
64 # -- Registry for the Longhorn Instance Manager image.
65 registry: chainreg.biz
66 # -- Repository for the Longhorn Instance Manager image.
67 repository: chainguard-private/longhorn-instance-manager
68 # -- Tag for the Longhorn Instance Manager image.
69 tag: latest@sha256:950f652b890f79138b12917a39aab3c13946ebe5906671dde7211bfad8bb04da
71 # -- Registry for the Longhorn Share Manager image.
72 registry: chainreg.biz
73 # -- Repository for the Longhorn Share Manager image.
74 repository: chainguard-private/longhorn-share-manager
75 # -- Tag for the Longhorn Share Manager image.
76 tag: latest@sha256:09995f57024611beec4e706b9f3d7cabde541739383c505bb28a9b596a2b8411
78 # -- Registry for the Backing Image Manager image. When unspecified, Longhorn uses the default value.
79 registry: chainreg.biz
80 # -- Repository for the Backing Image Manager image. When unspecified, Longhorn uses the default value.
81 repository: chainguard-private/backing-image-manager
82 # -- Tag for the Backing Image Manager image. When unspecified, Longhorn uses the default value.
83 tag: latest@sha256:517d6323cc7f70400ad16e4b5640a74bdbdf3d2e9acade28a2a8a9d916362a8a
85 # -- Registry for the Longhorn Support Bundle Manager image.
86 registry: chainreg.biz
87 # -- Repository for the Longhorn Support Bundle Manager image.
88 repository: chainguard-private/longhorn-support-bundle-kit
89 # -- Tag for the Longhorn Support Bundle Manager image.
90 tag: latest@sha256:50f27b336acb72c27ef60b98fc23ac673dd3c89eb1c779752e9de8e29232d5c7
93 # -- Registry for the CSI attacher image. When unspecified, Longhorn uses the default value.
94 registry: chainreg.biz
95 # -- Repository for the CSI attacher image. When unspecified, Longhorn uses the default value.
96 repository: chainguard-private/longhorn-csi-attacher
97 # -- Tag for the CSI attacher image. When unspecified, Longhorn uses the default value.
98 tag: latest@sha256:22f732996007f6de517d06befebf382c1e8e0592fd09bec00479ab1ad574e5aa
100 # -- Registry for the CSI Provisioner image. When unspecified, Longhorn uses the default value.
101 registry: chainreg.biz
102 # -- Repository for the CSI Provisioner image. When unspecified, Longhorn uses the default value.
103 repository: chainguard-private/longhorn-csi-provisioner
104 # -- Tag for the CSI Provisioner image. When unspecified, Longhorn uses the default value.
105 tag: latest@sha256:cd31674d24977a03a02e993382e6c7e1d7cb8a115d39e74ccaa0d6c462097895
107 # -- Registry for the CSI Node Driver Registrar image. When unspecified, Longhorn uses the default value.
108 registry: chainreg.biz
109 # -- Repository for the CSI Node Driver Registrar image. When unspecified, Longhorn uses the default value.
110 repository: chainguard-private/longhorn-csi-node-driver-registrar
111 # -- Tag for the CSI Node Driver Registrar image. When unspecified, Longhorn uses the default value.
112 tag: latest@sha256:90071e609042a0a0486e3a76ff9bdc9094ecb663a7e84d8abafc6c13b4344001
114 # -- Registry for the CSI Resizer image. When unspecified, Longhorn uses the default value.
115 registry: chainreg.biz
116 # -- Repository for the CSI Resizer image. When unspecified, Longhorn uses the default value.
117 repository: chainguard-private/longhorn-csi-resizer
118 # -- Tag for the CSI Resizer image. When unspecified, Longhorn uses the default value.
119 tag: latest@sha256:8eb3d5bf3c34685b1664daac442537a318785af9cc0056b505ed6fd1b871fc7a
121 # -- Registry for the CSI Snapshotter image. When unspecified, Longhorn uses the default value.
122 registry: chainreg.biz
123 # -- Repository for the CSI Snapshotter image. When unspecified, Longhorn uses the default value.
124 repository: chainguard-private/longhorn-csi-snapshotter
125 # -- Tag for the CSI Snapshotter image. When unspecified, Longhorn uses the default value.
126 tag: latest@sha256:b22f5252d9aeaa65a5bc916db3da025d315ba64b7c77bab70ad613c62afec985
128 # -- Registry for the CSI liveness probe image. When unspecified, Longhorn uses the default value.
129 registry: chainreg.biz
130 # -- Repository for the CSI liveness probe image. When unspecified, Longhorn uses the default value.
131 repository: chainguard-private/longhorn-livenessprobe
132 # -- Tag for the CSI liveness probe image. When unspecified, Longhorn uses the default value.
133 tag: latest@sha256:5ea5dc90800a02c480af4afeba493ba03fcd2d5ef992c1568a0d4a2212e7b0a8
136 # -- Registry for the OAuth Proxy image. Specify the upstream image (for example, "quay.io/openshift/origin-oauth-proxy"). This setting applies only to OpenShift users.
138 # -- Repository for the OAuth Proxy image. Specify the upstream image (for example, "quay.io/openshift/origin-oauth-proxy"). This setting applies only to OpenShift users.
140 # -- Tag for the OAuth Proxy image. Specify OCP/OKD version 4.1 or later (including version 4.18, which is available at quay.io/openshift/origin-oauth-proxy:4.18). This setting applies only to OpenShift users.
142 # -- Image pull policy that applies to all user-deployed Longhorn components, such as Longhorn Manager, Longhorn driver, and Longhorn UI.
143 pullPolicy: IfNotPresent
146 # -- Service type for Longhorn UI. (Options: "ClusterIP", "NodePort", "LoadBalancer", "Rancher-Proxy")
148 # -- NodePort port number for Longhorn UI. When unspecified, Longhorn selects a free port between 30000 and 32767.
150 # -- Class of a load balancer implementation
151 loadBalancerClass: ""
152 # -- Annotation for the Longhorn UI service.
154 ## If you want to set annotations for the Longhorn UI service, delete the `{}` in the line above
155 ## and uncomment this example block
156 # annotation-key1: "annotation-value1"
157 # annotation-key2: "annotation-value2"
159 ## If you want to set additional labels for the Longhorn UI service, delete the `{}` in the line above
160 ## and uncomment this example block
161 # label-key1: "label-value1"
162 # label-key2: "label-value2"
164 # -- Service type for Longhorn Manager.
166 # -- NodePort port number for Longhorn Manager. When unspecified, Longhorn selects a free port between 30000 and 32767.
169 # -- Setting that allows you to specify the default Longhorn StorageClass.
171 # -- Filesystem type of the default Longhorn StorageClass.
173 # -- mkfs parameters of the default Longhorn StorageClass.
174 defaultMkfsParams: ""
175 # -- Replica count of the default Longhorn StorageClass.
176 defaultClassReplicaCount: 3
177 # -- Data locality of the default Longhorn StorageClass. (Options: "disabled", "best-effort")
178 defaultDataLocality: disabled
179 # -- Reclaim policy that provides instructions for handling of a volume after its claim is released. (Options: "Retain", "Delete")
180 reclaimPolicy: Delete
181 # -- VolumeBindingMode controls when volume binding and dynamic provisioning should occur. (Options: "Immediate", "WaitForFirstConsumer") (Defaults to "Immediate")
182 volumeBindingMode: "Immediate"
183 # -- Setting that allows you to enable live migration of a Longhorn volume from one node to another.
185 # -- Setting that disables the revision counter and thereby prevents Longhorn from tracking all write operations to a volume. When salvaging a volume, Longhorn uses properties of the volume-head-xxx.img file (the last file size and the last time the file was modified) to select the replica to be used for volume recovery.
186 disableRevisionCounter: "true"
187 # -- Set NFS mount options for Longhorn StorageClass for RWX volumes
189 recurringJobSelector:
190 # -- Setting that allows you to enable the recurring job selector for a Longhorn StorageClass.
192 # -- Recurring job selector for a Longhorn StorageClass. Ensure that quotes are used correctly when specifying job parameters. (Example: `[{"name":"backup", "isGroup":true}]`)
195 # -- Setting that allows you to use a backing image in a Longhorn StorageClass.
197 # -- Backing image to be used for creating and restoring volumes in a Longhorn StorageClass. When no backing images are available, specify the data source type and parameters that Longhorn can use to create a backing image.
199 # -- Data source type of a backing image used in a Longhorn StorageClass.
200 # If the backing image exists in the cluster, Longhorn uses this setting to verify the image.
201 # If the backing image does not exist, Longhorn creates one using the specified data source type.
203 # -- Data source parameters of a backing image used in a Longhorn StorageClass.
204 # You can specify a JSON string of a map. (Example: `'{\"url\":\"https://backing-image-example.s3-region.amazonaws.com/test-backing-image\"}'`)
205 dataSourceParameters: ~
206 # -- Expected SHA-512 checksum of a backing image used in a Longhorn StorageClass.
209 # -- Setting that allows you to enable the disk selector for the default Longhorn StorageClass.
211 # -- Disk selector for the default Longhorn StorageClass. Longhorn uses only disks with the specified tags for storing volume data. (Examples: "nvme,sata")
214 # -- Setting that allows you to enable the node selector for the default Longhorn StorageClass.
216 # -- Node selector for the default Longhorn StorageClass. Longhorn uses only nodes with the specified tags for storing volume data. (Examples: "storage,fast")
218 # -- Setting that allows you to enable automatic snapshot removal during filesystem trim for a Longhorn StorageClass. (Options: "ignored", "enabled", "disabled")
219 unmapMarkSnapChainRemoved: ignored
220 # -- Setting that allows you to specify the data engine version for the default Longhorn StorageClass. (Options: "v1", "v2")
222 # -- Setting that allows you to specify the backup target for the default Longhorn StorageClass.
223 backupTargetName: default
225 # -- Setting that allows Longhorn to perform pre-upgrade checks. Disable this setting when installing Longhorn using Argo CD or other GitOps solutions.
227 # -- Setting that allows Longhorn to perform upgrade version checks after starting the Longhorn Manager DaemonSet Pods. Disabling this setting also disables `preUpgradeChecker.jobEnabled`. Longhorn recommends keeping this setting enabled.
228 upgradeVersionCheck: true
230 # -- kubelet root directory. When unspecified, Longhorn uses the default value.
232 # -- Configures Pod anti-affinity to prevent multiple instances on the same node. Use soft (tries to separate) or hard (must separate). When unspecified, Longhorn uses the default value ("soft").
233 podAntiAffinityPreset: ~
234 # -- Replica count of the CSI Attacher. When unspecified, Longhorn uses the default value ("3").
235 attacherReplicaCount: ~
236 # -- Replica count of the CSI Provisioner. When unspecified, Longhorn uses the default value ("3").
237 provisionerReplicaCount: ~
238 # -- Replica count of the CSI Resizer. When unspecified, Longhorn uses the default value ("3").
239 resizerReplicaCount: ~
240 # -- Replica count of the CSI Snapshotter. When unspecified, Longhorn uses the default value ("3").
241 snapshotterReplicaCount: ~
243 # -- Setting that allows Longhorn to automatically attach a volume and create snapshots or backups when recurring jobs are run.
244 allowRecurringJobWhileVolumeDetached: ~
245 # -- Setting that allows Longhorn to automatically create a default disk only on nodes with the label "node.longhorn.io/create-default-disk=true" (if no other disks exist). When this setting is disabled, Longhorn creates a default disk on each node that is added to the cluster.
246 createDefaultDiskLabeledNodes: ~
247 # -- Default path to use for storing data on a host. An absolute directory path indicates a filesystem-type disk used by the V1 Data Engine, while a path to a block device indicates a block-type disk used by the V2 Data Engine. The default value is "/var/lib/longhorn/".
249 # -- Default data locality. A Longhorn volume has data locality if a local replica of the volume exists on the same node as the pod that is using the volume.
250 defaultDataLocality: ~
251 # -- Setting that allows scheduling on nodes with healthy replicas of the same volume. This setting is disabled by default.
252 replicaSoftAntiAffinity: ~
253 # -- Setting that automatically rebalances replicas when an available node is discovered.
254 replicaAutoBalance: ~
255 # -- Percentage of storage that can be allocated relative to hard drive capacity. The default value is "100".
256 storageOverProvisioningPercentage: ~
257 # -- Percentage of minimum available disk capacity. When the minimum available capacity exceeds the total available capacity, the disk becomes unschedulable until more space is made available for use. The default value is "25".
258 storageMinimalAvailablePercentage: ~
259 # -- Percentage of disk space that is not allocated to the default disk on each new Longhorn node.
260 storageReservedPercentageForDefaultDisk: ~
261 # -- Upgrade Checker that periodically checks for new Longhorn versions. When a new version is available, a notification appears on the Longhorn UI. This setting is enabled by default
263 # -- The Upgrade Responder sends a notification whenever a new Longhorn version that you can upgrade to becomes available. The default value is https://longhorn-upgrade-responder.rancher.io/v1/checkupgrade.
264 upgradeResponderURL: ~
265 # -- URL prefix embedded in Longhorn Manager API response links (the "actions" and "links" fields). When set, internal components such as longhorn-driver-deployer and longhorn-csi-plugin will follow links using this URL, so it must be reachable from within the cluster without authentication. Setting this to an externally-facing URL that is protected by auth middleware (e.g. OAuth2 proxy, ingress auth) will cause internal components to receive an HTML redirect instead of JSON, resulting in "invalid character '<'" errors and CSI driver deployment failure. Use this setting only when the URL is accessible unauthenticated from inside the cluster. Format: scheme://host[:port] (for example, http://longhorn.example.com). Leave empty to use the default behavior (internal pod IP). Note: this value is persisted in the manager-url Setting CR; removing it from Helm values does not automatically clear the CR. To reset, manually set the manager-url Setting CR value to empty via the Longhorn UI or kubectl.
267 # -- Default number of replicas for volumes created using the Longhorn UI. For Kubernetes configuration, modify the `numberOfReplicas` field in the StorageClass. The default value is "{"v1":"3","v2":"3"}".
268 defaultReplicaCount: ~
269 # -- Default name of Longhorn static StorageClass. "storageClassName" is assigned to PVs and PVCs that are created for an existing Longhorn volume. "storageClassName" can also be used as a label, so it is possible to use a Longhorn StorageClass to bind a workload to an existing PV without creating a Kubernetes StorageClass object. "storageClassName" needs to be an existing StorageClass. The default value is "longhorn-static".
270 defaultLonghornStaticStorageClass: ~
271 # -- Number of minutes that Longhorn keeps a failed backup resource. When the value is "0", automatic deletion is disabled.
273 # -- Number of minutes that Longhorn allows for the backup execution. The default value is "1".
274 backupExecutionTimeout: ~
275 # -- Setting that restores recurring jobs from a backup volume on a backup target and creates recurring jobs if none exist during backup restoration.
276 restoreVolumeRecurringJobs: ~
277 # -- Maximum number of successful recurring backup and snapshot jobs to be retained. When the value is "0", a history of successful recurring jobs is not retained.
278 recurringSuccessfulJobsHistoryLimit: ~
279 # -- Maximum number of failed recurring backup and snapshot jobs to be retained. When the value is "0", a history of failed recurring jobs is not retained.
280 recurringFailedJobsHistoryLimit: ~
281 # -- Maximum number of snapshots or backups to be retained.
282 recurringJobMaxRetention: ~
283 # -- Maximum number of failed support bundles that can exist in the cluster. When the value is "0", Longhorn automatically purges all failed support bundles.
284 supportBundleFailedHistoryLimit: ~
285 # -- Taint or toleration for system-managed Longhorn components.
286 # Specify values using a semicolon-separated list in `kubectl taint` syntax (Example: key1=value1:effect; key2=value2:effect).
288 # -- Node selector for system-managed Longhorn components.
289 systemManagedComponentsNodeSelector: ~
290 # -- Resource limits for system-managed CSI components.
291 # This setting allows you to configure CPU and memory requests/limits for CSI attacher, provisioner, resizer, snapshotter, and plugin components.
292 # Supported components: csi-attacher, csi-provisioner, csi-resizer, csi-snapshotter, longhorn-csi-plugin, node-driver-registrar, longhorn-liveness-probe.
293 # Notice that changing resource limits will cause CSI components to restart, which may temporarily affect volume provisioning and attach/detach operations until the components are ready. The value should be a JSON object with component names as keys and ResourceRequirements as values.
294 systemManagedCSIComponentsResourceLimits: ~
295 # -- PriorityClass for system-managed Longhorn components.
296 # This setting can help prevent Longhorn components from being evicted under Node Pressure.
297 # Notice that this will be applied to Longhorn user-deployed components by default if there are no priority class values set yet, such as `longhornManager.priorityClass`.
298 priorityClass: &defaultPriorityClassNameRef "longhorn-critical"
299 # -- Setting that allows Longhorn to automatically salvage volumes when all replicas become faulty (for example, when the network connection is interrupted). Longhorn determines which replicas are usable and then uses these replicas for the volume. This setting is enabled by default.
301 # -- Setting that allows Longhorn to automatically delete a workload pod that is managed by a controller (for example, daemonset) whenever a Longhorn volume is detached unexpectedly (for example, during Kubernetes upgrades). After deletion, the controller restarts the pod and then Kubernetes handles volume reattachment and remounting.
302 autoDeletePodWhenVolumeDetachedUnexpectedly: ~
303 # -- Blacklist of controller api/kind values for the setting Automatically Delete Workload Pod when the Volume Is Detached Unexpectedly. If a workload pod is managed by a controller whose api/kind is listed in this blacklist, Longhorn will not automatically delete the pod when its volume is unexpectedly detached. Multiple controller api/kind entries can be specified, separated by semicolons. For example: `apps/StatefulSet;apps/DaemonSet`. Note that the controller api/kind is case sensitive and must exactly match the api/kind in the workload pod's owner reference.
304 blacklistForAutoDeletePodWhenVolumeDetachedUnexpectedly: ~
305 # -- Setting that prevents Longhorn Manager from scheduling replicas on a cordoned Kubernetes node. This setting is enabled by default.
306 disableSchedulingOnCordonedNode: ~
307 # -- Setting that allows Longhorn to schedule new replicas of a volume to nodes in the same zone as existing healthy replicas. Nodes that do not belong to any zone are treated as existing in the zone that contains healthy replicas. When identifying zones, Longhorn relies on the label "topology.kubernetes.io/zone=<Zone name of the node>" in the Kubernetes node object.
308 replicaZoneSoftAntiAffinity: ~
309 # -- Setting that allows scheduling on disks with existing healthy replicas of the same volume. This setting is enabled by default.
310 replicaDiskSoftAntiAffinity: ~
311 # -- Policy that defines the action Longhorn takes when a volume is stuck with a StatefulSet or Deployment pod on a node that failed.
312 nodeDownPodDeletionPolicy: ~
313 # -- Policy that defines the action Longhorn takes when a node with the last healthy replica of a volume is drained.
315 # -- Setting that allows automatic detaching of manually-attached volumes when a node is cordoned.
316 detachManuallyAttachedVolumesWhenCordoned: ~
317 # -- Number of seconds that Longhorn waits before reusing existing data on a failed replica instead of creating a new replica of a degraded volume.
318 replicaReplenishmentWaitInterval: ~
319 # -- Maximum number of replicas that can be concurrently rebuilt on each node.
320 concurrentReplicaRebuildPerNodeLimit: ~
321 # -- Maximum number of file synchronization operations that can run concurrently during a single replica rebuild. Right now, it's for v1 data engine only.
322 rebuildConcurrentSyncLimit: ~
323 # -- Maximum number of volumes that can be concurrently restored on each node using a backup. When the value is "0", restoration of volumes using a backup is disabled.
324 concurrentVolumeBackupRestorePerNodeLimit: ~
325 # -- Setting that disables the revision counter and thereby prevents Longhorn from tracking all write operations to a volume. When salvaging a volume, Longhorn uses properties of the "volume-head-xxx.img" file (the last file size and the last time the file was modified) to select the replica to be used for volume recovery. This setting applies only to volumes created using the Longhorn UI.
326 disableRevisionCounter: '{"v1":"true"}'
327 # -- Image pull policy for system-managed pods, such as Instance Manager, engine images, and CSI Driver. Changes to the image pull policy are applied only after the system-managed pods restart.
328 systemManagedPodsImagePullPolicy: ~
329 # -- Setting that allows you to create and attach a volume without having all replicas scheduled at the time of creation.
330 allowVolumeCreationWithDegradedAvailability: ~
331 # -- Setting that allows Longhorn to automatically clean up the system-generated snapshot after replica rebuilding is completed.
332 autoCleanupSystemGeneratedSnapshot: ~
333 # -- Setting that allows Longhorn to automatically clean up the snapshot generated by a recurring backup job.
334 autoCleanupRecurringJobBackupSnapshot: ~
335 # -- Maximum number of engines that are allowed to concurrently upgrade on each node after Longhorn Manager is upgraded. When the value is "0", Longhorn does not automatically upgrade volume engines to the new default engine image version.
336 concurrentAutomaticEngineUpgradePerNodeLimit: ~
337 # -- Number of minutes that Longhorn waits before cleaning up the backing image file when no replicas in the disk are using it.
338 backingImageCleanupWaitInterval: ~
339 # -- Number of seconds that Longhorn waits before downloading a backing image file again when the status of all image disk files changes to "failed" or "unknown".
340 backingImageRecoveryWaitInterval: ~
341 # -- Percentage of the total allocatable CPU resources on each node to be reserved for each instance manager pod. The default value is {"v1":"12","v2":"12"}.
342 guaranteedInstanceManagerCPU: ~
343 # -- Setting that notifies Longhorn that the cluster is using the Kubernetes Cluster Autoscaler.
344 kubernetesClusterAutoscalerEnabled: ~
345 # -- Enables Longhorn to automatically delete orphaned resources and their associated data or processes (e.g., stale replicas). Orphaned resources on failed or unknown nodes are not automatically cleaned up.
346 # You need to specify the resource types to be deleted using a semicolon-separated list (e.g., `replica-data;instance`). Available items are: `replica-data`, `instance`.
347 orphanResourceAutoDeletion: ~
348 # -- Specifies the wait time, in seconds, before Longhorn automatically deletes an orphaned Custom Resource (CR) and its associated resources.
349 # Note that if a user manually deletes an orphaned CR, the deletion occurs immediately and does not respect this grace period.
350 orphanResourceAutoDeletionGracePeriod: ~
351 # -- Storage network for in-cluster traffic. When unspecified, Longhorn uses the Kubernetes cluster network.
353 # -- Specifies a dedicated network for mounting RWX (ReadWriteMany) volumes. Leave this blank to use the default Kubernetes cluster network. **Caution**: This setting should change after all RWX volumes are detached because some Longhorn component pods must be recreated to apply the setting. You cannot modify this setting while RWX volumes are still attached.
354 endpointNetworkForRWXVolume: ~
355 # -- Flag that prevents accidental uninstallation of Longhorn.
356 deletingConfirmationFlag: ~
357 # -- Timeout between the Longhorn Engine and replicas. Specify a value between "8" and "30" seconds. The default value is "8".
358 engineReplicaTimeout: ~
359 # -- Setting that allows you to enable and disable snapshot hashing and data integrity checks.
360 snapshotDataIntegrity: ~
361 # -- Setting that allows disabling of snapshot hashing after snapshot creation to minimize impact on system performance.
362 snapshotDataIntegrityImmediateCheckAfterSnapshotCreation: ~
363 # -- Setting that defines when Longhorn checks the integrity of data in snapshot disk files. You must use the Unix cron expression format.
364 snapshotDataIntegrityCronjob: ~
365 # -- Setting that controls how many snapshot heavy task operations (such as purge and clone) can run concurrently per node. This is a best-effort mechanism: due to the distributed nature of the system, temporary oversubscription may occur. The limiter reduces worst-case overload but does not guarantee perfect enforcement.
366 snapshotHeavyTaskConcurrentLimit: ~
367 # -- Setting that allows Longhorn to automatically mark the latest snapshot and its parent files as removed during a filesystem trim. Longhorn does not remove snapshots containing multiple child files.
368 removeSnapshotsDuringFilesystemTrim: ~
369 # -- Setting that allows fast rebuilding of replicas using the checksum of snapshot disk files. Before enabling this setting, you must set the snapshot-data-integrity value to "enable" or "fast-check".
370 fastReplicaRebuildEnabled: ~
371 # -- Number of seconds that an HTTP client waits for a response from a File Sync server before considering the connection to have failed.
372 replicaFileSyncHttpClientTimeout: ~
373 # -- Number of seconds that Longhorn allows for the completion of replica rebuilding and snapshot cloning operations.
375 # -- Log levels that indicate the type and severity of logs in Longhorn Manager. The default value is "Info". (Options: "Panic", "Fatal", "Error", "Warn", "Info", "Debug", "Trace")
377 # -- Specifies the directory on the host where Longhorn stores log files for the instance manager pod. Currently, it is only used for instance manager pods in the v2 data engine.
379 # -- Setting that allows you to specify a backup compression method.
380 backupCompressionMethod: ~
381 # -- Maximum number of worker threads that can concurrently run for each backup.
382 backupConcurrentLimit: ~
383 # -- Specifies the default backup block size, in MiB, used when creating a new volume. Supported values are 2 or 16.
384 defaultBackupBlockSize: ~
385 # -- Maximum number of worker threads that can concurrently run for each restore operation.
386 restoreConcurrentLimit: ~
387 # -- Setting that allows you to enable the V1 Data Engine.
389 # -- Setting that allows you to enable the V2 Data Engine, which is based on the Storage Performance Development Kit (SPDK). The V2 Data Engine is an experimental feature and should not be used in production environments.
391 # -- Applies only to the V2 Data Engine. Enables hugepages for the Storage Performance Development Kit (SPDK) target daemon. If disabled, legacy memory is used. Allocation size is set via the Data Engine Memory Size setting.
392 dataEngineHugepageEnabled: ~
393 # -- Applies only to the V2 Data Engine. Specifies the hugepage size, in MiB, for the Storage Performance Development Kit (SPDK) target daemon. The default value is "{"v2":"2048"}"
394 dataEngineMemorySize: ~
395 # -- Applies only to the V2 Data Engine. Specifies the CPU cores on which the Storage Performance Development Kit (SPDK) target daemon runs. The daemon is deployed in each Instance Manager pod. Ensure that the number of assigned cores does not exceed the guaranteed Instance Manager CPUs for the V2 Data Engine. The default value is "{"v2":"0x1"}".
397 # -- This setting specifies the default write bandwidth limit (in megabytes per second) for volume replica rebuilding when using the v2 data engine (SPDK). If this value is set to 0, there will be no write bandwidth limitation. Individual volumes can override this setting by specifying their own rebuilding bandwidth limit.
398 replicaRebuildingBandwidthLimit: ~
399 # -- This setting specifies the default depth of each queue for Ublk frontend. This setting applies to volumes using the V2 Data Engine with Ublk front end. Individual volumes can override this setting by specifying their own Ublk queue depth.
400 defaultUblkQueueDepth: ~
401 # -- This setting specifies the default the number of queues for ublk frontend. This setting applies to volumes using the V2 Data Engine with Ublk front end. Individual volumes can override this setting by specifying their own number of queues for ublk.
402 defaultUblkNumberOfQueue: ~
403 # -- In seconds. The setting specifies the timeout for the instance manager pod liveness probe. The default value is 10 seconds.
404 instanceManagerPodLivenessProbeTimeout: ~
405 # -- Setting that allows scheduling of empty node selector volumes to any node.
406 allowEmptyNodeSelectorVolume: ~
407 # -- Setting that allows scheduling of empty disk selector volumes to any disk.
408 allowEmptyDiskSelectorVolume: ~
409 # -- Setting that allows Longhorn to periodically collect anonymous usage data for product improvement purposes. Longhorn sends collected data to the [Upgrade Responder](https://github.com/longhorn/upgrade-responder) server, which is the data source of the Longhorn Public Metrics Dashboard (https://metrics.longhorn.io). The Upgrade Responder server does not store data that can be used to identify clients, including IP addresses.
410 allowCollectingLonghornUsageMetrics: ~
411 # -- Setting that temporarily prevents all attempts to purge volume snapshots.
412 disableSnapshotPurge: ~
413 # -- Maximum snapshot count for a volume. The value should be between 2 to 250
415 # -- Applies only to the V2 Data Engine. Specifies the log level for the Storage Performance Development Kit (SPDK) target daemon. Supported values are: Error, Warning, Notice, Info, and Debug. The default is Notice.
416 dataEngineLogLevel: ~
417 # -- Applies only to the V2 Data Engine. Specifies the log flags for the Storage Performance Development Kit (SPDK) target daemon.
418 dataEngineLogFlags: ~
419 # -- Setting that freezes the filesystem on the root partition before a snapshot is created.
420 freezeFilesystemForSnapshot: ~
421 # -- Setting that automatically cleans up the snapshot when the backup is deleted.
422 autoCleanupSnapshotWhenDeleteBackup: ~
423 # -- Setting that automatically cleans up the snapshot after the on-demand backup is completed.
424 autoCleanupSnapshotAfterOnDemandBackupCompleted: ~
425 # -- Setting that allows Longhorn to detect node failure and immediately migrate affected RWX volumes.
426 rwxVolumeFastFailover: ~
427 # -- Enables automatic rebuilding of degraded replicas while the volume is detached. This setting only takes effect if the individual volume setting is set to `ignored` or `enabled`.
428 offlineReplicaRebuilding: ~
429 # -- Controls whether Longhorn monitors and records health information for node disks. When disabled, disk health checks and status updates are skipped.
430 nodeDiskHealthMonitoring: ~
431 # -- Comma-separated list of topology keys that the Longhorn CSI driver is allowed to pass through. When empty (default), no topology keys are passed through, and PVs will have no nodeAffinity. When configured (e.g., "topology.kubernetes.io/zone,topology.kubernetes.io/region"), only the specified keys are kept in topology segments. All other keys are filtered out from both CreateVolumeResponse.AccessibleTopology and NodeGetInfo topology.
432 csiAllowedTopologyKeys: ~
433 # -- Setting that controls CSI storage capacity tracking, which allows the kube-scheduler to filter nodes that cannot fit the requested volume.
434 csiStorageCapacityTracking: ~
435# -- Setting that allows you to update the default backupstore.
437 # -- Endpoint used to access the default backupstore. (Options: "NFS", "CIFS", "AWS", "GCP", "AZURE")
439 # -- Name of the Kubernetes secret associated with the default backup target.
440 backupTargetCredentialSecret: ~
441 # -- Number of seconds that Longhorn waits before checking the default backupstore for new backups. The default value is "300". When the value is "0", polling is disabled.
444 # -- Set to `true` to automatically create a new private registry secret.
446 # -- URL of a private registry. When unspecified, Longhorn uses the default system registry.
448 # -- User account used for authenticating with a private registry.
450 # -- Password for authenticating with a private registry.
452 # -- If create a new private registry secret is true, create a Kubernetes secret with this name; else use the existing secret of this name. Use it to pull images from your private registry.
456 # -- Format of Longhorn Manager logs. (Options: "plain", "json")
458 # -- PriorityClass for Longhorn Manager.
459 priorityClass: *defaultPriorityClassNameRef
460 # -- Toleration for Longhorn Manager on nodes allowed to run Longhorn components.
462 ## If you want to set tolerations for Longhorn Manager DaemonSet, delete the `[]` in the line above
463 ## and uncomment this example block
467 # effect: "NoSchedule"
468 # -- Resource requests and limits for Longhorn Manager pods.
470 # -- Node selector for Longhorn Manager. Specify the nodes allowed to run Longhorn Manager.
472 ## If you want to set node selector for Longhorn Manager DaemonSet, delete the `{}` in the line above
473 ## and uncomment this example block
474 # label-key1: "label-value1"
475 # label-key2: "label-value2"
476 # -- Annotation for the Longhorn Manager service.
477 serviceAnnotations: {}
478 ## If you want to set annotations for the Longhorn Manager service, delete the `{}` in the line above
479 ## and uncomment this example block
480 # annotation-key1: "annotation-value1"
481 # annotation-key2: "annotation-value2"
483 ## If you want to set labels for the Longhorn Manager service, delete the `{}` in the line above
484 ## and uncomment this example block
485 # label-key1: "label-value1"
486 # label-key2: "label-value2"
487 ## DaemonSet update strategy. Default "100% unavailable" matches the upgrade
488 ## flow (old managers removed before new start); override for rolling updates
489 ## if you prefer that behavior.
492 maxUnavailable: "100%"
495 # -- Format of longhorn-driver logs. (Options: "plain", "json")
497 # -- PriorityClass for Longhorn Driver.
498 priorityClass: *defaultPriorityClassNameRef
499 # -- Toleration for Longhorn Driver on nodes allowed to run Longhorn components.
501 ## If you want to set tolerations for Longhorn Driver Deployer Deployment, delete the `[]` in the line above
502 ## and uncomment this example block
506 # effect: "NoSchedule"
507 # -- Node selector for Longhorn Driver. Specify the nodes allowed to run Longhorn Driver.
509 ## If you want to set node selector for Longhorn Driver Deployer Deployment, delete the `{}` in the line above
510 ## and uncomment this example block
511 # label-key1: "label-value1"
512 # label-key2: "label-value2"
514 # -- Replica count for Longhorn UI.
516 # -- PriorityClass for Longhorn UI.
517 priorityClass: *defaultPriorityClassNameRef
518 # -- Affinity for Longhorn UI pods. Specify the affinity you want to use for Longhorn UI.
521 preferredDuringSchedulingIgnoredDuringExecution:
530 topologyKey: kubernetes.io/hostname
531 # -- Toleration for Longhorn UI on nodes allowed to run Longhorn components.
533 ## If you want to set tolerations for Longhorn UI Deployment, delete the `[]` in the line above
534 ## and uncomment this example block
538 # effect: "NoSchedule"
539 # -- Node selector for Longhorn UI. Specify the nodes allowed to run Longhorn UI.
541 ## If you want to set node selector for Longhorn UI Deployment, delete the `{}` in the line above
542 ## and uncomment this example block
543 # label-key1: "label-value1"
544 # label-key2: "label-value2"
546 # -- Setting that allows Longhorn to generate ingress records for the Longhorn UI service.
548 # -- IngressClass resource that contains ingress configuration, including the name of the Ingress controller.
549 # ingressClassName can replace the kubernetes.io/ingress.class annotation used in earlier Kubernetes releases.
551 # -- Hostname of the Layer 7 load balancer.
553 # -- Extra hostnames for TLS (Subject Alternative Names - SAN). Used when you need multiple FQDNs for the same ingress.
556 # - longhorn.example.com
557 # - longhorn-ui.internal.local
559 # -- Setting that allows you to enable TLS on ingress records.
561 # -- Setting that allows you to enable secure connections to the Longhorn UI service via port 443.
562 secureBackends: false
563 # -- TLS secret that contains the private key and certificate to be used for TLS. This setting applies only when TLS is enabled on ingress records.
564 tlsSecret: longhorn.local-tls
565 # -- Default ingress path. You can access the Longhorn UI by following the full ingress path {{host}}+{{path}}.
567 # -- Ingress path type. To maintain backward compatibility, the default value is "ImplementationSpecific".
568 pathType: ImplementationSpecific
569 ## If you're using kube-lego, you will want to add:
570 ## kubernetes.io/tls-acme: true
572 ## For a full list of possible ingress annotations, please see
573 ## ref: https://github.com/kubernetes/ingress-nginx/blob/master/docs/annotations.md
575 ## If tls is set to true, annotation ingress.kubernetes.io/secure-backends: "true" will automatically be set
576 # -- Ingress annotations in the form of key-value pairs.
578 # kubernetes.io/ingress.class: nginx
579 # kubernetes.io/tls-acme: true
581 # -- Secret that contains a TLS private key and certificate. Use secrets if you want to use your own certificates to secure ingresses.
583 ## If you're providing your own certificates, please use this to add the certificates as secrets
584 ## key and certificate should start with -----BEGIN CERTIFICATE----- or
585 ## -----BEGIN RSA PRIVATE KEY-----
587 ## name should line up with a tlsSecret set further up
588 ## If you're using kube-lego, this is unneeded, as it will create the secret for you if it is not set
590 ## It is also possible to create and manage the certificates outside of this helm chart
591 ## Please see README.md for more information
592 # - name: longhorn.local-tls
596 # -- Setting that allows Longhorn to generate HTTPRoute records for the Longhorn UI service using Gateway API.
598 # -- Gateway references for HTTPRoute. Specify which Gateway(s) should handle this route.
601 # - name: gateway-name
602 # namespace: gateway-namespace
603 # # Optional fields with defaults:
604 # # group: gateway.networking.k8s.io # default
605 # # kind: Gateway # default
606 # # sectionName: https # optional, targets a specific listener
607 # -- List of hostnames for the HTTPRoute. Multiple hostnames are supported.
610 # - longhorn.example.com
611 # - longhorn.example.org
612 # -- Default path for HTTPRoute. You can access the Longhorn UI by following the full path.
614 # -- Path match type for HTTPRoute. (Options: "Exact", "PathPrefix")
616 # -- Annotations for the HTTPRoute resource in the form of key-value pairs.
619 # annotation-key1: "annotation-value1"
620# -- Setting that allows you to enable pod security policies (PSPs) that allow privileged Longhorn pods to start. This setting applies only to clusters running Kubernetes 1.25 and earlier, and with the built-in Pod Security admission controller enabled.
622# -- Specify override namespace, specifically this is useful for using longhorn as sub-chart and its release namespace is not the `longhorn-system`.
624# -- Annotation for the Longhorn Manager DaemonSet pods. This setting is optional.
627 # -- Annotations to add to the service account
631 # -- Setting that allows the creation of a Prometheus ServiceMonitor resource for Longhorn Manager components.
633 # -- Additional labels for the Prometheus ServiceMonitor resource.
635 # -- Annotations for the Prometheus ServiceMonitor resource.
637 # -- Interval at which Prometheus scrapes the metrics from the target.
639 # -- Timeout after which Prometheus considers the scrape to be failed.
641 # -- Configures the relabeling rules to apply the target’s metadata labels. See the [Prometheus Operator
642 # documentation](https://prometheus-operator.dev/docs/api-reference/api/#monitoring.coreos.com/v1.Endpoint) for
643 # formatting details.
645 # -- Configures the relabeling rules to apply to the samples before ingestion. See the [Prometheus Operator
646 # documentation](https://prometheus-operator.dev/docs/api-reference/api/#monitoring.coreos.com/v1.Endpoint) for
647 # formatting details.
648 metricRelabelings: []
651 # -- Setting that allows Longhorn to integrate with OpenShift.
654 # -- Route for connections between Longhorn and the OpenShift web console.
656 # -- Port for accessing the OpenShift web console.
658 # -- Port for proxy that provides access to the OpenShift web console.
660# -- Setting that allows Longhorn to generate code coverage profiles.
661enableGoCoverDir: false
662# -- Add extra objects manifests