1
0
Fork 0
mirror of https://github.com/arangodb/kube-arangodb.git synced 2024-12-14 11:57:37 +00:00
kube-arangodb/docs/api/ArangoDeployment.V1.md

7866 lines
276 KiB
Markdown
Raw Permalink Normal View History

---
layout: page
parent: CRD reference
title: ArangoDeployment V1
---
# API Reference for ArangoDeployment V1
## Spec
### .spec.agents.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L156)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.agents.allowMemberRecreation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L198)</sup>
AllowMemberRecreation allows to recreate member.
This setting changes the member recreation logic based on group:
- For Sync Masters, Sync Workers, Coordinator and DB-Servers it determines if a member can be recreated in case of failure (default `true`)
- For Agents and Single this value is hardcoded to `false` and the value provided in spec is ignored.
***
### .spec.agents.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L99)</sup>
Annotations specified the annotations added to Pods in this group.
Annotations are merged with `spec.annotations`.
***
### .spec.agents.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L101)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.agents.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L103)</sup>
AnnotationsMode Define annotations mode which should be use while overriding annotations
***
### .spec.agents.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L152)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.agents.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L57)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.agents.count
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L49)</sup>
Count setting specifies the number of servers to start for the given group.
For the Agent group, this value must be a positive, odd number.
The default value is `3` for all groups except `single` (there the default is `1`
for `spec.mode: Single` and `2` for `spec.mode: ActiveFailover`).
For the `syncworkers` group, it is highly recommended to use the same number
as for the `dbservers` group.
***
### .spec.agents.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L59)</sup>
Entrypoint overrides container executable
***
### .spec.agents.envs\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L26)</sup>
***
### .spec.agents.envs\[int\].value
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L27)</sup>
***
### .spec.agents.ephemeralVolumes.apps.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.agents.ephemeralVolumes.temp.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.agents.exporterPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L211)</sup>
ExporterPort define Port used by exporter
***
### .spec.agents.extendedRotationCheck
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L181)</sup>
ExtendedRotationCheck extend checks for rotation
***
### .spec.agents.externalPortEnabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L193)</sup>
ExternalPortEnabled if external port should be enabled. If is set to false, ports needs to be exposed via sidecar. Only for ArangoD members
***
### .spec.agents.indexMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L204)</sup>
IndexMethod define group Indexing method
2023-10-12 14:37:40 +00:00
Possible Values:
* `"random"` (default) - Pick random ID for member. Enforced on the Community Operator.
* `"ordered"` - Use sequential number as Member ID, starting from 0. Enterprise Operator required.
2023-10-12 14:37:40 +00:00
***
### .spec.agents.initContainers.containers
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L91)</sup>
Containers contains list of containers
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.agents.initContainers.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L94)</sup>
Mode keep container replace mode
***
### .spec.agents.internalPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L189)</sup>
InternalPort define port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.agents.internalPortProtocol
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L191)</sup>
InternalPortProtocol define protocol of port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.agents.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L105)</sup>
Labels specified the labels added to Pods in this group.
***
### .spec.agents.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L107)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.agents.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L109)</sup>
LabelsMode Define labels mode which should be use while overriding labels
***
### .spec.agents.maxCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L53)</sup>
MaxCount specifies a maximum for the count of servers. If set, a specification is invalid if `count > maxCount`.
***
### .spec.agents.memoryReservation
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L81)</sup>
MemoryReservation determines the system reservation of memory while calculating `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` value.
If this field is set, `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` is reduced by a specified value in percent.
Accepted Range <0, 50>. If the value is outside the accepted range, it is adjusted to the closest value.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `0`
***
### .spec.agents.minCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L51)</sup>
MinCount specifies a minimum for the count of servers. If set, a specification is invalid if `count < minCount`.
***
### .spec.agents.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L160)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.agents.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L124)</sup>
NodeSelector setting specifies a set of labels to be used as `nodeSelector` for Pods of this node.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)
***
### .spec.agents.numactl.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L38)</sup>
2023-07-28 08:00:57 +00:00
Args define list of the numactl process
Default Value: `[]`
2023-07-28 08:00:57 +00:00
***
### .spec.agents.numactl.enabled
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L30)</sup>
2023-07-28 08:00:57 +00:00
Enabled define if numactl should be enabled
Default Value: `false`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.agents.numactl.path
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L34)</sup>
2023-07-28 08:00:57 +00:00
Path define numactl path within the container
Default Value: `/usr/bin/numactl`
2023-07-28 08:00:57 +00:00
***
### .spec.agents.overrideDetectedNumberOfCores
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L87)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` Container Environment Variable**
OverrideDetectedNumberOfCores determines if number of cores should be overridden based on values in resources.
If is set to true and Container CPU Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` to the value from the Container CPU Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.agents.overrideDetectedTotalMemory
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L75)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` Container Environment Variable**
OverrideDetectedTotalMemory determines if memory should be overridden based on values in resources.
If is set to true and Container Memory Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` to the value from the Container Memory Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.agents.podModes.network
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L31)</sup>
***
### .spec.agents.podModes.pid
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L32)</sup>
***
### .spec.agents.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L209)</sup>
Port define Port used by member
***
### .spec.agents.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L130)</sup>
PriorityClassName specifies a priority class name
Will be forwarded to the pod spec.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/pod-priority-preemption/)
***
### .spec.agents.probes.livenessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L27)</sup>
LivenessProbeDisabled if set to true, the operator does not generate a liveness probe for new pods belonging to this group
Default Value: `false`
***
### .spec.agents.probes.livenessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.agents.probes.livenessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.agents.probes.livenessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.agents.probes.livenessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.agents.probes.livenessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.agents.probes.ReadinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L34)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is deprecated, kept only for backward compatibility.**
OldReadinessProbeDisabled if true readinessProbes are disabled
***
### .spec.agents.probes.readinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L36)</sup>
ReadinessProbeDisabled override flag for probe disabled in good manner (lowercase) with backward compatibility
***
### .spec.agents.probes.readinessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.agents.probes.readinessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.agents.probes.readinessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.agents.probes.readinessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.agents.probes.readinessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.agents.probes.startupProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L41)</sup>
StartupProbeDisabled if true startupProbes are disabled
***
### .spec.agents.probes.startupProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.agents.probes.startupProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.agents.probes.startupProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.agents.probes.startupProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.agents.probes.startupProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.agents.pvcResizeMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L144)</sup>
VolumeResizeMode specified resize mode for PVCs and PVs
Possible Values:
* `"runtime"` (default) - PVC will be resized in Pod runtime (EKS, GKE)
* `"rotate"` - Pod will be shutdown and PVC will be resized (AKS)
***
### .spec.agents.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L69)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.agents.schedulerName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L61)</sup>
SchedulerName define scheduler name used for group
***
### .spec.agents.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.agents.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.agents.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.agents.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.agents.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.agents.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.agents.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.agents.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.agents.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.agents.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.agents.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.agents.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.agents.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.agents.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L120)</sup>
ServiceAccountName setting specifies the `serviceAccountName` for the `Pods` created
for each server of this group. If empty, it defaults to using the
`default` service account.
Using an alternative `ServiceAccount` is typically used to separate access rights.
The ArangoDB deployments need some very minimal access rights. With the
deployment of the operator, we grant the rights to 'get' all 'pod' resources.
If you are using a different service account, please grant these rights
to that service account.
***
### .spec.agents.shutdownDelay
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L187)</sup>
ShutdownDelay define how long operator should delay finalizer removal after shutdown
***
### .spec.agents.shutdownMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L185)</sup>
ShutdownMethod describe procedure of member shutdown taken by Operator
***
### .spec.agents.sidecarCoreNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L163)</sup>
SidecarCoreNames is a list of sidecar containers which must run in the pod.
Some names (e.g.: "server", "worker") are reserved, and they don't have any impact.
***
### .spec.agents.sidecars
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L167)</sup>
Sidecars specifies a list of additional containers to be started
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.agents.storageClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L65)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Use VolumeClaimTemplate instead.**
StorageClassName specifies the classname for storage of the servers.
***
### .spec.agents.terminationGracePeriodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L200)</sup>
TerminationGracePeriodSeconds override default TerminationGracePeriodSeconds for pods - via silent rotation
***
### .spec.agents.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L96)</sup>
Tolerations specifies the tolerations added to Pods in this group.
By default, suitable tolerations are set for the following keys with the `NoExecute` effect:
- `node.kubernetes.io/not-ready`
- `node.kubernetes.io/unreachable`
- `node.alpha.kubernetes.io/unreachable` (will be removed in future version)
For more information on tolerations, consult the https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.agents.volumeAllowShrink
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L148)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
VolumeAllowShrink allows shrinking of the volume
***
### .spec.agents.volumeClaimTemplate
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaim` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L139)</sup>
VolumeClaimTemplate specifies a volumeClaimTemplate used by operator to create to volume claims for pods of this group.
This setting is not available for group `coordinators`, `syncmasters` & `syncworkers`.
The default value describes a volume with `8Gi` storage, `ReadWriteOnce` access mode and volume mode set to `PersistentVolumeFilesystem`.
If this field is not set and `spec.<group>.resources.requests.storage` is set, then a default volume claim
with size as specified by `spec.<group>.resources.requests.storage` will be created. In that case `storage`
and `iops` is not forwarded to the pods resource requirements.
Links:
* [Documentation of core.PersistentVolumeClaim](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaim-v1-core)
***
### .spec.agents.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]ServerGroupSpecVolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L177)</sup>
VolumeMounts define list of volume mounts mounted into server container
Links:
* [Documentation of ServerGroupSpecVolumeMount](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#volumemount-v1-core)
***
### .spec.agents.volumes\[int\].configMap
2024-10-14 14:35:16 +00:00
Type: `core.ConfigMapVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L138)</sup>
ConfigMap which should be mounted into pod
Links:
* [Documentation of core.ConfigMapVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapvolumesource-v1-core)
***
### .spec.agents.volumes\[int\].emptyDir
2024-10-14 14:35:16 +00:00
Type: `core.EmptyDirVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L143)</sup>
EmptyDir
Links:
* [Documentation of core.EmptyDirVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#emptydirvolumesource-v1-core)
***
### .spec.agents.volumes\[int\].hostPath
2024-10-14 14:35:16 +00:00
Type: `core.HostPathVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L148)</sup>
HostPath
Links:
* [Documentation of core.HostPathVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#hostpathvolumesource-v1-core)
***
### .spec.agents.volumes\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L128)</sup>
Name of volume
***
### .spec.agents.volumes\[int\].persistentVolumeClaim
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaimVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L153)</sup>
PersistentVolumeClaim
Links:
* [Documentation of core.PersistentVolumeClaimVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaimvolumesource-v1-core)
***
### .spec.agents.volumes\[int\].secret
2024-10-14 14:35:16 +00:00
Type: `core.SecretVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L133)</sup>
Secret which should be mounted into pod
Links:
* [Documentation of core.SecretVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretvolumesource-v1-core)
***
### .spec.allowUnsafeUpgrade
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L152)</sup>
AllowUnsafeUpgrade determines if upgrade on missing member or with not in sync shards is allowed
***
### .spec.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L115)</sup>
Annotations specifies the annotations added to all ArangoDeployment owned resources (pods, services, PVCs, PDBs).
***
### .spec.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L118)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L124)</sup>
AnnotationsMode defines annotations mode which should be use while overriding annotations.
Possible Values:
* `"disabled"` (default) - Disable annotations/labels override. Default if there is no annotations/labels set in ArangoDeployment
* `"append"` - Add new annotations/labels without affecting old ones
* `"replace"` - Replace existing annotations/labels
***
### .spec.architecture
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L257)</sup>
Architecture defines the list of supported architectures.
First element on the list is marked as default architecture.
Possible values are:
- `amd64`: Use processors with the x86-64 architecture.
- `arm64`: Use processors with the 64-bit ARM architecture.
The setting expects a list of strings, but you should only specify a single
list item for the architecture, except when you want to migrate from one
architecture to the other. The first list item defines the new default
architecture for the deployment that you want to migrate to.
Links:
* [Architecture Change](../how-to/arch_change.md)
Default Value: `['amd64']`
***
### .spec.auth.jwtSecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/authentication_spec.go#L38)</sup>
JWTSecretName setting specifies the name of a kubernetes `Secret` that contains a secret key used for generating
JWT tokens to access all ArangoDB servers.
When no name is specified, it defaults to `<deployment-name>-jwt`.
To disable authentication, set this value to `None`.
If you specify a name of a `Secret`, that secret must have the key value in a data field named `token`.
If you specify a name of a `Secret` that does not exist, a random key is created and stored in a `Secret` with given name.
Changing secret key results in restarting of a whole cluster.
***
### .spec.bootstrap.passwordSecretNames
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/bootstrap.go#L62)</sup>
PasswordSecretNames contains a map of username to password-secret-name
This setting specifies a secret name for the credentials per specific users.
When a deployment is created the operator will setup the user accounts
according to the credentials given by the secret. If the secret doesn't exist
the operator creates a secret with a random password.
There are two magic values for the secret name:
- `None` specifies no action. This disables root password randomization. This is the default value. (Thus the root password is empty - not recommended)
- `Auto` specifies automatic name generation, which is `<deploymentname>-root-password`.
Links:
* [How to set root user password](../how-to/set_root_user_password.md)
***
### .spec.chaos.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/chaos_spec.go#L33)</sup>
Enabled switches the chaos monkey for a deployment on or off.
***
### .spec.chaos.interval
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/chaos_spec.go#L35)</sup>
Interval is the time between events
***
### .spec.chaos.kill-pod-probability
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/chaos_spec.go#L37)</sup>
KillPodProbability is the chance of a pod being killed during an event
***
### .spec.ClusterDomain
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L229)</sup>
ClusterDomain define domain used in the kubernetes cluster.
Required only of domain is not set to default (cluster.local)
Default Value: `cluster.local`
***
### .spec.communicationMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L237)</sup>
CommunicationMethod define communication method used in deployment
Possible Values:
* `"headless"` (default) - Define old communication mechanism, based on headless service.
* `"dns"` - Define ClusterIP Service DNS based communication.
* `"short-dns"` - Define ClusterIP Service DNS based communication. Use namespaced short DNS (used in migration)
* `"headless-dns"` - Define Headless Service DNS based communication.
* `"ip"` - Define ClusterIP Service IP based communication.
***
### .spec.coordinators.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L156)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.coordinators.allowMemberRecreation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L198)</sup>
AllowMemberRecreation allows to recreate member.
This setting changes the member recreation logic based on group:
- For Sync Masters, Sync Workers, Coordinator and DB-Servers it determines if a member can be recreated in case of failure (default `true`)
- For Agents and Single this value is hardcoded to `false` and the value provided in spec is ignored.
***
### .spec.coordinators.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L99)</sup>
Annotations specified the annotations added to Pods in this group.
Annotations are merged with `spec.annotations`.
***
### .spec.coordinators.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L101)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.coordinators.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L103)</sup>
AnnotationsMode Define annotations mode which should be use while overriding annotations
***
### .spec.coordinators.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L152)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.coordinators.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L57)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.coordinators.count
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L49)</sup>
Count setting specifies the number of servers to start for the given group.
For the Agent group, this value must be a positive, odd number.
The default value is `3` for all groups except `single` (there the default is `1`
for `spec.mode: Single` and `2` for `spec.mode: ActiveFailover`).
For the `syncworkers` group, it is highly recommended to use the same number
as for the `dbservers` group.
***
### .spec.coordinators.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L59)</sup>
Entrypoint overrides container executable
***
### .spec.coordinators.envs\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L26)</sup>
***
### .spec.coordinators.envs\[int\].value
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L27)</sup>
***
### .spec.coordinators.ephemeralVolumes.apps.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.coordinators.ephemeralVolumes.temp.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.coordinators.exporterPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L211)</sup>
ExporterPort define Port used by exporter
***
### .spec.coordinators.extendedRotationCheck
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L181)</sup>
ExtendedRotationCheck extend checks for rotation
***
### .spec.coordinators.externalPortEnabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L193)</sup>
ExternalPortEnabled if external port should be enabled. If is set to false, ports needs to be exposed via sidecar. Only for ArangoD members
***
### .spec.coordinators.indexMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L204)</sup>
IndexMethod define group Indexing method
2023-10-12 14:37:40 +00:00
Possible Values:
* `"random"` (default) - Pick random ID for member. Enforced on the Community Operator.
* `"ordered"` - Use sequential number as Member ID, starting from 0. Enterprise Operator required.
2023-10-12 14:37:40 +00:00
***
### .spec.coordinators.initContainers.containers
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L91)</sup>
Containers contains list of containers
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.coordinators.initContainers.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L94)</sup>
Mode keep container replace mode
***
### .spec.coordinators.internalPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L189)</sup>
InternalPort define port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.coordinators.internalPortProtocol
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L191)</sup>
InternalPortProtocol define protocol of port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.coordinators.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L105)</sup>
Labels specified the labels added to Pods in this group.
***
### .spec.coordinators.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L107)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.coordinators.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L109)</sup>
LabelsMode Define labels mode which should be use while overriding labels
***
### .spec.coordinators.maxCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L53)</sup>
MaxCount specifies a maximum for the count of servers. If set, a specification is invalid if `count > maxCount`.
***
### .spec.coordinators.memoryReservation
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L81)</sup>
MemoryReservation determines the system reservation of memory while calculating `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` value.
If this field is set, `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` is reduced by a specified value in percent.
Accepted Range <0, 50>. If the value is outside the accepted range, it is adjusted to the closest value.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `0`
***
### .spec.coordinators.minCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L51)</sup>
MinCount specifies a minimum for the count of servers. If set, a specification is invalid if `count < minCount`.
***
### .spec.coordinators.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L160)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.coordinators.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L124)</sup>
NodeSelector setting specifies a set of labels to be used as `nodeSelector` for Pods of this node.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)
***
### .spec.coordinators.numactl.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L38)</sup>
2023-07-28 08:00:57 +00:00
Args define list of the numactl process
Default Value: `[]`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.coordinators.numactl.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L30)</sup>
2023-07-28 08:00:57 +00:00
Enabled define if numactl should be enabled
Default Value: `false`
2023-07-28 08:00:57 +00:00
***
### .spec.coordinators.numactl.path
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L34)</sup>
2023-07-28 08:00:57 +00:00
Path define numactl path within the container
Default Value: `/usr/bin/numactl`
2023-07-28 08:00:57 +00:00
***
### .spec.coordinators.overrideDetectedNumberOfCores
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L87)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` Container Environment Variable**
OverrideDetectedNumberOfCores determines if number of cores should be overridden based on values in resources.
If is set to true and Container CPU Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` to the value from the Container CPU Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.coordinators.overrideDetectedTotalMemory
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L75)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` Container Environment Variable**
OverrideDetectedTotalMemory determines if memory should be overridden based on values in resources.
If is set to true and Container Memory Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` to the value from the Container Memory Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.coordinators.podModes.network
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L31)</sup>
***
### .spec.coordinators.podModes.pid
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L32)</sup>
***
### .spec.coordinators.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L209)</sup>
Port define Port used by member
***
### .spec.coordinators.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L130)</sup>
PriorityClassName specifies a priority class name
Will be forwarded to the pod spec.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/pod-priority-preemption/)
***
### .spec.coordinators.probes.livenessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L27)</sup>
LivenessProbeDisabled if set to true, the operator does not generate a liveness probe for new pods belonging to this group
Default Value: `false`
***
### .spec.coordinators.probes.livenessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.coordinators.probes.livenessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.coordinators.probes.livenessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.coordinators.probes.livenessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.coordinators.probes.livenessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.coordinators.probes.ReadinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L34)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is deprecated, kept only for backward compatibility.**
OldReadinessProbeDisabled if true readinessProbes are disabled
***
### .spec.coordinators.probes.readinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L36)</sup>
ReadinessProbeDisabled override flag for probe disabled in good manner (lowercase) with backward compatibility
***
### .spec.coordinators.probes.readinessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.coordinators.probes.readinessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.coordinators.probes.readinessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.coordinators.probes.readinessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.coordinators.probes.readinessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.coordinators.probes.startupProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L41)</sup>
StartupProbeDisabled if true startupProbes are disabled
***
### .spec.coordinators.probes.startupProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.coordinators.probes.startupProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.coordinators.probes.startupProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.coordinators.probes.startupProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.coordinators.probes.startupProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.coordinators.pvcResizeMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L144)</sup>
VolumeResizeMode specified resize mode for PVCs and PVs
Possible Values:
* `"runtime"` (default) - PVC will be resized in Pod runtime (EKS, GKE)
* `"rotate"` - Pod will be shutdown and PVC will be resized (AKS)
***
### .spec.coordinators.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L69)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.coordinators.schedulerName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L61)</sup>
SchedulerName define scheduler name used for group
***
### .spec.coordinators.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.coordinators.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.coordinators.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.coordinators.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.coordinators.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.coordinators.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.coordinators.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.coordinators.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.coordinators.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.coordinators.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.coordinators.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.coordinators.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.coordinators.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.coordinators.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L120)</sup>
ServiceAccountName setting specifies the `serviceAccountName` for the `Pods` created
for each server of this group. If empty, it defaults to using the
`default` service account.
Using an alternative `ServiceAccount` is typically used to separate access rights.
The ArangoDB deployments need some very minimal access rights. With the
deployment of the operator, we grant the rights to 'get' all 'pod' resources.
If you are using a different service account, please grant these rights
to that service account.
***
### .spec.coordinators.shutdownDelay
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L187)</sup>
ShutdownDelay define how long operator should delay finalizer removal after shutdown
***
### .spec.coordinators.shutdownMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L185)</sup>
ShutdownMethod describe procedure of member shutdown taken by Operator
***
### .spec.coordinators.sidecarCoreNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L163)</sup>
SidecarCoreNames is a list of sidecar containers which must run in the pod.
Some names (e.g.: "server", "worker") are reserved, and they don't have any impact.
***
### .spec.coordinators.sidecars
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L167)</sup>
Sidecars specifies a list of additional containers to be started
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.coordinators.storageClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L65)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Use VolumeClaimTemplate instead.**
StorageClassName specifies the classname for storage of the servers.
***
### .spec.coordinators.terminationGracePeriodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L200)</sup>
TerminationGracePeriodSeconds override default TerminationGracePeriodSeconds for pods - via silent rotation
***
### .spec.coordinators.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L96)</sup>
Tolerations specifies the tolerations added to Pods in this group.
By default, suitable tolerations are set for the following keys with the `NoExecute` effect:
- `node.kubernetes.io/not-ready`
- `node.kubernetes.io/unreachable`
- `node.alpha.kubernetes.io/unreachable` (will be removed in future version)
For more information on tolerations, consult the https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.coordinators.volumeAllowShrink
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L148)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
VolumeAllowShrink allows shrinking of the volume
***
### .spec.coordinators.volumeClaimTemplate
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaim` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L139)</sup>
VolumeClaimTemplate specifies a volumeClaimTemplate used by operator to create to volume claims for pods of this group.
This setting is not available for group `coordinators`, `syncmasters` & `syncworkers`.
The default value describes a volume with `8Gi` storage, `ReadWriteOnce` access mode and volume mode set to `PersistentVolumeFilesystem`.
If this field is not set and `spec.<group>.resources.requests.storage` is set, then a default volume claim
with size as specified by `spec.<group>.resources.requests.storage` will be created. In that case `storage`
and `iops` is not forwarded to the pods resource requirements.
Links:
* [Documentation of core.PersistentVolumeClaim](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaim-v1-core)
***
### .spec.coordinators.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]ServerGroupSpecVolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L177)</sup>
VolumeMounts define list of volume mounts mounted into server container
Links:
* [Documentation of ServerGroupSpecVolumeMount](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#volumemount-v1-core)
***
### .spec.coordinators.volumes\[int\].configMap
2024-10-14 14:35:16 +00:00
Type: `core.ConfigMapVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L138)</sup>
ConfigMap which should be mounted into pod
Links:
* [Documentation of core.ConfigMapVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapvolumesource-v1-core)
***
### .spec.coordinators.volumes\[int\].emptyDir
2024-10-14 14:35:16 +00:00
Type: `core.EmptyDirVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L143)</sup>
EmptyDir
Links:
* [Documentation of core.EmptyDirVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#emptydirvolumesource-v1-core)
***
### .spec.coordinators.volumes\[int\].hostPath
2024-10-14 14:35:16 +00:00
Type: `core.HostPathVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L148)</sup>
HostPath
Links:
* [Documentation of core.HostPathVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#hostpathvolumesource-v1-core)
***
### .spec.coordinators.volumes\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L128)</sup>
Name of volume
***
### .spec.coordinators.volumes\[int\].persistentVolumeClaim
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaimVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L153)</sup>
PersistentVolumeClaim
Links:
* [Documentation of core.PersistentVolumeClaimVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaimvolumesource-v1-core)
***
### .spec.coordinators.volumes\[int\].secret
2024-10-14 14:35:16 +00:00
Type: `core.SecretVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L133)</sup>
Secret which should be mounted into pod
Links:
* [Documentation of core.SecretVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretvolumesource-v1-core)
***
### .spec.database.maintenance
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/database_spec.go#L25)</sup>
Maintenance manage maintenance mode on Cluster side. Requires maintenance feature to be enabled
***
### .spec.dbservers.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L156)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.dbservers.allowMemberRecreation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L198)</sup>
AllowMemberRecreation allows to recreate member.
This setting changes the member recreation logic based on group:
- For Sync Masters, Sync Workers, Coordinator and DB-Servers it determines if a member can be recreated in case of failure (default `true`)
- For Agents and Single this value is hardcoded to `false` and the value provided in spec is ignored.
***
### .spec.dbservers.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L99)</sup>
Annotations specified the annotations added to Pods in this group.
Annotations are merged with `spec.annotations`.
***
### .spec.dbservers.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L101)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.dbservers.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L103)</sup>
AnnotationsMode Define annotations mode which should be use while overriding annotations
***
### .spec.dbservers.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L152)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.dbservers.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L57)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.dbservers.count
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L49)</sup>
Count setting specifies the number of servers to start for the given group.
For the Agent group, this value must be a positive, odd number.
The default value is `3` for all groups except `single` (there the default is `1`
for `spec.mode: Single` and `2` for `spec.mode: ActiveFailover`).
For the `syncworkers` group, it is highly recommended to use the same number
as for the `dbservers` group.
***
### .spec.dbservers.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L59)</sup>
Entrypoint overrides container executable
***
### .spec.dbservers.envs\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L26)</sup>
***
### .spec.dbservers.envs\[int\].value
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L27)</sup>
***
### .spec.dbservers.ephemeralVolumes.apps.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.dbservers.ephemeralVolumes.temp.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.dbservers.exporterPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L211)</sup>
ExporterPort define Port used by exporter
***
### .spec.dbservers.extendedRotationCheck
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L181)</sup>
ExtendedRotationCheck extend checks for rotation
***
### .spec.dbservers.externalPortEnabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L193)</sup>
ExternalPortEnabled if external port should be enabled. If is set to false, ports needs to be exposed via sidecar. Only for ArangoD members
***
### .spec.dbservers.indexMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L204)</sup>
IndexMethod define group Indexing method
2023-10-12 14:37:40 +00:00
Possible Values:
* `"random"` (default) - Pick random ID for member. Enforced on the Community Operator.
* `"ordered"` - Use sequential number as Member ID, starting from 0. Enterprise Operator required.
2023-10-12 14:37:40 +00:00
***
### .spec.dbservers.initContainers.containers
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L91)</sup>
Containers contains list of containers
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.dbservers.initContainers.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L94)</sup>
Mode keep container replace mode
***
### .spec.dbservers.internalPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L189)</sup>
InternalPort define port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.dbservers.internalPortProtocol
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L191)</sup>
InternalPortProtocol define protocol of port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.dbservers.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L105)</sup>
Labels specified the labels added to Pods in this group.
***
### .spec.dbservers.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L107)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.dbservers.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L109)</sup>
LabelsMode Define labels mode which should be use while overriding labels
***
### .spec.dbservers.maxCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L53)</sup>
MaxCount specifies a maximum for the count of servers. If set, a specification is invalid if `count > maxCount`.
***
### .spec.dbservers.memoryReservation
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L81)</sup>
MemoryReservation determines the system reservation of memory while calculating `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` value.
If this field is set, `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` is reduced by a specified value in percent.
Accepted Range <0, 50>. If the value is outside the accepted range, it is adjusted to the closest value.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `0`
***
### .spec.dbservers.minCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L51)</sup>
MinCount specifies a minimum for the count of servers. If set, a specification is invalid if `count < minCount`.
***
### .spec.dbservers.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L160)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.dbservers.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L124)</sup>
NodeSelector setting specifies a set of labels to be used as `nodeSelector` for Pods of this node.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)
***
### .spec.dbservers.numactl.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L38)</sup>
2023-07-28 08:00:57 +00:00
Args define list of the numactl process
Default Value: `[]`
2023-07-28 08:00:57 +00:00
***
### .spec.dbservers.numactl.enabled
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L30)</sup>
2023-07-28 08:00:57 +00:00
Enabled define if numactl should be enabled
Default Value: `false`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.dbservers.numactl.path
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L34)</sup>
2023-07-28 08:00:57 +00:00
Path define numactl path within the container
Default Value: `/usr/bin/numactl`
2023-07-28 08:00:57 +00:00
***
### .spec.dbservers.overrideDetectedNumberOfCores
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L87)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` Container Environment Variable**
OverrideDetectedNumberOfCores determines if number of cores should be overridden based on values in resources.
If is set to true and Container CPU Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` to the value from the Container CPU Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.dbservers.overrideDetectedTotalMemory
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L75)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` Container Environment Variable**
OverrideDetectedTotalMemory determines if memory should be overridden based on values in resources.
If is set to true and Container Memory Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` to the value from the Container Memory Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.dbservers.podModes.network
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L31)</sup>
***
### .spec.dbservers.podModes.pid
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L32)</sup>
***
### .spec.dbservers.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L209)</sup>
Port define Port used by member
***
### .spec.dbservers.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L130)</sup>
PriorityClassName specifies a priority class name
Will be forwarded to the pod spec.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/pod-priority-preemption/)
***
### .spec.dbservers.probes.livenessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L27)</sup>
LivenessProbeDisabled if set to true, the operator does not generate a liveness probe for new pods belonging to this group
Default Value: `false`
***
### .spec.dbservers.probes.livenessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.dbservers.probes.livenessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.dbservers.probes.livenessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.dbservers.probes.livenessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.dbservers.probes.livenessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.dbservers.probes.ReadinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L34)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is deprecated, kept only for backward compatibility.**
OldReadinessProbeDisabled if true readinessProbes are disabled
***
### .spec.dbservers.probes.readinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L36)</sup>
ReadinessProbeDisabled override flag for probe disabled in good manner (lowercase) with backward compatibility
***
### .spec.dbservers.probes.readinessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.dbservers.probes.readinessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.dbservers.probes.readinessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.dbservers.probes.readinessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.dbservers.probes.readinessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.dbservers.probes.startupProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L41)</sup>
StartupProbeDisabled if true startupProbes are disabled
***
### .spec.dbservers.probes.startupProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.dbservers.probes.startupProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.dbservers.probes.startupProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.dbservers.probes.startupProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.dbservers.probes.startupProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.dbservers.pvcResizeMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L144)</sup>
VolumeResizeMode specified resize mode for PVCs and PVs
Possible Values:
* `"runtime"` (default) - PVC will be resized in Pod runtime (EKS, GKE)
* `"rotate"` - Pod will be shutdown and PVC will be resized (AKS)
***
### .spec.dbservers.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L69)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.dbservers.schedulerName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L61)</sup>
SchedulerName define scheduler name used for group
***
### .spec.dbservers.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.dbservers.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.dbservers.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.dbservers.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.dbservers.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.dbservers.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.dbservers.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.dbservers.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.dbservers.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.dbservers.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.dbservers.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.dbservers.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.dbservers.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.dbservers.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L120)</sup>
ServiceAccountName setting specifies the `serviceAccountName` for the `Pods` created
for each server of this group. If empty, it defaults to using the
`default` service account.
Using an alternative `ServiceAccount` is typically used to separate access rights.
The ArangoDB deployments need some very minimal access rights. With the
deployment of the operator, we grant the rights to 'get' all 'pod' resources.
If you are using a different service account, please grant these rights
to that service account.
***
### .spec.dbservers.shutdownDelay
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L187)</sup>
ShutdownDelay define how long operator should delay finalizer removal after shutdown
***
### .spec.dbservers.shutdownMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L185)</sup>
ShutdownMethod describe procedure of member shutdown taken by Operator
***
### .spec.dbservers.sidecarCoreNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L163)</sup>
SidecarCoreNames is a list of sidecar containers which must run in the pod.
Some names (e.g.: "server", "worker") are reserved, and they don't have any impact.
***
### .spec.dbservers.sidecars
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L167)</sup>
Sidecars specifies a list of additional containers to be started
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.dbservers.storageClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L65)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Use VolumeClaimTemplate instead.**
StorageClassName specifies the classname for storage of the servers.
***
### .spec.dbservers.terminationGracePeriodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L200)</sup>
TerminationGracePeriodSeconds override default TerminationGracePeriodSeconds for pods - via silent rotation
***
### .spec.dbservers.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L96)</sup>
Tolerations specifies the tolerations added to Pods in this group.
By default, suitable tolerations are set for the following keys with the `NoExecute` effect:
- `node.kubernetes.io/not-ready`
- `node.kubernetes.io/unreachable`
- `node.alpha.kubernetes.io/unreachable` (will be removed in future version)
For more information on tolerations, consult the https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.dbservers.volumeAllowShrink
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L148)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
VolumeAllowShrink allows shrinking of the volume
***
### .spec.dbservers.volumeClaimTemplate
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaim` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L139)</sup>
VolumeClaimTemplate specifies a volumeClaimTemplate used by operator to create to volume claims for pods of this group.
This setting is not available for group `coordinators`, `syncmasters` & `syncworkers`.
The default value describes a volume with `8Gi` storage, `ReadWriteOnce` access mode and volume mode set to `PersistentVolumeFilesystem`.
If this field is not set and `spec.<group>.resources.requests.storage` is set, then a default volume claim
with size as specified by `spec.<group>.resources.requests.storage` will be created. In that case `storage`
and `iops` is not forwarded to the pods resource requirements.
Links:
* [Documentation of core.PersistentVolumeClaim](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaim-v1-core)
***
### .spec.dbservers.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]ServerGroupSpecVolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L177)</sup>
VolumeMounts define list of volume mounts mounted into server container
Links:
* [Documentation of ServerGroupSpecVolumeMount](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#volumemount-v1-core)
***
### .spec.dbservers.volumes\[int\].configMap
2024-10-14 14:35:16 +00:00
Type: `core.ConfigMapVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L138)</sup>
ConfigMap which should be mounted into pod
Links:
* [Documentation of core.ConfigMapVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapvolumesource-v1-core)
***
### .spec.dbservers.volumes\[int\].emptyDir
2024-10-14 14:35:16 +00:00
Type: `core.EmptyDirVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L143)</sup>
EmptyDir
Links:
* [Documentation of core.EmptyDirVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#emptydirvolumesource-v1-core)
***
### .spec.dbservers.volumes\[int\].hostPath
2024-10-14 14:35:16 +00:00
Type: `core.HostPathVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L148)</sup>
HostPath
Links:
* [Documentation of core.HostPathVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#hostpathvolumesource-v1-core)
***
### .spec.dbservers.volumes\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L128)</sup>
Name of volume
***
### .spec.dbservers.volumes\[int\].persistentVolumeClaim
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaimVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L153)</sup>
PersistentVolumeClaim
Links:
* [Documentation of core.PersistentVolumeClaimVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaimvolumesource-v1-core)
***
### .spec.dbservers.volumes\[int\].secret
2024-10-14 14:35:16 +00:00
Type: `core.SecretVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L133)</sup>
Secret which should be mounted into pod
Links:
* [Documentation of core.SecretVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretvolumesource-v1-core)
***
### .spec.disableIPv6
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L98)</sup>
DisableIPv6 setting prevents the use of IPv6 addresses by ArangoDB servers.
This setting cannot be changed after the deployment has been created.
Default Value: `false`
***
### .spec.downtimeAllowed
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L93)</sup>
DowntimeAllowed setting is used to allow automatic reconciliation actions that yield some downtime of the ArangoDB deployment.
When this setting is set to false, no automatic action that may result in downtime is allowed.
If the need for such an action is detected, an event is added to the ArangoDeployment.
Once this setting is set to true, the automatic action is executed.
Operations that may result in downtime are:
- Rotating TLS CA certificate
Note: It is still possible that there is some downtime when the Kubernetes cluster is down, or in a bad state, irrespective of the value of this setting.
Default Value: `false`
***
### .spec.environment
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L54)</sup>
Environment setting specifies the type of environment in which the deployment is created.
Possible Values:
* `"Development"` (default) - This value optimizes the deployment for development use. It is possible to run a deployment on a small number of nodes (e.g. minikube).
* `"Production"` - This value optimizes the deployment for production use. It puts required affinity constraints on all pods to avoid Agents & DB-Servers from running on the same machine.
***
### .spec.externalAccess.advertisedEndpoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L58)</sup>
AdvertisedEndpoint is passed to the coordinators/single servers for advertising a specific endpoint
***
### .spec.externalAccess.loadBalancerIP
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L48)</sup>
LoadBalancerIP define optional IP used to configure a load-balancer on, in case of Auto or LoadBalancer type.
If you do not specify this setting, an IP will be chosen automatically by the load-balancer provisioner.
***
### .spec.externalAccess.loadBalancerSourceRanges
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L55)</sup>
LoadBalancerSourceRanges define LoadBalancerSourceRanges used for LoadBalancer Service type
If specified and supported by the platform, this will restrict traffic through the cloud-provider
load-balancer will be restricted to the specified client IPs. This field will be ignored if the
cloud-provider does not support the feature.
Links:
* [Cloud Provider Firewall](https://kubernetes.io/docs/tasks/access-application-cluster/configure-cloud-provider-firewall/)
***
### .spec.externalAccess.managedServiceNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L62)</sup>
ManagedServiceNames keeps names of services which are not managed by KubeArangoDB.
It is only relevant when type of service is `managed`.
***
### .spec.externalAccess.nodePort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L44)</sup>
NodePort define optional port used in case of Auto or NodePort type.
This setting is used when `spec.externalAccess.type` is set to `NodePort` or `Auto`.
If you do not specify this setting, a random port will be chosen automatically.
***
### .spec.externalAccess.type
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L39)</sup>
Type specifies the type of Service that will be created to provide access to the ArangoDB deployment from outside the Kubernetes cluster.
Possible Values:
* `"Auto"` (default) - Create a Service of type LoadBalancer and fallback to a Service or type NodePort when the LoadBalancer is not assigned an IP address.
* `"None"` - limit access to application running inside the Kubernetes cluster.
* `"LoadBalancer"` - Create a Service of type LoadBalancer for the ArangoDB deployment.
* `"NodePort"` - Create a Service of type NodePort for the ArangoDB deployment.
***
### .spec.features.foxx.queues
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_features.go#L24)</sup>
***
### .spec.gateway.dynamic
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec_gateway.go#L36)</sup>
Dynamic setting enables/disables support dynamic configuration of the gateway in the cluster.
When enabled, gateway config will be reloaded by ConfigMap live updates.
Default Value: `false`
***
### .spec.gateway.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec_gateway.go#L31)</sup>
2024-08-28 09:26:04 +00:00
Enabled setting enables/disables support for gateway in the cluster.
When enabled, the cluster will contain a number of `gateway` servers.
Default Value: `false`
***
### .spec.gateway.image
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec_gateway.go#L40)</sup>
2024-08-28 09:26:04 +00:00
Image is the image to use for the gateway.
By default, the image is determined by the operator.
***
### .spec.gateways.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L156)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.gateways.allowMemberRecreation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L198)</sup>
AllowMemberRecreation allows to recreate member.
This setting changes the member recreation logic based on group:
- For Sync Masters, Sync Workers, Coordinator and DB-Servers it determines if a member can be recreated in case of failure (default `true`)
- For Agents and Single this value is hardcoded to `false` and the value provided in spec is ignored.
***
### .spec.gateways.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L99)</sup>
Annotations specified the annotations added to Pods in this group.
Annotations are merged with `spec.annotations`.
***
### .spec.gateways.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L101)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.gateways.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L103)</sup>
AnnotationsMode Define annotations mode which should be use while overriding annotations
***
### .spec.gateways.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L152)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.gateways.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L57)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.gateways.count
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L49)</sup>
Count setting specifies the number of servers to start for the given group.
For the Agent group, this value must be a positive, odd number.
The default value is `3` for all groups except `single` (there the default is `1`
for `spec.mode: Single` and `2` for `spec.mode: ActiveFailover`).
For the `syncworkers` group, it is highly recommended to use the same number
as for the `dbservers` group.
***
### .spec.gateways.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L59)</sup>
Entrypoint overrides container executable
***
### .spec.gateways.envs\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L26)</sup>
***
### .spec.gateways.envs\[int\].value
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L27)</sup>
***
### .spec.gateways.ephemeralVolumes.apps.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.gateways.ephemeralVolumes.temp.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.gateways.exporterPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L211)</sup>
ExporterPort define Port used by exporter
***
### .spec.gateways.extendedRotationCheck
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L181)</sup>
ExtendedRotationCheck extend checks for rotation
***
### .spec.gateways.externalPortEnabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L193)</sup>
ExternalPortEnabled if external port should be enabled. If is set to false, ports needs to be exposed via sidecar. Only for ArangoD members
***
### .spec.gateways.indexMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L204)</sup>
IndexMethod define group Indexing method
Possible Values:
* `"random"` (default) - Pick random ID for member. Enforced on the Community Operator.
* `"ordered"` - Use sequential number as Member ID, starting from 0. Enterprise Operator required.
***
### .spec.gateways.initContainers.containers
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L91)</sup>
Containers contains list of containers
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.gateways.initContainers.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L94)</sup>
Mode keep container replace mode
***
### .spec.gateways.internalPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L189)</sup>
InternalPort define port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.gateways.internalPortProtocol
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L191)</sup>
InternalPortProtocol define protocol of port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.gateways.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L105)</sup>
Labels specified the labels added to Pods in this group.
***
### .spec.gateways.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L107)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.gateways.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L109)</sup>
LabelsMode Define labels mode which should be use while overriding labels
***
### .spec.gateways.maxCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L53)</sup>
MaxCount specifies a maximum for the count of servers. If set, a specification is invalid if `count > maxCount`.
***
### .spec.gateways.memoryReservation
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L81)</sup>
MemoryReservation determines the system reservation of memory while calculating `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` value.
If this field is set, `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` is reduced by a specified value in percent.
Accepted Range <0, 50>. If the value is outside the accepted range, it is adjusted to the closest value.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `0`
***
### .spec.gateways.minCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L51)</sup>
MinCount specifies a minimum for the count of servers. If set, a specification is invalid if `count < minCount`.
***
### .spec.gateways.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L160)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.gateways.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L124)</sup>
NodeSelector setting specifies a set of labels to be used as `nodeSelector` for Pods of this node.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)
***
### .spec.gateways.numactl.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L38)</sup>
Args define list of the numactl process
Default Value: `[]`
***
### .spec.gateways.numactl.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L30)</sup>
Enabled define if numactl should be enabled
Default Value: `false`
***
### .spec.gateways.numactl.path
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L34)</sup>
Path define numactl path within the container
Default Value: `/usr/bin/numactl`
***
### .spec.gateways.overrideDetectedNumberOfCores
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L87)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` Container Environment Variable**
OverrideDetectedNumberOfCores determines if number of cores should be overridden based on values in resources.
If is set to true and Container CPU Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` to the value from the Container CPU Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.gateways.overrideDetectedTotalMemory
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L75)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` Container Environment Variable**
OverrideDetectedTotalMemory determines if memory should be overridden based on values in resources.
If is set to true and Container Memory Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` to the value from the Container Memory Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.gateways.podModes.network
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L31)</sup>
***
### .spec.gateways.podModes.pid
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L32)</sup>
***
### .spec.gateways.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L209)</sup>
Port define Port used by member
***
### .spec.gateways.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L130)</sup>
PriorityClassName specifies a priority class name
Will be forwarded to the pod spec.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/pod-priority-preemption/)
***
### .spec.gateways.probes.livenessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L27)</sup>
LivenessProbeDisabled if set to true, the operator does not generate a liveness probe for new pods belonging to this group
Default Value: `false`
***
### .spec.gateways.probes.livenessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.gateways.probes.livenessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.gateways.probes.livenessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.gateways.probes.livenessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.gateways.probes.livenessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.gateways.probes.ReadinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L34)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is deprecated, kept only for backward compatibility.**
OldReadinessProbeDisabled if true readinessProbes are disabled
***
### .spec.gateways.probes.readinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L36)</sup>
ReadinessProbeDisabled override flag for probe disabled in good manner (lowercase) with backward compatibility
***
### .spec.gateways.probes.readinessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.gateways.probes.readinessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.gateways.probes.readinessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.gateways.probes.readinessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.gateways.probes.readinessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.gateways.probes.startupProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L41)</sup>
StartupProbeDisabled if true startupProbes are disabled
***
### .spec.gateways.probes.startupProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.gateways.probes.startupProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.gateways.probes.startupProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.gateways.probes.startupProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.gateways.probes.startupProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.gateways.pvcResizeMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L144)</sup>
VolumeResizeMode specified resize mode for PVCs and PVs
Possible Values:
* `"runtime"` (default) - PVC will be resized in Pod runtime (EKS, GKE)
* `"rotate"` - Pod will be shutdown and PVC will be resized (AKS)
***
### .spec.gateways.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L69)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.gateways.schedulerName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L61)</sup>
SchedulerName define scheduler name used for group
***
### .spec.gateways.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.gateways.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.gateways.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.gateways.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.gateways.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.gateways.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.gateways.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.gateways.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.gateways.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.gateways.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.gateways.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.gateways.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.gateways.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.gateways.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L120)</sup>
ServiceAccountName setting specifies the `serviceAccountName` for the `Pods` created
for each server of this group. If empty, it defaults to using the
`default` service account.
Using an alternative `ServiceAccount` is typically used to separate access rights.
The ArangoDB deployments need some very minimal access rights. With the
deployment of the operator, we grant the rights to 'get' all 'pod' resources.
If you are using a different service account, please grant these rights
to that service account.
***
### .spec.gateways.shutdownDelay
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L187)</sup>
ShutdownDelay define how long operator should delay finalizer removal after shutdown
***
### .spec.gateways.shutdownMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L185)</sup>
ShutdownMethod describe procedure of member shutdown taken by Operator
***
### .spec.gateways.sidecarCoreNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L163)</sup>
SidecarCoreNames is a list of sidecar containers which must run in the pod.
Some names (e.g.: "server", "worker") are reserved, and they don't have any impact.
***
### .spec.gateways.sidecars
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L167)</sup>
Sidecars specifies a list of additional containers to be started
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.gateways.storageClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L65)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Use VolumeClaimTemplate instead.**
StorageClassName specifies the classname for storage of the servers.
***
### .spec.gateways.terminationGracePeriodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L200)</sup>
TerminationGracePeriodSeconds override default TerminationGracePeriodSeconds for pods - via silent rotation
***
### .spec.gateways.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L96)</sup>
Tolerations specifies the tolerations added to Pods in this group.
By default, suitable tolerations are set for the following keys with the `NoExecute` effect:
- `node.kubernetes.io/not-ready`
- `node.kubernetes.io/unreachable`
- `node.alpha.kubernetes.io/unreachable` (will be removed in future version)
For more information on tolerations, consult the https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.gateways.volumeAllowShrink
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L148)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
VolumeAllowShrink allows shrinking of the volume
***
### .spec.gateways.volumeClaimTemplate
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaim` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L139)</sup>
VolumeClaimTemplate specifies a volumeClaimTemplate used by operator to create to volume claims for pods of this group.
This setting is not available for group `coordinators`, `syncmasters` & `syncworkers`.
The default value describes a volume with `8Gi` storage, `ReadWriteOnce` access mode and volume mode set to `PersistentVolumeFilesystem`.
If this field is not set and `spec.<group>.resources.requests.storage` is set, then a default volume claim
with size as specified by `spec.<group>.resources.requests.storage` will be created. In that case `storage`
and `iops` is not forwarded to the pods resource requirements.
Links:
* [Documentation of core.PersistentVolumeClaim](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaim-v1-core)
***
### .spec.gateways.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]ServerGroupSpecVolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L177)</sup>
VolumeMounts define list of volume mounts mounted into server container
Links:
* [Documentation of ServerGroupSpecVolumeMount](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#volumemount-v1-core)
***
### .spec.gateways.volumes\[int\].configMap
2024-10-14 14:35:16 +00:00
Type: `core.ConfigMapVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L138)</sup>
ConfigMap which should be mounted into pod
Links:
* [Documentation of core.ConfigMapVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapvolumesource-v1-core)
***
### .spec.gateways.volumes\[int\].emptyDir
2024-10-14 14:35:16 +00:00
Type: `core.EmptyDirVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L143)</sup>
EmptyDir
Links:
* [Documentation of core.EmptyDirVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#emptydirvolumesource-v1-core)
***
### .spec.gateways.volumes\[int\].hostPath
2024-10-14 14:35:16 +00:00
Type: `core.HostPathVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L148)</sup>
HostPath
Links:
* [Documentation of core.HostPathVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#hostpathvolumesource-v1-core)
***
### .spec.gateways.volumes\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L128)</sup>
Name of volume
***
### .spec.gateways.volumes\[int\].persistentVolumeClaim
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaimVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L153)</sup>
PersistentVolumeClaim
Links:
* [Documentation of core.PersistentVolumeClaimVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaimvolumesource-v1-core)
***
### .spec.gateways.volumes\[int\].secret
2024-10-14 14:35:16 +00:00
Type: `core.SecretVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L133)</sup>
Secret which should be mounted into pod
Links:
* [Documentation of core.SecretVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretvolumesource-v1-core)
***
### .spec.id.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L48)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.id.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L44)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.id.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L32)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.id.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L28)</sup>
Entrypoint overrides container executable
***
### .spec.id.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L52)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.id.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L38)</sup>
NodeSelector specifies a set of selectors for nodes
***
### .spec.id.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L40)</sup>
PriorityClassName specifies a priority class name
***
### .spec.id.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L60)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.id.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.id.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.id.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.id.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.id.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.id.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.id.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.id.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.id.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.id.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.id.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.id.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.id.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.id.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L54)</sup>
ServiceAccountName specifies the name of the service account used for Pods in this group.
***
### .spec.id.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_id_group_spec.go#L36)</sup>
Tolerations specifies the tolerations added to Pods in this group.
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.image
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L67)</sup>
Image specifies the docker image to use for all ArangoDB servers.
In a development environment this setting defaults to arangodb/arangodb:latest.
For production environments this is a required setting without a default value.
It is highly recommend to use explicit version (not latest) for production environments.
***
### .spec.imageDiscoveryMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L83)</sup>
2023-07-24 14:53:50 +00:00
ImageDiscoveryMode specifies the image discovery mode.
Possible Values:
* `"kubelet"` (default) - Use sha256 of the discovered image in the pods
* `"direct"` - Use image provided in the spec.image directly in the pods
2023-07-24 14:53:50 +00:00
***
### .spec.imagePullPolicy
2024-10-14 14:35:16 +00:00
Type: `core.PullPolicy` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L75)</sup>
ImagePullPolicy specifies the pull policy for the docker image to use for all ArangoDB servers.
Links:
* [Documentation of core.PullPolicy](https://kubernetes.io/docs/concepts/containers/images/#image-pull-policy)
Possible Values:
* `"Always"` (default) - Means that kubelet always attempts to pull the latest image. Container will fail If the pull fails.
* `"Never"` - Means that kubelet never pulls an image, but only uses a local image. Container will fail if the image isn't present
* `"IfNotPresent"` - Means that kubelet pulls if the image isn't present on disk. Container will fail if the image isn't present and the pull fails.
***
### .spec.imagePullSecrets
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L78)</sup>
ImagePullSecrets specifies the list of image pull secrets for the docker image to use for all ArangoDB servers.
***
### .spec.integration.sidecar.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/core.go#L54)</sup>
Arguments to the entrypoint.
The container image's CMD is used if this is not provided.
Variable references $(VAR_NAME) are expanded using the container's environment. If a variable
cannot be resolved, the reference in the input string will be unchanged. Double $$ are reduced
to a single $, which allows for escaping the $(VAR_NAME) syntax: i.e. "$$(VAR_NAME)" will
produce the string literal "$(VAR_NAME)". Escaped references will never be expanded, regardless
of whether the variable exists or not. Cannot be updated.
Links:
* [Kubernetes Docs](https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell)
***
### .spec.integration.sidecar.command
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/core.go#L44)</sup>
Entrypoint array. Not executed within a shell.
The container image's ENTRYPOINT is used if this is not provided.
Variable references $(VAR_NAME) are expanded using the container's environment. If a variable
cannot be resolved, the reference in the input string will be unchanged. Double $$ are reduced
to a single $, which allows for escaping the $(VAR_NAME) syntax: i.e. "$$(VAR_NAME)" will
produce the string literal "$(VAR_NAME)". Escaped references will never be expanded, regardless
of whether the variable exists or not. Cannot be updated.
Links:
* [Kubernetes Docs](https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell)
***
### .spec.integration.sidecar.controllerListenPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/integration/integration.go#L36)</sup>
ControllerListenPort defines on which port the sidecar container will be listening for controller requests
Default Value: `9202`
***
### .spec.integration.sidecar.env
2024-10-14 14:35:16 +00:00
Type: `core.EnvVar` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/environments.go#L36)</sup>
Env keeps the information about environment variables provided to the container
Links:
* [Kubernetes Docs](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#envvar-v1-core)
***
### .spec.integration.sidecar.envFrom
2024-10-14 14:35:16 +00:00
Type: `core.EnvFromSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/environments.go#L41)</sup>
EnvFrom keeps the information about environment variable sources provided to the container
Links:
* [Kubernetes Docs](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#envfromsource-v1-core)
***
### .spec.integration.sidecar.image
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/image.go#L35)</sup>
Image define image details
***
### .spec.integration.sidecar.imagePullPolicy
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/image.go#L39)</sup>
ImagePullPolicy define Image pull policy
Default Value: `IfNotPresent`
***
### .spec.integration.sidecar.lifecycle
2024-10-14 14:35:16 +00:00
Type: `core.Lifecycle` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/lifecycle.go#L35)</sup>
Lifecycle keeps actions that the management system should take in response to container lifecycle events.
***
### .spec.integration.sidecar.listenPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/integration/integration.go#L32)</sup>
ListenPort defines on which port the sidecar container will be listening for connections
Default Value: `9201`
***
### .spec.integration.sidecar.livenessProbe
2024-10-14 14:35:16 +00:00
Type: `core.Probe` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/probes.go#L37)</sup>
LivenessProbe keeps configuration of periodic probe of container liveness.
Container will be restarted if the probe fails.
Links:
* [Kubernetes docs](https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes)
***
### .spec.integration.sidecar.method
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/policy/merge.go#L32)</sup>
Method defines the merge method
Possible Values:
* `"override"` (default) - Overrides values during configuration merge
* `"append"` - Appends, if possible, values during configuration merge
***
### .spec.integration.sidecar.ports
2024-10-14 14:35:16 +00:00
Type: `[]core.ContainerPort` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/networking.go#L39)</sup>
Ports contains list of ports to expose from the container. Not specifying a port here
DOES NOT prevent that port from being exposed. Any port which is
listening on the default "0.0.0.0" address inside a container will be
accessible from the network.
***
### .spec.integration.sidecar.readinessProbe
2024-10-14 14:35:16 +00:00
Type: `core.Probe` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/probes.go#L42)</sup>
ReadinessProbe keeps configuration of periodic probe of container service readiness.
Container will be removed from service endpoints if the probe fails.
Links:
* [Kubernetes docs](https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes)
***
### .spec.integration.sidecar.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/resources.go#L37)</sup>
Resources holds resource requests & limits for container
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.integration.sidecar.securityContext
2024-10-14 14:35:16 +00:00
Type: `core.SecurityContext` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/security.go#L35)</sup>
SecurityContext holds container-level security attributes and common container settings.
Links:
* [Kubernetes docs](https://kubernetes.io/docs/tasks/configure-pod-container/security-context/)
***
### .spec.integration.sidecar.startupProbe
2024-10-14 14:35:16 +00:00
Type: `core.Probe` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/probes.go#L50)</sup>
StartupProbe indicates that the Pod has successfully initialized.
If specified, no other probes are executed until this completes successfully.
If this probe fails, the Pod will be restarted, just as if the livenessProbe failed.
This can be used to provide different probe parameters at the beginning of a Pod's lifecycle,
when it might take a long time to load data or warm a cache, than during steady-state operation.
Links:
* [Kubernetes docs](https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes)
***
### .spec.integration.sidecar.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]core.VolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/volume_mounts.go#L35)</sup>
VolumeMounts keeps list of pod volumes to mount into the container's filesystem.
***
### .spec.integration.sidecar.workingDir
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/scheduler/v1beta1/container/resources/core.go#L59)</sup>
Container's working directory.
If not specified, the container runtime's default will be used, which
might be configured in the container image.
***
### .spec.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L127)</sup>
Labels specifies the labels added to Pods in this group.
***
### .spec.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L130)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L136)</sup>
LabelsMode Define labels mode which should be use while overriding labels
Possible Values:
* `"disabled"` (default) - Disable annotations/labels override. Default if there is no annotations/labels set in ArangoDeployment
* `"append"` - Add new annotations/labels without affecting old ones
* `"replace"` - Replace existing annotations/labels
***
### .spec.license.secretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/license_spec.go#L33)</sup>
SecretName setting specifies the name of a kubernetes `Secret` that contains
the license key token used for enterprise images. This value is not used for
the Community Edition.
***
### .spec.lifecycle.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/lifecycle_spec.go#L31)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.memberPropagationMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L212)</sup>
MemberPropagationMode defines how changes to pod spec should be propogated.
Changes to a pods configuration require a restart of that pod in almost all cases.
Pods are restarted eagerly by default, which can cause more restarts than desired, especially when updating arangod as well as the operator.
The propagation of the configuration changes can be deferred to the next restart, either triggered manually by the user or by another operation like an upgrade.
This reduces the number of restarts for upgrading both the server and the operator from two to one.
Possible Values:
* `"always"` (default) - Restart the member as soon as a configuration change is discovered
* `"on-restart"` - Wait until the next restart to change the member configuration
***
### .spec.metrics.authentication.jwtTokenSecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec.go#L34)</sup>
JWTTokenSecretName contains the name of the JWT kubernetes secret used for authentication
***
### .spec.metrics.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec.go#L81)</sup>
Enabled if this is set to `true`, the operator runs a sidecar container for
every Agent, DB-Server, Coordinator and Single server.
Links:
* [Metrics collection](../metrics.md)
Default Value: `false`
***
### .spec.metrics.extensions.usageMetrics
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec_extensions.go#L29)</sup>
> [!IMPORTANT]
> **UsageMetrics needs to be also enabled via DBServer Arguments**
UsageMetrics enables ArangoDB Usage metrics scrape. Affects only DBServers in the Cluster mode.
Links:
* [Documentation](https://docs.arangodb.com/devel/develop/http-api/monitoring/metrics/#get-usage-metrics)
Default Value: `false`
***
### .spec.metrics.image
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec.go#L86)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Image is now extracted from Operator Pod**
Image used for the Metrics Sidecar
***
### .spec.metrics.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec.go#L97)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
Mode define metrics exported mode
***
### .spec.metrics.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec.go#L107)</sup>
***
### .spec.metrics.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec.go#L92)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.metrics.serviceMonitor.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_service_monitor_spec.go#L24)</sup>
***
### .spec.metrics.serviceMonitor.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_service_monitor_spec.go#L25)</sup>
***
### .spec.metrics.tls
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_metrics_spec.go#L103)</sup>
TLS defines if TLS should be enabled on Metrics exporter endpoint.
This option will enable TLS only if TLS is enabled on ArangoDeployment,
otherwise `true` value will not take any effect.
Default Value: `true`
***
### .spec.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L49)</sup>
2023-07-24 16:52:51 +00:00
Mode specifies the type of ArangoDB deployment to create.
Possible Values:
* `"Cluster"` (default) - Full cluster. Defaults to 3 Agents, 3 DB-Servers & 3 Coordinators.
* `"ActiveFailover"` - Active-failover single pair. Defaults to 3 Agents and 2 single servers.
* `"Single"` - Single server only (note this does not provide high availability or reliability).
2023-07-24 16:52:51 +00:00
This field is **immutable**: Change of the ArangoDeployment Mode is not possible after creation.
***
### .spec.networkAttachedVolumes
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L112)</sup>
NetworkAttachedVolumes
If set to `true`, a ResignLeadership operation will be triggered when a DB-Server pod is evicted (rather than a CleanOutServer operation).
Furthermore, the pod will simply be redeployed on a different node, rather than cleaned and retired and replaced by a new member.
You must only set this option to true if your persistent volumes are “movable” in the sense that they can be mounted from a different k8s node, like in the case of network attached volumes.
If your persistent volumes are tied to a specific pod, you must leave this option on false.
Default Value: `true`
***
### .spec.rebalancer.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/rebalancer_spec.go#L26)</sup>
***
### .spec.rebalancer.optimizers.leader
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/rebalancer_spec.go#L75)</sup>
***
### .spec.rebalancer.parallelMoves
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/rebalancer_spec.go#L28)</sup>
***
### .spec.rebalancer.readers.count
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/rebalancer_spec.go#L63)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **does not work in Rebalancer V2**
Count Enable Shard Count machanism
***
### .spec.recovery.autoRecover
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/recovery_spec.go#L26)</sup>
***
### .spec.restoreEncryptionSecret
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L149)</sup>
RestoreEncryptionSecret specifies optional name of secret which contains encryption key used for restore
***
### .spec.restoreFrom
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L146)</sup>
RestoreFrom setting specifies a `ArangoBackup` resource name the cluster should be restored from.
After a restore or failure to do so, the status of the deployment contains information about the restore operation in the restore key.
It will contain some of the following fields:
- `requestedFrom`: name of the ArangoBackup used to restore from.
- `message`: optional message explaining why the restore failed.
- `state`: state indicating if the restore was successful or not. Possible values: Restoring, Restored, RestoreFailed
If the restoreFrom key is removed from the spec, the restore key is deleted as well.
A new restore attempt is made if and only if either in the status restore is not set or if spec.restoreFrom and status.requestedFrom are different.
***
### .spec.rocksdb.encryption.keySecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/rocksdb_spec.go#L37)</sup>
KeySecretName setting specifies the name of a Kubernetes `Secret` that contains an encryption key used for encrypting all data stored by ArangoDB servers.
When an encryption key is used, encryption of the data in the cluster is enabled, without it encryption is disabled.
The default value is empty.
This requires the Enterprise Edition.
The encryption key cannot be changed after the cluster has been created.
The secret specified by this setting, must have a data field named 'key' containing an encryption key that is exactly 32 bytes long.
***
### .spec.single.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L156)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.single.allowMemberRecreation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L198)</sup>
AllowMemberRecreation allows to recreate member.
This setting changes the member recreation logic based on group:
- For Sync Masters, Sync Workers, Coordinator and DB-Servers it determines if a member can be recreated in case of failure (default `true`)
- For Agents and Single this value is hardcoded to `false` and the value provided in spec is ignored.
***
### .spec.single.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L99)</sup>
Annotations specified the annotations added to Pods in this group.
Annotations are merged with `spec.annotations`.
***
### .spec.single.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L101)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.single.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L103)</sup>
AnnotationsMode Define annotations mode which should be use while overriding annotations
***
### .spec.single.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L152)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.single.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L57)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.single.count
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L49)</sup>
Count setting specifies the number of servers to start for the given group.
For the Agent group, this value must be a positive, odd number.
The default value is `3` for all groups except `single` (there the default is `1`
for `spec.mode: Single` and `2` for `spec.mode: ActiveFailover`).
For the `syncworkers` group, it is highly recommended to use the same number
as for the `dbservers` group.
***
### .spec.single.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L59)</sup>
Entrypoint overrides container executable
***
### .spec.single.envs\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L26)</sup>
***
### .spec.single.envs\[int\].value
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L27)</sup>
***
### .spec.single.ephemeralVolumes.apps.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.single.ephemeralVolumes.temp.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.single.exporterPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L211)</sup>
ExporterPort define Port used by exporter
***
### .spec.single.extendedRotationCheck
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L181)</sup>
ExtendedRotationCheck extend checks for rotation
***
### .spec.single.externalPortEnabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L193)</sup>
ExternalPortEnabled if external port should be enabled. If is set to false, ports needs to be exposed via sidecar. Only for ArangoD members
***
### .spec.single.indexMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L204)</sup>
IndexMethod define group Indexing method
2023-10-12 14:37:40 +00:00
Possible Values:
* `"random"` (default) - Pick random ID for member. Enforced on the Community Operator.
* `"ordered"` - Use sequential number as Member ID, starting from 0. Enterprise Operator required.
2023-10-12 14:37:40 +00:00
***
### .spec.single.initContainers.containers
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L91)</sup>
Containers contains list of containers
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.single.initContainers.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L94)</sup>
Mode keep container replace mode
***
### .spec.single.internalPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L189)</sup>
InternalPort define port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.single.internalPortProtocol
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L191)</sup>
InternalPortProtocol define protocol of port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.single.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L105)</sup>
Labels specified the labels added to Pods in this group.
***
### .spec.single.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L107)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.single.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L109)</sup>
LabelsMode Define labels mode which should be use while overriding labels
***
### .spec.single.maxCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L53)</sup>
MaxCount specifies a maximum for the count of servers. If set, a specification is invalid if `count > maxCount`.
***
### .spec.single.memoryReservation
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L81)</sup>
MemoryReservation determines the system reservation of memory while calculating `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` value.
If this field is set, `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` is reduced by a specified value in percent.
Accepted Range <0, 50>. If the value is outside the accepted range, it is adjusted to the closest value.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `0`
***
### .spec.single.minCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L51)</sup>
MinCount specifies a minimum for the count of servers. If set, a specification is invalid if `count < minCount`.
***
### .spec.single.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L160)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.single.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L124)</sup>
NodeSelector setting specifies a set of labels to be used as `nodeSelector` for Pods of this node.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)
***
### .spec.single.numactl.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L38)</sup>
2023-07-28 08:00:57 +00:00
Args define list of the numactl process
Default Value: `[]`
2023-07-28 08:00:57 +00:00
***
### .spec.single.numactl.enabled
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L30)</sup>
2023-07-28 08:00:57 +00:00
Enabled define if numactl should be enabled
Default Value: `false`
2023-07-28 08:00:57 +00:00
***
### .spec.single.numactl.path
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L34)</sup>
2023-07-28 08:00:57 +00:00
Path define numactl path within the container
Default Value: `/usr/bin/numactl`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.single.overrideDetectedNumberOfCores
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L87)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` Container Environment Variable**
OverrideDetectedNumberOfCores determines if number of cores should be overridden based on values in resources.
If is set to true and Container CPU Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` to the value from the Container CPU Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.single.overrideDetectedTotalMemory
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L75)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` Container Environment Variable**
OverrideDetectedTotalMemory determines if memory should be overridden based on values in resources.
If is set to true and Container Memory Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` to the value from the Container Memory Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.single.podModes.network
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L31)</sup>
***
### .spec.single.podModes.pid
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L32)</sup>
***
### .spec.single.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L209)</sup>
Port define Port used by member
***
### .spec.single.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L130)</sup>
PriorityClassName specifies a priority class name
Will be forwarded to the pod spec.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/pod-priority-preemption/)
***
### .spec.single.probes.livenessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L27)</sup>
LivenessProbeDisabled if set to true, the operator does not generate a liveness probe for new pods belonging to this group
Default Value: `false`
***
### .spec.single.probes.livenessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.single.probes.livenessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.single.probes.livenessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.single.probes.livenessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.single.probes.livenessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.single.probes.ReadinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L34)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is deprecated, kept only for backward compatibility.**
OldReadinessProbeDisabled if true readinessProbes are disabled
***
### .spec.single.probes.readinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L36)</sup>
ReadinessProbeDisabled override flag for probe disabled in good manner (lowercase) with backward compatibility
***
### .spec.single.probes.readinessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.single.probes.readinessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.single.probes.readinessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.single.probes.readinessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.single.probes.readinessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.single.probes.startupProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L41)</sup>
StartupProbeDisabled if true startupProbes are disabled
***
### .spec.single.probes.startupProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.single.probes.startupProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.single.probes.startupProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.single.probes.startupProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.single.probes.startupProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.single.pvcResizeMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L144)</sup>
VolumeResizeMode specified resize mode for PVCs and PVs
Possible Values:
* `"runtime"` (default) - PVC will be resized in Pod runtime (EKS, GKE)
* `"rotate"` - Pod will be shutdown and PVC will be resized (AKS)
***
### .spec.single.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L69)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.single.schedulerName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L61)</sup>
SchedulerName define scheduler name used for group
***
### .spec.single.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.single.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.single.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.single.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.single.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.single.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.single.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.single.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.single.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.single.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.single.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.single.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.single.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.single.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L120)</sup>
ServiceAccountName setting specifies the `serviceAccountName` for the `Pods` created
for each server of this group. If empty, it defaults to using the
`default` service account.
Using an alternative `ServiceAccount` is typically used to separate access rights.
The ArangoDB deployments need some very minimal access rights. With the
deployment of the operator, we grant the rights to 'get' all 'pod' resources.
If you are using a different service account, please grant these rights
to that service account.
***
### .spec.single.shutdownDelay
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L187)</sup>
ShutdownDelay define how long operator should delay finalizer removal after shutdown
***
### .spec.single.shutdownMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L185)</sup>
ShutdownMethod describe procedure of member shutdown taken by Operator
***
### .spec.single.sidecarCoreNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L163)</sup>
SidecarCoreNames is a list of sidecar containers which must run in the pod.
Some names (e.g.: "server", "worker") are reserved, and they don't have any impact.
***
### .spec.single.sidecars
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L167)</sup>
Sidecars specifies a list of additional containers to be started
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.single.storageClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L65)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Use VolumeClaimTemplate instead.**
StorageClassName specifies the classname for storage of the servers.
***
### .spec.single.terminationGracePeriodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L200)</sup>
TerminationGracePeriodSeconds override default TerminationGracePeriodSeconds for pods - via silent rotation
***
### .spec.single.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L96)</sup>
Tolerations specifies the tolerations added to Pods in this group.
By default, suitable tolerations are set for the following keys with the `NoExecute` effect:
- `node.kubernetes.io/not-ready`
- `node.kubernetes.io/unreachable`
- `node.alpha.kubernetes.io/unreachable` (will be removed in future version)
For more information on tolerations, consult the https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.single.volumeAllowShrink
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L148)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
VolumeAllowShrink allows shrinking of the volume
***
### .spec.single.volumeClaimTemplate
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaim` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L139)</sup>
VolumeClaimTemplate specifies a volumeClaimTemplate used by operator to create to volume claims for pods of this group.
This setting is not available for group `coordinators`, `syncmasters` & `syncworkers`.
The default value describes a volume with `8Gi` storage, `ReadWriteOnce` access mode and volume mode set to `PersistentVolumeFilesystem`.
If this field is not set and `spec.<group>.resources.requests.storage` is set, then a default volume claim
with size as specified by `spec.<group>.resources.requests.storage` will be created. In that case `storage`
and `iops` is not forwarded to the pods resource requirements.
Links:
* [Documentation of core.PersistentVolumeClaim](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaim-v1-core)
***
### .spec.single.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]ServerGroupSpecVolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L177)</sup>
VolumeMounts define list of volume mounts mounted into server container
Links:
* [Documentation of ServerGroupSpecVolumeMount](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#volumemount-v1-core)
***
### .spec.single.volumes\[int\].configMap
2024-10-14 14:35:16 +00:00
Type: `core.ConfigMapVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L138)</sup>
ConfigMap which should be mounted into pod
Links:
* [Documentation of core.ConfigMapVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapvolumesource-v1-core)
***
### .spec.single.volumes\[int\].emptyDir
2024-10-14 14:35:16 +00:00
Type: `core.EmptyDirVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L143)</sup>
EmptyDir
Links:
* [Documentation of core.EmptyDirVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#emptydirvolumesource-v1-core)
***
### .spec.single.volumes\[int\].hostPath
2024-10-14 14:35:16 +00:00
Type: `core.HostPathVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L148)</sup>
HostPath
Links:
* [Documentation of core.HostPathVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#hostpathvolumesource-v1-core)
***
### .spec.single.volumes\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L128)</sup>
Name of volume
***
### .spec.single.volumes\[int\].persistentVolumeClaim
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaimVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L153)</sup>
PersistentVolumeClaim
Links:
* [Documentation of core.PersistentVolumeClaimVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaimvolumesource-v1-core)
***
### .spec.single.volumes\[int\].secret
2024-10-14 14:35:16 +00:00
Type: `core.SecretVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L133)</sup>
Secret which should be mounted into pod
Links:
* [Documentation of core.SecretVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretvolumesource-v1-core)
***
### .spec.storageEngine
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L61)</sup>
StorageEngine specifies the type of storage engine used for all servers in the cluster.
Possible Values:
* `"RocksDB"` (default) - To use the RocksDB storage engine.
* `"MMFiles"` - To use the MMFiles storage engine. Deprecated.
This field is **immutable**: This setting cannot be changed after the cluster has been created.
***
### .spec.sync.auth.clientCASecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/sync_authentication_spec.go#L41)</sup>
ClientCASecretName setting specifies the name of a kubernetes `Secret` that contains
a PEM encoded CA certificate used for client certificate verification
in all ArangoSync master servers.
This is a required setting when `spec.sync.enabled` is `true`.
***
### .spec.sync.auth.jwtSecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/sync_authentication_spec.go#L36)</sup>
JWTSecretName setting specifies the name of a kubernetes `Secret` that contains
the JWT token used for accessing all ArangoSync master servers.
When not specified, the `spec.auth.jwtSecretName` value is used.
If you specify a name of a `Secret` that does not exist, a random token is created
and stored in a `Secret` with given name.
***
### .spec.sync.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/sync_spec.go#L34)</sup>
Enabled setting enables/disables support for data center 2 data center
replication in the cluster. When enabled, the cluster will contain
a number of `syncmaster` & `syncworker` servers.
Default Value: `false`
***
### .spec.sync.externalAccess.accessPackageSecretNames
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/sync_external_access_spec.go#L49)</sup>
AccessPackageSecretNames setting specifies the names of zero of more `Secrets` that will be created by the deployment
operator containing "access packages". An access package contains those `Secrets` that are needed
to access the SyncMasters of this `ArangoDeployment`.
By removing a name from this setting, the corresponding `Secret` is also deleted.
Note that to remove all access packages, leave an empty array in place (`[]`).
Completely removing the setting results in not modifying the list.
Links:
* [See the ArangoDeploymentReplication specification](deployment-replication-resource-reference.md)
***
### .spec.sync.externalAccess.advertisedEndpoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L58)</sup>
AdvertisedEndpoint is passed to the coordinators/single servers for advertising a specific endpoint
***
### .spec.sync.externalAccess.loadBalancerIP
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L48)</sup>
LoadBalancerIP define optional IP used to configure a load-balancer on, in case of Auto or LoadBalancer type.
If you do not specify this setting, an IP will be chosen automatically by the load-balancer provisioner.
***
### .spec.sync.externalAccess.loadBalancerSourceRanges
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L55)</sup>
LoadBalancerSourceRanges define LoadBalancerSourceRanges used for LoadBalancer Service type
If specified and supported by the platform, this will restrict traffic through the cloud-provider
load-balancer will be restricted to the specified client IPs. This field will be ignored if the
cloud-provider does not support the feature.
Links:
* [Cloud Provider Firewall](https://kubernetes.io/docs/tasks/access-application-cluster/configure-cloud-provider-firewall/)
***
### .spec.sync.externalAccess.managedServiceNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L62)</sup>
ManagedServiceNames keeps names of services which are not managed by KubeArangoDB.
It is only relevant when type of service is `managed`.
***
### .spec.sync.externalAccess.masterEndpoint
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/sync_external_access_spec.go#L40)</sup>
MasterEndpoint setting specifies the master endpoint(s) advertised by the ArangoSync SyncMasters.
If not set, this setting defaults to:
- If `spec.sync.externalAccess.loadBalancerIP` is set, it defaults to `https://<load-balancer-ip>:<8629>`.
- Otherwise it defaults to `https://<sync-service-dns-name>:<8629>`.
***
### .spec.sync.externalAccess.nodePort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L44)</sup>
NodePort define optional port used in case of Auto or NodePort type.
This setting is used when `spec.externalAccess.type` is set to `NodePort` or `Auto`.
If you do not specify this setting, a random port will be chosen automatically.
***
### .spec.sync.externalAccess.type
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/external_access_spec.go#L39)</sup>
Type specifies the type of Service that will be created to provide access to the ArangoDB deployment from outside the Kubernetes cluster.
Possible Values:
* `"Auto"` (default) - Create a Service of type LoadBalancer and fallback to a Service or type NodePort when the LoadBalancer is not assigned an IP address.
* `"None"` - limit access to application running inside the Kubernetes cluster.
* `"LoadBalancer"` - Create a Service of type LoadBalancer for the ArangoDB deployment.
* `"NodePort"` - Create a Service of type NodePort for the ArangoDB deployment.
***
### .spec.sync.image
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/sync_spec.go#L40)</sup>
***
### .spec.sync.monitoring.tokenSecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/sync_monitoring_spec.go#L34)</sup>
TokenSecretName setting specifies the name of a kubernetes `Secret` that contains
the bearer token used for accessing all monitoring endpoints of all arangod/arangosync servers.
When not specified, no monitoring token is used.
***
### .spec.sync.tls.altNames
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L72)</sup>
AltNames setting specifies a list of alternate names that will be added to all generated
certificates. These names can be DNS names or email addresses.
The default value is empty.
***
### .spec.sync.tls.caSecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L67)</sup>
CASecretName setting specifies the name of a kubernetes `Secret` that contains
a standard CA certificate + private key used to sign certificates for individual
ArangoDB servers.
When no name is specified, it defaults to `<deployment-name>-ca`.
To disable authentication, set this value to `None`.
If you specify a name of a `Secret` that does not exist, a self-signed CA certificate + key is created
and stored in a `Secret` with given name.
The specified `Secret`, must contain the following data fields:
- `ca.crt` PEM encoded public key of the CA certificate
- `ca.key` PEM encoded private key of the CA certificate
***
### .spec.sync.tls.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L81)</sup>
***
### .spec.sync.tls.sni.mapping.\<string\>
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_sni_spec.go#L30)</sup>
***
### .spec.sync.tls.ttl
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L79)</sup>
TTL setting specifies the time to live of all generated server certificates.
When the server certificate is about to expire, it will be automatically replaced
by a new one and the affected server will be restarted.
Note: The time to live of the CA certificate (when created automatically)
will be set to 10 years.
Default Value: `"2160h" (about 3 months)`
***
### .spec.syncmasters.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L156)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.syncmasters.allowMemberRecreation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L198)</sup>
AllowMemberRecreation allows to recreate member.
This setting changes the member recreation logic based on group:
- For Sync Masters, Sync Workers, Coordinator and DB-Servers it determines if a member can be recreated in case of failure (default `true`)
- For Agents and Single this value is hardcoded to `false` and the value provided in spec is ignored.
***
### .spec.syncmasters.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L99)</sup>
Annotations specified the annotations added to Pods in this group.
Annotations are merged with `spec.annotations`.
***
### .spec.syncmasters.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L101)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.syncmasters.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L103)</sup>
AnnotationsMode Define annotations mode which should be use while overriding annotations
***
### .spec.syncmasters.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L152)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.syncmasters.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L57)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.syncmasters.count
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L49)</sup>
Count setting specifies the number of servers to start for the given group.
For the Agent group, this value must be a positive, odd number.
The default value is `3` for all groups except `single` (there the default is `1`
for `spec.mode: Single` and `2` for `spec.mode: ActiveFailover`).
For the `syncworkers` group, it is highly recommended to use the same number
as for the `dbservers` group.
***
### .spec.syncmasters.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L59)</sup>
Entrypoint overrides container executable
***
### .spec.syncmasters.envs\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L26)</sup>
***
### .spec.syncmasters.envs\[int\].value
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L27)</sup>
***
### .spec.syncmasters.ephemeralVolumes.apps.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.syncmasters.ephemeralVolumes.temp.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.syncmasters.exporterPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L211)</sup>
ExporterPort define Port used by exporter
***
### .spec.syncmasters.extendedRotationCheck
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L181)</sup>
ExtendedRotationCheck extend checks for rotation
***
### .spec.syncmasters.externalPortEnabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L193)</sup>
ExternalPortEnabled if external port should be enabled. If is set to false, ports needs to be exposed via sidecar. Only for ArangoD members
***
### .spec.syncmasters.indexMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L204)</sup>
IndexMethod define group Indexing method
2023-10-12 14:37:40 +00:00
Possible Values:
* `"random"` (default) - Pick random ID for member. Enforced on the Community Operator.
* `"ordered"` - Use sequential number as Member ID, starting from 0. Enterprise Operator required.
2023-10-12 14:37:40 +00:00
***
### .spec.syncmasters.initContainers.containers
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L91)</sup>
Containers contains list of containers
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.syncmasters.initContainers.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L94)</sup>
Mode keep container replace mode
***
### .spec.syncmasters.internalPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L189)</sup>
InternalPort define port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.syncmasters.internalPortProtocol
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L191)</sup>
InternalPortProtocol define protocol of port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.syncmasters.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L105)</sup>
Labels specified the labels added to Pods in this group.
***
### .spec.syncmasters.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L107)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.syncmasters.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L109)</sup>
LabelsMode Define labels mode which should be use while overriding labels
***
### .spec.syncmasters.maxCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L53)</sup>
MaxCount specifies a maximum for the count of servers. If set, a specification is invalid if `count > maxCount`.
***
### .spec.syncmasters.memoryReservation
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L81)</sup>
MemoryReservation determines the system reservation of memory while calculating `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` value.
If this field is set, `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` is reduced by a specified value in percent.
Accepted Range <0, 50>. If the value is outside the accepted range, it is adjusted to the closest value.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `0`
***
### .spec.syncmasters.minCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L51)</sup>
MinCount specifies a minimum for the count of servers. If set, a specification is invalid if `count < minCount`.
***
### .spec.syncmasters.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L160)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.syncmasters.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L124)</sup>
NodeSelector setting specifies a set of labels to be used as `nodeSelector` for Pods of this node.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)
***
### .spec.syncmasters.numactl.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L38)</sup>
2023-07-28 08:00:57 +00:00
Args define list of the numactl process
Default Value: `[]`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.syncmasters.numactl.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L30)</sup>
2023-07-28 08:00:57 +00:00
Enabled define if numactl should be enabled
Default Value: `false`
2023-07-28 08:00:57 +00:00
***
### .spec.syncmasters.numactl.path
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L34)</sup>
2023-07-28 08:00:57 +00:00
Path define numactl path within the container
Default Value: `/usr/bin/numactl`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.syncmasters.overrideDetectedNumberOfCores
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L87)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` Container Environment Variable**
OverrideDetectedNumberOfCores determines if number of cores should be overridden based on values in resources.
If is set to true and Container CPU Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` to the value from the Container CPU Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.syncmasters.overrideDetectedTotalMemory
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L75)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` Container Environment Variable**
OverrideDetectedTotalMemory determines if memory should be overridden based on values in resources.
If is set to true and Container Memory Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` to the value from the Container Memory Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.syncmasters.podModes.network
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L31)</sup>
***
### .spec.syncmasters.podModes.pid
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L32)</sup>
***
### .spec.syncmasters.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L209)</sup>
Port define Port used by member
***
### .spec.syncmasters.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L130)</sup>
PriorityClassName specifies a priority class name
Will be forwarded to the pod spec.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/pod-priority-preemption/)
***
### .spec.syncmasters.probes.livenessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L27)</sup>
LivenessProbeDisabled if set to true, the operator does not generate a liveness probe for new pods belonging to this group
Default Value: `false`
***
### .spec.syncmasters.probes.livenessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.syncmasters.probes.livenessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.syncmasters.probes.livenessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.syncmasters.probes.livenessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.syncmasters.probes.livenessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.syncmasters.probes.ReadinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L34)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is deprecated, kept only for backward compatibility.**
OldReadinessProbeDisabled if true readinessProbes are disabled
***
### .spec.syncmasters.probes.readinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L36)</sup>
ReadinessProbeDisabled override flag for probe disabled in good manner (lowercase) with backward compatibility
***
### .spec.syncmasters.probes.readinessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.syncmasters.probes.readinessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.syncmasters.probes.readinessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.syncmasters.probes.readinessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.syncmasters.probes.readinessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.syncmasters.probes.startupProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L41)</sup>
StartupProbeDisabled if true startupProbes are disabled
***
### .spec.syncmasters.probes.startupProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.syncmasters.probes.startupProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.syncmasters.probes.startupProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.syncmasters.probes.startupProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.syncmasters.probes.startupProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.syncmasters.pvcResizeMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L144)</sup>
VolumeResizeMode specified resize mode for PVCs and PVs
Possible Values:
* `"runtime"` (default) - PVC will be resized in Pod runtime (EKS, GKE)
* `"rotate"` - Pod will be shutdown and PVC will be resized (AKS)
***
### .spec.syncmasters.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L69)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.syncmasters.schedulerName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L61)</sup>
SchedulerName define scheduler name used for group
***
### .spec.syncmasters.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.syncmasters.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.syncmasters.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.syncmasters.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.syncmasters.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.syncmasters.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.syncmasters.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.syncmasters.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.syncmasters.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.syncmasters.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.syncmasters.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.syncmasters.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.syncmasters.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.syncmasters.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L120)</sup>
ServiceAccountName setting specifies the `serviceAccountName` for the `Pods` created
for each server of this group. If empty, it defaults to using the
`default` service account.
Using an alternative `ServiceAccount` is typically used to separate access rights.
The ArangoDB deployments need some very minimal access rights. With the
deployment of the operator, we grant the rights to 'get' all 'pod' resources.
If you are using a different service account, please grant these rights
to that service account.
***
### .spec.syncmasters.shutdownDelay
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L187)</sup>
ShutdownDelay define how long operator should delay finalizer removal after shutdown
***
### .spec.syncmasters.shutdownMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L185)</sup>
ShutdownMethod describe procedure of member shutdown taken by Operator
***
### .spec.syncmasters.sidecarCoreNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L163)</sup>
SidecarCoreNames is a list of sidecar containers which must run in the pod.
Some names (e.g.: "server", "worker") are reserved, and they don't have any impact.
***
### .spec.syncmasters.sidecars
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L167)</sup>
Sidecars specifies a list of additional containers to be started
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.syncmasters.storageClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L65)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Use VolumeClaimTemplate instead.**
StorageClassName specifies the classname for storage of the servers.
***
### .spec.syncmasters.terminationGracePeriodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L200)</sup>
TerminationGracePeriodSeconds override default TerminationGracePeriodSeconds for pods - via silent rotation
***
### .spec.syncmasters.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L96)</sup>
Tolerations specifies the tolerations added to Pods in this group.
By default, suitable tolerations are set for the following keys with the `NoExecute` effect:
- `node.kubernetes.io/not-ready`
- `node.kubernetes.io/unreachable`
- `node.alpha.kubernetes.io/unreachable` (will be removed in future version)
For more information on tolerations, consult the https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.syncmasters.volumeAllowShrink
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L148)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
VolumeAllowShrink allows shrinking of the volume
***
### .spec.syncmasters.volumeClaimTemplate
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaim` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L139)</sup>
VolumeClaimTemplate specifies a volumeClaimTemplate used by operator to create to volume claims for pods of this group.
This setting is not available for group `coordinators`, `syncmasters` & `syncworkers`.
The default value describes a volume with `8Gi` storage, `ReadWriteOnce` access mode and volume mode set to `PersistentVolumeFilesystem`.
If this field is not set and `spec.<group>.resources.requests.storage` is set, then a default volume claim
with size as specified by `spec.<group>.resources.requests.storage` will be created. In that case `storage`
and `iops` is not forwarded to the pods resource requirements.
Links:
* [Documentation of core.PersistentVolumeClaim](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaim-v1-core)
***
### .spec.syncmasters.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]ServerGroupSpecVolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L177)</sup>
VolumeMounts define list of volume mounts mounted into server container
Links:
* [Documentation of ServerGroupSpecVolumeMount](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#volumemount-v1-core)
***
### .spec.syncmasters.volumes\[int\].configMap
2024-10-14 14:35:16 +00:00
Type: `core.ConfigMapVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L138)</sup>
ConfigMap which should be mounted into pod
Links:
* [Documentation of core.ConfigMapVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapvolumesource-v1-core)
***
### .spec.syncmasters.volumes\[int\].emptyDir
2024-10-14 14:35:16 +00:00
Type: `core.EmptyDirVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L143)</sup>
EmptyDir
Links:
* [Documentation of core.EmptyDirVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#emptydirvolumesource-v1-core)
***
### .spec.syncmasters.volumes\[int\].hostPath
2024-10-14 14:35:16 +00:00
Type: `core.HostPathVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L148)</sup>
HostPath
Links:
* [Documentation of core.HostPathVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#hostpathvolumesource-v1-core)
***
### .spec.syncmasters.volumes\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L128)</sup>
Name of volume
***
### .spec.syncmasters.volumes\[int\].persistentVolumeClaim
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaimVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L153)</sup>
PersistentVolumeClaim
Links:
* [Documentation of core.PersistentVolumeClaimVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaimvolumesource-v1-core)
***
### .spec.syncmasters.volumes\[int\].secret
2024-10-14 14:35:16 +00:00
Type: `core.SecretVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L133)</sup>
Secret which should be mounted into pod
Links:
* [Documentation of core.SecretVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretvolumesource-v1-core)
***
### .spec.syncworkers.affinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L156)</sup>
Affinity specified additional affinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.PodAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podaffinity-v1-core)
***
### .spec.syncworkers.allowMemberRecreation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L198)</sup>
AllowMemberRecreation allows to recreate member.
This setting changes the member recreation logic based on group:
- For Sync Masters, Sync Workers, Coordinator and DB-Servers it determines if a member can be recreated in case of failure (default `true`)
- For Agents and Single this value is hardcoded to `false` and the value provided in spec is ignored.
***
### .spec.syncworkers.annotations
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L99)</sup>
Annotations specified the annotations added to Pods in this group.
Annotations are merged with `spec.annotations`.
***
### .spec.syncworkers.annotationsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L101)</sup>
AnnotationsIgnoreList list regexp or plain definitions which annotations should be ignored
***
### .spec.syncworkers.annotationsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L103)</sup>
AnnotationsMode Define annotations mode which should be use while overriding annotations
***
### .spec.syncworkers.antiAffinity
2024-10-14 14:35:16 +00:00
Type: `core.PodAntiAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L152)</sup>
AntiAffinity specified additional antiAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of core.Pod.AntiAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#podantiaffinity-v1-core)
***
### .spec.syncworkers.args
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L57)</sup>
Args setting specifies additional command-line arguments passed to all servers of this group.
Default Value: `[]`
***
### .spec.syncworkers.count
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L49)</sup>
Count setting specifies the number of servers to start for the given group.
For the Agent group, this value must be a positive, odd number.
The default value is `3` for all groups except `single` (there the default is `1`
for `spec.mode: Single` and `2` for `spec.mode: ActiveFailover`).
For the `syncworkers` group, it is highly recommended to use the same number
as for the `dbservers` group.
***
### .spec.syncworkers.entrypoint
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L59)</sup>
Entrypoint overrides container executable
***
### .spec.syncworkers.envs\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L26)</sup>
***
### .spec.syncworkers.envs\[int\].value
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_env_var.go#L27)</sup>
***
### .spec.syncworkers.ephemeralVolumes.apps.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.syncworkers.ephemeralVolumes.temp.size
2024-10-14 14:35:16 +00:00
Type: `resource.Quantity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_ephemeral_volumes.go#L64)</sup>
Size define size of the ephemeral volume
Links:
* [Documentation of resource.Quantity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#quantity-resource-core)
***
### .spec.syncworkers.exporterPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L211)</sup>
ExporterPort define Port used by exporter
***
### .spec.syncworkers.extendedRotationCheck
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L181)</sup>
ExtendedRotationCheck extend checks for rotation
***
### .spec.syncworkers.externalPortEnabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L193)</sup>
ExternalPortEnabled if external port should be enabled. If is set to false, ports needs to be exposed via sidecar. Only for ArangoD members
***
### .spec.syncworkers.indexMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L204)</sup>
IndexMethod define group Indexing method
2023-10-12 14:37:40 +00:00
Possible Values:
* `"random"` (default) - Pick random ID for member. Enforced on the Community Operator.
* `"ordered"` - Use sequential number as Member ID, starting from 0. Enterprise Operator required.
2023-10-12 14:37:40 +00:00
***
### .spec.syncworkers.initContainers.containers
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L91)</sup>
Containers contains list of containers
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.syncworkers.initContainers.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_init_containers.go#L94)</sup>
Mode keep container replace mode
***
### .spec.syncworkers.internalPort
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L189)</sup>
InternalPort define port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.syncworkers.internalPortProtocol
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L191)</sup>
InternalPortProtocol define protocol of port used in internal communication, can be accessed over localhost via sidecar. Only for ArangoD members
***
### .spec.syncworkers.labels
2024-10-14 14:35:16 +00:00
Type: `object` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L105)</sup>
Labels specified the labels added to Pods in this group.
***
### .spec.syncworkers.labelsIgnoreList
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L107)</sup>
LabelsIgnoreList list regexp or plain definitions which labels should be ignored
***
### .spec.syncworkers.labelsMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L109)</sup>
LabelsMode Define labels mode which should be use while overriding labels
***
### .spec.syncworkers.maxCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L53)</sup>
MaxCount specifies a maximum for the count of servers. If set, a specification is invalid if `count > maxCount`.
***
### .spec.syncworkers.memoryReservation
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L81)</sup>
MemoryReservation determines the system reservation of memory while calculating `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` value.
If this field is set, `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` is reduced by a specified value in percent.
Accepted Range <0, 50>. If the value is outside the accepted range, it is adjusted to the closest value.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `0`
***
### .spec.syncworkers.minCount
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L51)</sup>
MinCount specifies a minimum for the count of servers. If set, a specification is invalid if `count < minCount`.
***
### .spec.syncworkers.nodeAffinity
2024-10-14 14:35:16 +00:00
Type: `core.NodeAffinity` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L160)</sup>
NodeAffinity specified additional nodeAffinity settings in ArangoDB Pod definitions
Links:
* [Documentation of code.NodeAffinity](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#nodeaffinity-v1-core)
***
### .spec.syncworkers.nodeSelector
2024-10-14 14:35:16 +00:00
Type: `map[string]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L124)</sup>
NodeSelector setting specifies a set of labels to be used as `nodeSelector` for Pods of this node.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/)
***
### .spec.syncworkers.numactl.args
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L38)</sup>
2023-07-28 08:00:57 +00:00
Args define list of the numactl process
Default Value: `[]`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.syncworkers.numactl.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L30)</sup>
2023-07-28 08:00:57 +00:00
Enabled define if numactl should be enabled
Default Value: `false`
2023-07-28 08:00:57 +00:00
***
### .spec.syncworkers.numactl.path
2023-07-28 08:00:57 +00:00
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_numactl_spec.go#L34)</sup>
2023-07-28 08:00:57 +00:00
Path define numactl path within the container
Default Value: `/usr/bin/numactl`
2023-07-28 08:00:57 +00:00
***
2023-07-28 08:00:57 +00:00
### .spec.syncworkers.overrideDetectedNumberOfCores
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L87)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` Container Environment Variable**
OverrideDetectedNumberOfCores determines if number of cores should be overridden based on values in resources.
If is set to true and Container CPU Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_NUMBER_OF_CORES` to the value from the Container CPU Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.syncworkers.overrideDetectedTotalMemory
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L75)</sup>
> [!IMPORTANT]
> **Values set by this feature override user-provided `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` Container Environment Variable**
OverrideDetectedTotalMemory determines if memory should be overridden based on values in resources.
If is set to true and Container Memory Limits are set, it sets Container Environment Variable `ARANGODB_OVERRIDE_DETECTED_TOTAL_MEMORY` to the value from the Container Memory Limits.
Links:
* [Documentation of the ArangoDB Envs](https://docs.arangodb.com/devel/components/arangodb-server/environment-variables/)
Default Value: `true`
***
### .spec.syncworkers.podModes.network
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L31)</sup>
***
### .spec.syncworkers.podModes.pid
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_pod_modes.go#L32)</sup>
***
### .spec.syncworkers.port
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L209)</sup>
Port define Port used by member
***
### .spec.syncworkers.priorityClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L130)</sup>
PriorityClassName specifies a priority class name
Will be forwarded to the pod spec.
Links:
* [Kubernetes documentation](https://kubernetes.io/docs/concepts/configuration/pod-priority-preemption/)
***
### .spec.syncworkers.probes.livenessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L27)</sup>
LivenessProbeDisabled if set to true, the operator does not generate a liveness probe for new pods belonging to this group
Default Value: `false`
***
### .spec.syncworkers.probes.livenessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.syncworkers.probes.livenessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.syncworkers.probes.livenessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.syncworkers.probes.livenessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.syncworkers.probes.livenessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.syncworkers.probes.ReadinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L34)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is deprecated, kept only for backward compatibility.**
OldReadinessProbeDisabled if true readinessProbes are disabled
***
### .spec.syncworkers.probes.readinessProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L36)</sup>
ReadinessProbeDisabled override flag for probe disabled in good manner (lowercase) with backward compatibility
***
### .spec.syncworkers.probes.readinessProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.syncworkers.probes.readinessProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.syncworkers.probes.readinessProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.syncworkers.probes.readinessProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.syncworkers.probes.readinessProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.syncworkers.probes.startupProbeDisabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L41)</sup>
StartupProbeDisabled if true startupProbes are disabled
***
### .spec.syncworkers.probes.startupProbeSpec.failureThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L77)</sup>
FailureThreshold when a Pod starts and the probe fails, Kubernetes will try failureThreshold times before giving up.
Giving up means restarting the container.
Minimum value is 1.
Default Value: `3`
***
### .spec.syncworkers.probes.startupProbeSpec.initialDelaySeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L60)</sup>
InitialDelaySeconds specifies number of seconds after the container has started before liveness or readiness probes are initiated.
Minimum value is 0.
Default Value: `2`
***
### .spec.syncworkers.probes.startupProbeSpec.periodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L64)</sup>
PeriodSeconds How often (in seconds) to perform the probe.
Minimum value is 1.
Default Value: `10`
***
### .spec.syncworkers.probes.startupProbeSpec.successThreshold
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L72)</sup>
SuccessThreshold Minimum consecutive successes for the probe to be considered successful after having failed.
Minimum value is 1.
Default Value: `1`
***
### .spec.syncworkers.probes.startupProbeSpec.timeoutSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec_probe.go#L68)</sup>
TimeoutSeconds specifies number of seconds after which the probe times out
Minimum value is 1.
Default Value: `2`
***
### .spec.syncworkers.pvcResizeMode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L144)</sup>
VolumeResizeMode specified resize mode for PVCs and PVs
Possible Values:
* `"runtime"` (default) - PVC will be resized in Pod runtime (EKS, GKE)
* `"rotate"` - Pod will be shutdown and PVC will be resized (AKS)
***
### .spec.syncworkers.resources
2024-10-14 14:35:16 +00:00
Type: `core.ResourceRequirements` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L69)</sup>
Resources holds resource requests & limits
Links:
* [Documentation of core.ResourceRequirements](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#resourcerequirements-v1-core)
***
### .spec.syncworkers.schedulerName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L61)</sup>
SchedulerName define scheduler name used for group
***
### .spec.syncworkers.securityContext.addCapabilities
2024-10-14 14:35:16 +00:00
Type: `[]core.Capability` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L41)</sup>
AddCapabilities add new capabilities to containers
***
### .spec.syncworkers.securityContext.allowPrivilegeEscalation
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L44)</sup>
AllowPrivilegeEscalation Controls whether a process can gain more privileges than its parent process.
***
### .spec.syncworkers.securityContext.dropAllCapabilities
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L38)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **This field is added for backward compatibility. Will be removed in 1.1.0.**
DropAllCapabilities specifies if capabilities should be dropped for this pod containers
***
### .spec.syncworkers.securityContext.fsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L61)</sup>
FSGroup is a special supplemental group that applies to all containers in a pod.
***
### .spec.syncworkers.securityContext.privileged
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L47)</sup>
Privileged If true, runs container in privileged mode. Processes in privileged containers are
essentially equivalent to root on the host.
***
### .spec.syncworkers.securityContext.readOnlyRootFilesystem
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L49)</sup>
ReadOnlyRootFilesystem if true, mounts the container's root filesystem as read-only.
***
### .spec.syncworkers.securityContext.runAsGroup
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L55)</sup>
RunAsGroup is the GID to run the entrypoint of the container process.
***
### .spec.syncworkers.securityContext.runAsNonRoot
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L51)</sup>
RunAsNonRoot if true, indicates that the container must run as a non-root user.
***
### .spec.syncworkers.securityContext.runAsUser
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L53)</sup>
RunAsUser is the UID to run the entrypoint of the container process.
***
### .spec.syncworkers.securityContext.seccompProfile
2024-10-14 14:35:16 +00:00
Type: `core.SeccompProfile` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L77)</sup>
SeccompProfile defines a pod/container's seccomp profile settings. Only one profile source may be set.
Links:
* [Documentation of core.SeccompProfile](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#seccompprofile-v1-core)
***
### .spec.syncworkers.securityContext.seLinuxOptions
2024-10-14 14:35:16 +00:00
Type: `core.SELinuxOptions` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L82)</sup>
SELinuxOptions are the labels to be applied to the container
Links:
* [Documentation of core.SELinuxOptions](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#selinuxoptions-v1-core)
***
### .spec.syncworkers.securityContext.supplementalGroups
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L59)</sup>
SupplementalGroups is a list of groups applied to the first process run in each container, in addition to the container's primary GID,
the fsGroup (if specified), and group memberships defined in the container image for the uid of the container process.
***
### .spec.syncworkers.securityContext.sysctls
2024-10-14 14:35:16 +00:00
Type: `map[string]intstr.IntOrString` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_security_context_spec.go#L72)</sup>
Sysctls hold a list of namespaced sysctls used for the pod. Pods with unsupported
sysctls (by the container runtime) might fail to launch.
Map Value can be String or Int
Links:
* [Documentation](https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/)
Example:
```yaml
sysctls:
"kernel.shm_rmid_forced": "0"
"net.core.somaxconn": 1024
"kernel.msgmax": "65536"
```
***
### .spec.syncworkers.serviceAccountName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L120)</sup>
ServiceAccountName setting specifies the `serviceAccountName` for the `Pods` created
for each server of this group. If empty, it defaults to using the
`default` service account.
Using an alternative `ServiceAccount` is typically used to separate access rights.
The ArangoDB deployments need some very minimal access rights. With the
deployment of the operator, we grant the rights to 'get' all 'pod' resources.
If you are using a different service account, please grant these rights
to that service account.
***
### .spec.syncworkers.shutdownDelay
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L187)</sup>
ShutdownDelay define how long operator should delay finalizer removal after shutdown
***
### .spec.syncworkers.shutdownMethod
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L185)</sup>
ShutdownMethod describe procedure of member shutdown taken by Operator
***
### .spec.syncworkers.sidecarCoreNames
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L163)</sup>
SidecarCoreNames is a list of sidecar containers which must run in the pod.
Some names (e.g.: "server", "worker") are reserved, and they don't have any impact.
***
### .spec.syncworkers.sidecars
2024-10-14 14:35:16 +00:00
Type: `[]core.Container` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L167)</sup>
Sidecars specifies a list of additional containers to be started
Links:
* [Documentation of core.Container](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#container-v1-core)
***
### .spec.syncworkers.storageClassName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L65)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Use VolumeClaimTemplate instead.**
StorageClassName specifies the classname for storage of the servers.
***
### .spec.syncworkers.terminationGracePeriodSeconds
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L200)</sup>
TerminationGracePeriodSeconds override default TerminationGracePeriodSeconds for pods - via silent rotation
***
### .spec.syncworkers.tolerations
2024-10-14 14:35:16 +00:00
Type: `[]core.Toleration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L96)</sup>
Tolerations specifies the tolerations added to Pods in this group.
By default, suitable tolerations are set for the following keys with the `NoExecute` effect:
- `node.kubernetes.io/not-ready`
- `node.kubernetes.io/unreachable`
- `node.alpha.kubernetes.io/unreachable` (will be removed in future version)
For more information on tolerations, consult the https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
Links:
* [Documentation of core.Toleration](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#toleration-v1-core)
***
### .spec.syncworkers.volumeAllowShrink
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L148)</sup>
> [!WARNING]
> ***DEPRECATED***
>
> **Not used anymore**
VolumeAllowShrink allows shrinking of the volume
***
### .spec.syncworkers.volumeClaimTemplate
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaim` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L139)</sup>
VolumeClaimTemplate specifies a volumeClaimTemplate used by operator to create to volume claims for pods of this group.
This setting is not available for group `coordinators`, `syncmasters` & `syncworkers`.
The default value describes a volume with `8Gi` storage, `ReadWriteOnce` access mode and volume mode set to `PersistentVolumeFilesystem`.
If this field is not set and `spec.<group>.resources.requests.storage` is set, then a default volume claim
with size as specified by `spec.<group>.resources.requests.storage` will be created. In that case `storage`
and `iops` is not forwarded to the pods resource requirements.
Links:
* [Documentation of core.PersistentVolumeClaim](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaim-v1-core)
***
### .spec.syncworkers.volumeMounts
2024-10-14 14:35:16 +00:00
Type: `[]ServerGroupSpecVolumeMount` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_spec.go#L177)</sup>
VolumeMounts define list of volume mounts mounted into server container
Links:
* [Documentation of ServerGroupSpecVolumeMount](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#volumemount-v1-core)
***
### .spec.syncworkers.volumes\[int\].configMap
2024-10-14 14:35:16 +00:00
Type: `core.ConfigMapVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L138)</sup>
ConfigMap which should be mounted into pod
Links:
* [Documentation of core.ConfigMapVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapvolumesource-v1-core)
***
### .spec.syncworkers.volumes\[int\].emptyDir
2024-10-14 14:35:16 +00:00
Type: `core.EmptyDirVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L143)</sup>
EmptyDir
Links:
* [Documentation of core.EmptyDirVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#emptydirvolumesource-v1-core)
***
### .spec.syncworkers.volumes\[int\].hostPath
2024-10-14 14:35:16 +00:00
Type: `core.HostPathVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L148)</sup>
HostPath
Links:
* [Documentation of core.HostPathVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#hostpathvolumesource-v1-core)
***
### .spec.syncworkers.volumes\[int\].name
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L128)</sup>
Name of volume
***
### .spec.syncworkers.volumes\[int\].persistentVolumeClaim
2024-10-14 14:35:16 +00:00
Type: `core.PersistentVolumeClaimVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L153)</sup>
PersistentVolumeClaim
Links:
* [Documentation of core.PersistentVolumeClaimVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#persistentvolumeclaimvolumesource-v1-core)
***
### .spec.syncworkers.volumes\[int\].secret
2024-10-14 14:35:16 +00:00
Type: `core.SecretVolumeSource` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/server_group_volume.go#L133)</sup>
Secret which should be mounted into pod
Links:
* [Documentation of core.SecretVolumeSource](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretvolumesource-v1-core)
***
### .spec.timeouts.actions
2024-10-14 14:35:16 +00:00
Type: `map[string]meta.Duration` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/timeouts.go#L44)</sup>
Actions keep map of the actions timeouts.
Links:
* [List of supported action names](../generated/actions.md)
* [Definition of meta.Duration](https://github.com/kubernetes/apimachinery/blob/v0.26.6/pkg/apis/meta/v1/duration.go)
Example:
```yaml
actions:
AddMember: 30m
```
***
### .spec.timeouts.maintenanceGracePeriod
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/timeouts.go#L36)</sup>
MaintenanceGracePeriod action timeout
***
### .spec.timezone
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_spec.go#L261)</sup>
Timezone if specified, will set a timezone for deployment.
Must be in format accepted by "tzdata", e.g. `America/New_York` or `Europe/London`
***
### .spec.tls.altNames
2024-10-14 14:35:16 +00:00
Type: `[]string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L72)</sup>
AltNames setting specifies a list of alternate names that will be added to all generated
certificates. These names can be DNS names or email addresses.
The default value is empty.
***
### .spec.tls.caSecretName
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L67)</sup>
CASecretName setting specifies the name of a kubernetes `Secret` that contains
a standard CA certificate + private key used to sign certificates for individual
ArangoDB servers.
When no name is specified, it defaults to `<deployment-name>-ca`.
To disable authentication, set this value to `None`.
If you specify a name of a `Secret` that does not exist, a self-signed CA certificate + key is created
and stored in a `Secret` with given name.
The specified `Secret`, must contain the following data fields:
- `ca.crt` PEM encoded public key of the CA certificate
- `ca.key` PEM encoded private key of the CA certificate
***
### .spec.tls.mode
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L81)</sup>
***
### .spec.tls.sni.mapping.\<string\>
2024-10-14 14:35:16 +00:00
Type: `array` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_sni_spec.go#L30)</sup>
***
### .spec.tls.ttl
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/tls_spec.go#L79)</sup>
TTL setting specifies the time to live of all generated server certificates.
When the server certificate is about to expire, it will be automatically replaced
by a new one and the affected server will be restarted.
Note: The time to live of the CA certificate (when created automatically)
will be set to 10 years.
Default Value: `"2160h" (about 3 months)`
***
### .spec.topology.enabled
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/topology_spec.go#L26)</sup>
***
### .spec.topology.label
2024-10-14 14:35:16 +00:00
Type: `string` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/topology_spec.go#L28)</sup>
***
### .spec.topology.zones
2024-10-14 14:35:16 +00:00
Type: `integer` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/topology_spec.go#L27)</sup>
***
### .spec.upgrade.autoUpgrade
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_upgrade_spec.go#L26)</sup>
AutoUpgrade flag specifies if upgrade should be auto-injected, even if is not required (in case of stuck)
Default Value: `false`
***
### .spec.upgrade.debugLog
2024-10-14 14:35:16 +00:00
Type: `boolean` <sup>[\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.43/pkg/apis/deployment/v1/deployment_upgrade_spec.go#L30)</sup>
DebugLog flag specifies if containers running upgrade process should print more debugging information.
This applies only to init containers.
Default Value: `false`