Type object
File match vCluster.yml vCluster.yaml vcluster.yaml vcluster.yml
Schema URL https://catalog.lintel.tools/schemas/schemastore/vcluster/latest.json
Source https://raw.githubusercontent.com/loft-sh/vcluster/main/chart/values.schema.json

Validate with Lintel

npx @lintel/lintel check
Type: object

Config is the vCluster config.

Properties

global

Global values shared across all (sub)charts

exportKubeConfig object

ExportKubeConfig describes how vCluster should export the vCluster kubeconfig.

6 nested properties
context string

Context is the name of the context within the generated kubeconfig to use.

server string

Override the default https://localhost:8443 and specify a custom hostname for the generated kubeconfig.

insecure boolean

If tls should get skipped for the server

serviceAccount object
3 nested properties
name string

Name of the service account to be used to generate a service account token instead of the default certificates.

namespace string

Namespace of the service account to be used to generate a service account token instead of the default certificates. If omitted, will use the kube-system namespace.

clusterRole string

ClusterRole to assign to the service account.

secret object

Declare in which host cluster secret vCluster should store the generated virtual cluster kubeconfig.

2 nested properties
name string

Name is the name of the secret where the kubeconfig should get stored.

namespace string

Namespace where vCluster should store the kubeconfig secret. If this is not equal to the namespace where you deployed vCluster, you need to make sure vCluster has access to this other namespace.

AdditionalSecrets specifies the additional host cluster secrets in which vCluster will store the generated virtual cluster kubeconfigs.

sync object
2 nested properties
toHost object
20 nested properties
pods object
9 nested properties
enabled boolean

Enabled defines if pod syncing should be enabled.

translateImage Record<string, string>

TranslateImage maps an image to another image that should be used instead. For example this can be used to rewrite a certain image that is used within the virtual cluster to be another image on the host cluster

enforceTolerations string[]

EnforceTolerations will add the specified tolerations to all pods synced by the virtual cluster.

useSecretsForSATokens boolean

UseSecretsForSATokens will use secrets to save the generated service account tokens by virtual cluster instead of using a pod annotation.

runtimeClassName string

RuntimeClassName is the runtime class to set for synced pods.

priorityClassName string

PriorityClassName is the priority class to set for synced pods.

rewriteHosts object

Patches patch the resource according to the provided specification.

hybridScheduling object
secrets object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

all boolean

All defines if all resources of that type should get synced or only the necessary ones that are needed.

Patches patch the resource according to the provided specification.

configMaps object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

all boolean

All defines if all resources of that type should get synced or only the necessary ones that are needed.

Patches patch the resource according to the provided specification.

ingresses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

services object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

endpoints object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

endpointSlices object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

networkPolicies object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

persistentVolumeClaims object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

persistentVolumes object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

volumeSnapshots object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

volumeSnapshotContents object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

storageClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

serviceAccounts object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

podDisruptionBudgets object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

priorityClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

customResources Record<string, object>

CustomResources defines what custom resources should get synced from the virtual cluster to the host cluster. vCluster will copy the definition automatically from host cluster to virtual cluster on startup. vCluster will also automatically add any required RBAC permissions to the vCluster role for this to work.

namespaces object

SyncToHostNamespaces defines how namespaces should be synced from the virtual cluster to the host cluster.

5 nested properties
enabled boolean required

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
mappingsOnly boolean

MappingsOnly defines if creation of namespaces not matched by mappings should be allowed.

extraLabels Record<string, string>

ExtraLabels are additional labels to add to the namespace in the host cluster.

resourceClaims object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

resourceClaimTemplates object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

fromHost object
14 nested properties
nodes object
5 nested properties
enabled boolean

Enabled specifies if syncing real nodes should be enabled. If this is disabled, vCluster will create fake nodes instead.

syncBackChanges boolean

SyncBackChanges enables syncing labels and taints from the virtual cluster to the host cluster. If this is enabled someone within the virtual cluster will be able to change the labels and taints of the host cluster node.

clearImageStatus boolean

ClearImageStatus will erase the image status when syncing a node. This allows to hide images that are pulled by the node.

selector object

Patches patch the resource according to the provided specification.

events object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

ingressClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
runtimeClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
priorityClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
storageClasses object
3 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
csiNodes object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

csiDrivers object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

csiStorageCapacities object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

customResources Record<string, object>

CustomResources defines what custom resources should get synced read-only to the virtual cluster from the host cluster. vCluster will automatically add any required RBAC to the vCluster cluster role.

volumeSnapshotClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

configMaps object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
secrets object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
deviceClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
integrations object

Integrations holds config for vCluster integrations with other operators or tools running on the host cluster

6 nested properties
metricsServer object

MetricsServer reuses the metrics server from the host cluster within the vCluster.

4 nested properties
enabled boolean

Enabled signals the metrics server integration should be enabled.

apiService object

APIService holds configuration related to the api server

1 nested properties
service object

APIServiceService holds the service name and namespace of the host apiservice.

nodes boolean

Nodes defines if metrics-server nodes api should get proxied from host to virtual cluster.

pods boolean

Pods defines if metrics-server pods api should get proxied from host to virtual cluster.

kubeVirt object

KubeVirt reuses a host kubevirt and makes certain CRDs from it available inside the vCluster

4 nested properties
enabled boolean

Enabled signals if the integration should be enabled

apiService object

APIService holds configuration related to the api server

1 nested properties
service object

APIServiceService holds the service name and namespace of the host apiservice.

webhook object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object

KubeVirtSync are the crds that are supported by this integration

6 nested properties
dataVolumes object
virtualMachineInstanceMigrations object
virtualMachineInstances object
virtualMachines object
virtualMachineClones object
virtualMachinePools object
externalSecrets object

ExternalSecrets reuses a host external secret operator and makes certain CRDs from it available inside the vCluster

4 nested properties
enabled boolean

Enabled defines whether the external secret integration is enabled or not

version string

Version defines the version of the external secrets operator to use. If empty, the storage version will be used.

webhook object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object
2 nested properties
toHost object
fromHost object
certManager object

CertManager reuses a host cert-manager and makes its CRDs from it available inside the vCluster

2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object
2 nested properties
toHost object
fromHost object
istio object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object
1 nested properties
toHost object
netris object

NetrisIntegration holds netris integration configuration.

3 nested properties
enabled boolean

Enabled defines if netris integration is enabled +optional

connector string

Connector specifies the netris connector name +optional

kubeVip object

NetrisKubeVipConfig holds kube-vip configuration for netris integration

3 nested properties
serverCluster string

ServerCluster specifies the server cluster name +optional

bridge string

Bridge specifies the bridge interface name +optional

ipRange string

IPRange specifies the IP range for kube-vip +optional

deploy object
7 nested properties
kubeProxy object
9 nested properties
enabled boolean

Enabled defines if the kube proxy should be enabled.

image string

Image is the image for the kube-proxy.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the kube-proxy.

priorityClassName string

PriorityClassName is the priority class name for the kube-proxy.

tolerations array

Tolerations is the tolerations for the kube-proxy.

extraEnv array

ExtraEnv is the extra environment variables for the kube-proxy.

extraArgs string[]

ExtraArgs are additional arguments to pass to the kube-proxy.

config object

Config is the config for the kube-proxy that will be merged into the default kube-proxy config. More information can be found here: https://kubernetes.io/docs/reference/config-api/kube-proxy-config.v1alpha1/#kubeproxy-config-k8s-io-v1alpha1-KubeProxyConfiguration

metallb object
4 nested properties
enabled boolean

Enabled defines if metallb should be enabled.

controllerImage string

ControllerImage is the image for metallb controller.

speakerImage string

SpeakerImage is the image for metallb speaker.

ipAddressPool object
2 nested properties
addresses string[]

Addresses is a list of IP addresses to use for the IP address pool.

l2Advertisement boolean

L2Advertisement defines if L2 advertisement should be enabled for the IP address pool.

cni object
1 nested properties
flannel object
4 nested properties
enabled boolean

Enabled defines if Flannel should be enabled.

image string

Image is the image for Flannel main container.

initImage string

InitImage is the image for Flannel init container.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

localPathProvisioner object
4 nested properties
enabled boolean

Enabled defines if LocalPathProvisioner should be enabled.

image string

Image is the image for local path provisioner.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodePath string

NodePath is the path on the node where to create the persistent volume directories.

ingressNginx object
2 nested properties
enabled boolean

Enabled defines if ingress-nginx should be enabled.

defaultIngressClass boolean

DefaultIngressClass defines if the deployed ingress class should be the default ingress class.

metricsServer object
1 nested properties
enabled boolean

Enabled defines if metrics server should be enabled.

volumeSnapshotController object

VolumeSnapshotController defines CSI volumes snapshot-controller configuration.

1 nested properties
enabled boolean

Enabled defines if the CSI volumes snapshot-controller should be enabled.

networking object
5 nested properties
serviceCIDR string

ServiceCIDR holds the service cidr for the virtual cluster. This should only be set if privateNodes.enabled is true or vCluster cannot detect the host service cidr.

podCIDR string

PodCIDR holds the pod cidr for the virtual cluster. This should only be set if privateNodes.enabled is true.

replicateServices object
2 nested properties

ToHost defines the services that should get synced from virtual cluster to the host cluster. If services are synced to a different namespace than the virtual cluster is in, additional permissions for the other namespace are required.

fromHost ServiceMapping[]

FromHost defines the services that should get synced from the host to the virtual cluster.

resolveDNS ResolveDNS[]

ResolveDNS allows to define extra DNS rules. This only works if embedded coredns is configured.

advanced object
3 nested properties
clusterDomain string

ClusterDomain is the Kubernetes cluster domain to use within the virtual cluster.

fallbackHostCluster boolean

FallbackHostCluster allows to fallback dns to the host cluster. This is useful if you want to reach host services without any other modification. You will need to provide a namespace for the service, e.g. my-other-service.my-other-namespace

proxyKubelets object
2 nested properties
byHostname boolean

ByHostname will add a special vCluster hostname to the nodes where the node can be reached at. This doesn't work for all applications, e.g. Prometheus requires a node IP.

byIP boolean

ByIP will create a separate service in the host cluster for every node that will point to virtual cluster and will be used to route traffic.

policies object
5 nested properties
networkPolicy object
6 nested properties
enabled boolean

Enabled defines if the network policy should be deployed by vCluster.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

fallbackDns string

FallbackDNS is the fallback DNS server to use if the virtual cluster does not have a DNS server.

controlPlane object
2 nested properties

Ingress rules for the vCluster control plane.

Egress rules for the vCluster control plane.

workload object
3 nested properties
publicEgress object

Ingress rules for the vCluster workloads.

Egress rules for the vCluster workloads.

podSecurityStandard string

PodSecurityStandard that can be enforced can be one of: empty (""), baseline, restricted or privileged

resourceQuota object
6 nested properties
enabled string | boolean

Enabled defines if the resource quota should be enabled. "auto" means that if limitRange is enabled, the resourceQuota will be enabled as well.

quota object

Quota are the quota options

scopeSelector object

ScopeSelector is the resource quota scope selector

scopes string[]

Scopes are the resource quota scopes

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

limitRange object
7 nested properties
enabled string | boolean

Enabled defines if the limit range should be deployed by vCluster. "auto" means that if resourceQuota is enabled, the limitRange will be enabled as well.

default object

Default are the default limits for the limit range

defaultRequest object

DefaultRequest are the default request options for the limit range

max object

Max are the max limits for the limit range

min object

Min are the min limits for the limit range

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

centralAdmission object
2 nested properties

ValidatingWebhooks are validating webhooks that should be enforced in the virtual cluster

MutatingWebhooks are mutating webhooks that should be enforced in the virtual cluster

controlPlane object
13 nested properties
endpoint string

Endpoint is the endpoint of the virtual cluster. This is used to connect to the virtual cluster.

distro object
1 nested properties
k8s object
10 nested properties
enabled boolean

Enabled specifies if the K8s distro should be enabled. Only one distro can be enabled at the same time.

version string

Version is the Kubernetes version to use.

apiServer object
controllerManager object
scheduler object
image object
imagePullPolicy string

ImagePullPolicy is the pull policy for the distro image

env object[]

Env are extra environment variables to use for the main container and NOT the init container.

resources object

Resources for the distro init container

securityContext object

Security options can be used for the distro init container

standalone object
4 nested properties
enabled boolean

Enabled defines if standalone mode should be enabled.

dataDir string

DataDir defines the data directory for the standalone mode.

autoNodes object
3 nested properties
provider string

Provider is the node provider of the nodes in this pool.

quantity integer

Quantity is the number of nodes to deploy for standalone mode.

nodeTypeSelector Requirement[]

NodeTypeSelector filters the types of nodes that can be provisioned by this pool. All requirements must be met for a node type to be eligible.

joinNode object
8 nested properties
enabled boolean

Enabled defines if the standalone node should be joined into the cluster. If false, only the control plane binaries will be executed and no node will show up in the actual cluster.

preInstallCommands string[]

PreInstallCommands are commands that will be executed before containerd, kubelet etc. is installed.

preJoinCommands string[]

PreJoinCommands are commands that will be executed before kubeadm join is executed.

postJoinCommands string[]

PostJoinCommands are commands that will be executed after kubeadm join is executed.

containerd object
caCertPath string

CACertPath is the path to the SSL certificate authority used to secure communications between node and control-plane. Defaults to "/etc/kubernetes/pki/ca.crt".

skipPhases string[]

SkipPhases is a list of phases to skip during command execution. The list of phases can be obtained with the "kubeadm join --help" command.

nodeRegistration object
backingStore object
2 nested properties
etcd object
3 nested properties
embedded object
deploy object
external object
database object
2 nested properties
embedded object
external object
coredns object
8 nested properties
enabled boolean

Enabled defines if coredns is enabled

embedded boolean

Embedded defines if vCluster will start the embedded coredns service within the control-plane and not as a separate deployment. This is a PRO feature.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

service object
3 nested properties
spec object

Spec holds extra options for the coredns service

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

deployment object
10 nested properties
image string

Image is the coredns image to use

replicas integer

Replicas is the amount of coredns pods to run.

nodeSelector Record<string, string>

NodeSelector is the node selector to use for coredns.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

resources object
pods object
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the CoreDNS pod.

overwriteConfig string

OverwriteConfig can be used to overwrite the coredns config

overwriteManifests string

OverwriteManifests can be used to overwrite the coredns manifests used to deploy coredns

priorityClassName string

PriorityClassName specifies the priority class name for the CoreDNS pods.

proxy object
3 nested properties
bindAddress string

BindAddress under which vCluster will expose the proxy.

port integer

Port under which vCluster will expose the proxy. Changing port is currently not supported.

extraSANs string[]

ExtraSANs are extra hostnames to sign the vCluster proxy certificate for.

hostPathMapper object
2 nested properties
enabled boolean

Enabled specifies if the host path mapper will be used

central boolean

Central specifies if the central host path mapper will be used

ingress object
6 nested properties
enabled boolean

Enabled defines if the control plane ingress should be enabled

host string

Host is the host where vCluster will be reachable

pathType string

PathType is the path type of the ingress

spec object

Spec allows you to configure extra ingress options.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

tlsRoute object
7 nested properties
enabled boolean

Enabled defines if the control plane should be exposed via a gateway api tls route. Make sure to enable tls passthrough in the gateway via tls.mode to "Passthrough"

apiVersion string

APIVersion is the version of the gateway api tls route.

host string

Host is the host where vCluster will be reachable

parentRefs object[]

ParentRefs are the parent references for the TLS route

spec object

Spec allows you to configure extra tls route options.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

service object
6 nested properties
enabled boolean

Enabled defines if the control plane service should be enabled

spec object

Spec allows you to configure extra service options.

kubeletNodePort integer

KubeletNodePort is the node port where the fake kubelet is exposed. Defaults to 0.

httpsNodePort integer

HTTPSNodePort is the node port where https is exposed. Defaults to 0.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

statefulSet object
22 nested properties
highAvailability object
4 nested properties
replicas integer

Replicas is the amount of replicas to use for the statefulSet.

leaseDuration integer

LeaseDuration is the time to lease for the leader.

renewDeadline integer

RenewDeadline is the deadline to renew a lease for the leader.

retryPeriod integer

RetryPeriod is the time until a replica will retry to get a lease.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

scheduling object
6 nested properties
nodeSelector object

NodeSelector is the node selector to apply to the pod.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

priorityClassName string

PriorityClassName is the priority class name for the the pod.

podManagementPolicy string

PodManagementPolicy is the statefulSet pod management policy.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the pod.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

probes object
3 nested properties
livenessProbe object

LivenessProbe defines the configuration for the liveness probe.

readinessProbe object

ReadinessProbe defines the configuration for the readiness probe.

startupProbe object

StartupProbe defines the configuration for the startup probe.

persistence object
6 nested properties
volumeClaim object
volumeClaimTemplates object[]

VolumeClaimTemplates defines the volumeClaimTemplates for the statefulSet

dataVolume object[]

Allows you to override the dataVolume. Only works correctly if volumeClaim.enabled=false.

binariesVolume object[]

BinariesVolume defines a binaries volume that is used to retrieve distro specific executables to be run by the syncer controller. This volume doesn't need to be persistent.

addVolumes object[]

AddVolumes defines extra volumes for the pod

addVolumeMounts VolumeMount[]

AddVolumeMounts defines extra volume mounts for the container

enableServiceLinks boolean

EnableServiceLinks for the StatefulSet pod

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

pods object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

workingDir string

WorkingDir specifies in what folder the main process should get started.

command string[]

Command allows you to override the main command.

args string[]

Args allows you to override the main arguments.

env object[]

Env are additional environment variables for the statefulSet container.

dnsPolicy string

Set DNS policy for the pod.

dnsConfig object

PodDNSConfig defines the DNS parameters of a pod in addition to those generated from DNSPolicy.

3 nested properties
nameservers string[]

A list of DNS name server IP addresses. This will be appended to the base nameservers generated from DNSPolicy. Duplicated nameservers will be removed. +optional +listType=atomic

searches string[]

A list of DNS search domains for host-name lookup. This will be appended to the base search paths generated from DNSPolicy. Duplicated search paths will be removed. +optional +listType=atomic

A list of DNS resolver options. This will be merged with the base options generated from DNSPolicy. Duplicated entries will be removed. Resolution options given in Options will override those that appear in the base DNSPolicy. +optional +listType=atomic

initContainers array

InitContainers are additional init containers for the statefulSet.

sidecarContainers array

SidecarContainers are additional sidecar containers for the statefulSet.

hostAliases HostAlias[]

HostAliases allows you to add custom entries to the /etc/hosts file of each Pod created.

runtimeClassName string

RuntimeClassName is the runtime class to set for the statefulSet pods.

serviceMonitor object
3 nested properties
enabled boolean

Enabled configures if Helm should create the service monitor.

labels Record<string, string>

Labels are the extra labels to add to the service monitor.

annotations Record<string, string>

Annotations are the extra annotations to add to the service monitor.

advanced object
11 nested properties
defaultImageRegistry string

DefaultImageRegistry will be used as a prefix for all internal images deployed by vCluster or Helm. This makes it easy to upload all required vCluster images to a single private repository and set this value. Workload images are not affected by this.

virtualScheduler object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

serviceAccount object
5 nested properties
enabled boolean

Enabled specifies if the service account should get deployed.

name string

Name specifies what name to use for the service account.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

workloadServiceAccount object
5 nested properties
enabled boolean

Enabled specifies if the service account for the workloads should get deployed.

name string

Name specifies what name to use for the service account for the virtual cluster workloads.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the workload service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

headlessService object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

konnectivity object
2 nested properties
server object
agent object
registry object
3 nested properties
enabled boolean

Enabled defines if the embedded registry should be enabled.

anonymousPull boolean

AnonymousPull allows enabling anonymous pull for the embedded registry. This allows anybody to pull images from the registry without authentication.

config

Config is the regular docker registry config. See https://distribution.github.io/distribution/about/configuration/ for more details.

cloudControllerManager object
1 nested properties
enabled boolean

Enabled defines if the embedded cloud controller manager should be enabled. This defaults to true, but can be disabled if you want to use an external cloud controller manager such as AWS or GCP. The cloud controller manager is responsible for setting the node's ip addresses as well as the provider id for the node and other node metadata.

globalMetadata object
1 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

kubeVip object
3 nested properties
enabled boolean

Enabled defines if embedded kube-vip should be enabled.

interface string

Interface is the network interface on which the VIP is announced.

gateway string

Gateway is the gateway address in CIDR notation (e.g., 10.100.0.1/24). This is used to configure policy-based routing for the VIP and must include the subnet prefix.

podDisruptionBudget object
4 nested properties
enabled boolean

Enabled defines if the pod disruption budget should be enabled.

minAvailable

MinAvailable describes the minimal number or percentage of available pods.

maxUnavailable

MaxUnavailable describes the minimal number or percentage of unavailable pods.

unhealthyPodEvictionPolicy string

UnhealthyPodEvictionPolicy defines the criteria when unhealthy pods should be considered for eviction. Currently supported values are:

  • IfHealthyBudget - pods that are in the Running phase but not yet healthy are considered disrupted and may be evicted even if the PodDisruptionBudget criteria are not met.
  • AlwaysAllow - pods that are in the Running phase but not yet healthy are considered disrupted and can be evicted regardless of whether the criteria in a PDB is met.
privateNodes object

PrivateNodes enables private nodes for vCluster.

6 nested properties
enabled boolean

Enabled defines if dedicated nodes should be enabled.

kubelet object
1 nested properties
config object

Config is the config for the kubelet that will be merged into the default kubelet config. More information can be found here: https://kubernetes.io/docs/reference/config-api/kubelet-config.v1beta1/#kubelet-config-k8s-io-v1beta1-KubeletConfiguration

autoUpgrade object
7 nested properties
enabled boolean

Enabled defines if auto upgrade should be enabled.

image string

Image is the image for the auto upgrade pod started by vCluster. If empty defaults to the controlPlane.statefulSet.image.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the auto upgrade. If empty will select all worker nodes.

binariesPath string

BinariesPath is the base path for the kubeadm binaries. Defaults to /usr/local/bin

cniBinariesPath string

CNIBinariesPath is the base path for the CNI binaries. Defaults to /opt/cni/bin

concurrency integer

Concurrency is the number of nodes that can be upgraded at the same time.

joinNode object
7 nested properties
preInstallCommands string[]

PreInstallCommands are commands that will be executed before containerd, kubelet etc. is installed.

preJoinCommands string[]

PreJoinCommands are commands that will be executed before kubeadm join is executed.

postJoinCommands string[]

PostJoinCommands are commands that will be executed after kubeadm join is executed.

containerd object
3 nested properties
enabled boolean

Enabled defines if containerd should be installed and configured by vCluster.

registry object
pauseImage string

PauseImage is the image for the pause container.

caCertPath string

CACertPath is the path to the SSL certificate authority used to secure communications between node and control-plane. Defaults to "/etc/kubernetes/pki/ca.crt".

skipPhases string[]

SkipPhases is a list of phases to skip during command execution. The list of phases can be obtained with the "kubeadm join --help" command.

nodeRegistration object
5 nested properties
criSocket string

CRI socket is the socket for the CRI.

kubeletExtraArgs KubeletExtraArg[]

KubeletExtraArgs passes through extra arguments to the kubelet. The arguments here are passed to the kubelet command line via the environment file kubeadm writes at runtime for the kubelet to source. This overrides the generic base-level configuration in the kubelet-config ConfigMap Flags have higher priority when parsing. These values are local and specific to the node kubeadm is executing on. An argument name in this list is the flag name as it appears on the command line except without leading dash(es). Extra arguments will override existing default arguments. Duplicate extra arguments are allowed.

Taints are additional taints to set for the kubelet.

ignorePreflightErrors string[]

IgnorePreflightErrors provides a slice of pre-flight errors to be ignored when the current node is registered, e.g. 'IsPrivilegedUser,Swap'. Value 'all' ignores errors from all checks.

imagePullPolicy string

ImagePullPolicy specifies the policy for image pulling during kubeadm "init" and "join" operations. The value of this field must be one of "Always", "IfNotPresent" or "Never". If this field is unset kubeadm will default it to "IfNotPresent", or pull the required images if not present on the host.

AutoNodes stores auto nodes configuration.

vpn object
2 nested properties
enabled boolean

Enabled defines if the private nodes vpn should be enabled.

nodeToNode object
1 nested properties
enabled boolean

Enabled defines if the node to node vpn should be enabled.

rbac object
3 nested properties
role object
3 nested properties
enabled boolean

Enabled defines if the role should be enabled or disabled.

extraRules object[]

ExtraRules will add rules to the role.

overwriteRules object[]

OverwriteRules will overwrite the role rules completely.

clusterRole object
3 nested properties
enabled string | boolean

Enabled defines if the cluster role should be enabled or disabled. If auto, vCluster automatically determines whether the virtual cluster requires a cluster role.

extraRules object[]

ExtraRules will add rules to the cluster role.

overwriteRules object[]

OverwriteRules will overwrite the cluster role rules completely.

enableVolumeSnapshotRules object
1 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

plugins Record<string, object>

Define which vCluster plugins to load.

experimental object
7 nested properties
deploy object
2 nested properties
host object
2 nested properties
manifests string

Manifests are raw Kubernetes manifests that should get applied within the host cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the host cluster.

vcluster object
3 nested properties
manifests string

Manifests are raw Kubernetes manifests that should get applied within the virtual cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the virtual cluster.

Helm are Helm charts that should get deployed into the virtual cluster

syncSettings object
3 nested properties
setOwner boolean

SetOwner specifies if vCluster should set an owner reference on the synced objects to the vCluster service. This allows for easy garbage collection.

hostMetricsBindAddress string

HostMetricsBindAddress is the bind address for the local manager

virtualMetricsBindAddress string

VirtualMetricsBindAddress is the bind address for the virtual manager

virtualClusterKubeConfig object
5 nested properties
kubeConfig string

KubeConfig is the virtual cluster kubeconfig path.

serverCAKey string

ServerCAKey is the server ca key path.

serverCACert string

ServerCAKey is the server ca cert path.

clientCACert string

ServerCAKey is the client ca cert path.

requestHeaderCACert string

RequestHeaderCACert is the request header ca cert path.

denyProxyRequests DenyRule[]

DenyProxyRequests denies certain requests in the vCluster proxy.

proxy object
1 nested properties
customResources Record<string, object>

CustomResources is a map of resource keys (format: "kind.apiGroup/version") to proxy configuration

docker object
10 nested properties
image string

Image defines the image to use for the container. Defaults to ghcr.io/loft-sh/vm-container.

ports string[]

Ports defines extra port mappings to be added to the container.

volumes string[]

Volumes defines extra volumes to be added to the container.

env string[]

Env defines extra environment variables to be added to the container. Use key=value.

args string[]

Args defines extra arguments to be added to the docker run command of the container.

enabled boolean

Enabled defines if the vCluster was deployed using Docker. This is automatically set by vCluster and should not be set by the user.

network string

Network defines the network to use for the vCluster. If not specified, the a network will be created for the vCluster.

Nodes defines the nodes of the vCluster.

registryProxy object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

loadBalancer object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

forwardPorts boolean

ForwardPorts defines if the load balancer ips should be made available locally via port forwarding. This will be only done if necessary for example on macos when using docker desktop.

NodeMonitors allows you to create a service monitor for each node.

telemetry object
5 nested properties
enabled boolean

Enabled specifies that the telemetry for the vCluster control plane should be enabled.

instanceCreator string
machineID string
platformUserID string
platformInstanceID string
serviceCIDR string

ServiceCIDR holds the service cidr for the virtual cluster. Do not use this option anymore.

pro boolean

Specifies whether to use vCluster Pro. This is automatically inferred in newer versions. Do not use that option anymore.

plugin Record<string, object>

Plugin specifies which vCluster plugins to enable. Use "plugins" instead. Do not use this option anymore.

logging object

Logging holds the log encoding details

1 nested properties
encoding string

Encoding specifies the format of vCluster logs, it can either be json or console.

sleep object

Sleep holds configuration for automatically putting the virtual cluster to sleep.

1 nested properties
auto object

SleepAuto holds configuration for automatic sleep and wakeup

5 nested properties
afterInactivity string

AfterInactivity represents how long a vCluster can be idle before workloads are automatically put to sleep

schedule string

Schedule represents a cron schedule for when to sleep workloads

exclude object

SleepAutoExclusion holds conifiguration for excluding workloads from sleeping by label(s)

1 nested properties
selector object
wakeup object

SleepAutoWakeup holds the cron schedule to wake workloads automatically

1 nested properties
schedule string
timezone string

Timezone specifies time zone used for scheduled sleep operations. Defaults to UTC. Accepts the same format as time.LoadLocation() in Go (https://pkg.go.dev/time#LoadLocation). The value should be a location name corresponding to a file in the IANA Time Zone database, such as "America/New_York". +optional

snapshots object

Snapshots holds configuration for automatic vCluster snapshots.

1 nested properties
auto object

SnapshotsAuto holds automatic snapshot scheduling and retention configuration

5 nested properties
schedule string

Schedule specifies a scheduled time in Cron format, see https://en.wikipedia.org/wiki/Cron for a virtual cluster snapshot to be taken +optional

timezone string

Timezone specifies time zone used for scheduled snapshot operations. Defaults to UTC. Accepts the same format as time.LoadLocation() in Go (https://pkg.go.dev/time#LoadLocation). The value should be a location name corresponding to a file in the IANA Time Zone database, such as "America/New_York". +optional

retention object

SnapshotRetention holds snapshot retention configuration

2 nested properties
period integer

Period defines the number of days a snapshot will be kept +optional

maxSnapshots integer

MaxSnapshots defines the number of snapshots that can be taken +optional

storage object

SnapshotStorage holds snapshot storage configuration

4 nested properties
type string

Type specifies supported type of storage services for a snapshot S3/OCI/Container, see https://www.vcluster.com/docs/vcluster/manage/backup-restore#store-snapshots-in-s3-buckets +optional

s3 object

SnapshotStorageS3 holds S3 storage configuration

oci object

SnapshotStorageOCI holds OCI registry storage configuration

container object

SnapshotStorageContainer holds container local storage configuration

volumes object

SnapshotVolumes holds volume snapshot configuration

1 nested properties
enabled boolean

Enabled specifies whether a snapshot should also include volumes in the snapshot +optional

deletion object

Deletion holds configuration for automatic vCluster deletion.

2 nested properties
prevent boolean

Prevent prevents the vCluster from being deleted +optional

auto object

DeletionAuto holds automatic deletion configuration

1 nested properties
afterInactivity string

AfterInactivity specifies after how long of inactivity the virtual cluster will be deleted. Uses Go duration format (e.g., "720h" for 30 days). +optional

platform object

Platform holds vCluster Platform specific configuration.

2 nested properties
apiKey object

PlatformAPIKey defines where to find the platform access key.

3 nested properties
secretName string

SecretName is the name of the secret where the platform access key is stored. This defaults to vcluster-platform-api-key if undefined. +optional

namespace string

Namespace defines the namespace where the access key secret should be retrieved from. If this is not equal to the namespace where the vCluster instance is deployed, you need to make sure vCluster has access to this other namespace. +optional

createRBAC boolean

CreateRBAC will automatically create the necessary RBAC roles and role bindings to allow vCluster to read the secret specified in the above namespace, if specified. This defaults to true. +optional

project string

Project specifies which platform project the vcluster should be imported to +optional

Definitions

APIService object

APIService holds configuration related to the api server

service object

APIServiceService holds the service name and namespace of the host apiservice.

3 nested properties
name string

Name is the name of the host service of the apiservice.

namespace string

Namespace is the name of the host service of the apiservice.

port integer

Port is the target port on the host service to connect to.

APIServiceService object

APIServiceService holds the service name and namespace of the host apiservice.

name string

Name is the name of the host service of the apiservice.

namespace string

Namespace is the name of the host service of the apiservice.

port integer

Port is the target port on the host service to connect to.

AutoUpgrade object
enabled boolean

Enabled defines if auto upgrade should be enabled.

image string

Image is the image for the auto upgrade pod started by vCluster. If empty defaults to the controlPlane.statefulSet.image.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the auto upgrade. If empty will select all worker nodes.

binariesPath string

BinariesPath is the base path for the kubeadm binaries. Defaults to /usr/local/bin

cniBinariesPath string

CNIBinariesPath is the base path for the CNI binaries. Defaults to /opt/cni/bin

concurrency integer

Concurrency is the number of nodes that can be upgraded at the same time.

BackingStore object
etcd object
3 nested properties
embedded object
4 nested properties
enabled boolean

Enabled defines if the embedded etcd should be used.

migrateFromDeployedEtcd boolean

MigrateFromDeployedEtcd signals that vCluster should migrate from the deployed external etcd to embedded etcd.

snapshotCount integer

SnapshotCount defines the number of snapshots to keep for the embedded etcd. Defaults to 10000 if less than 1.

extraArgs string[]

ExtraArgs are additional arguments to pass to the embedded etcd.

deploy object
4 nested properties
enabled boolean

Enabled defines that an external etcd should be deployed.

statefulSet object
service object
headlessService object
external object
3 nested properties
enabled boolean

Enabled defines if the external etcd should be used.

endpoint string

Endpoint holds the endpoint of the external etcd server, e.g. my-example-service:2379

tls object

EtcdExternalTLS defines tls for external etcd server

database object
2 nested properties
embedded object
7 nested properties
enabled boolean

Enabled defines if the database should be used.

dataSource string

DataSource is the kine dataSource to use for the database. This depends on the database format. This is optional for the external database. Examples:

  • mysql: mysql://username:password@tcp(hostname:3306)/vcluster
  • postgres: postgres://username:password@hostname:5432/vcluster
identityProvider string

IdentityProvider is the kine identity provider to use when generating temporary authentication tokens for enhanced security. This is optional for the external database. Examples:

  • aws: RDS IAM Authentication
keyFile string

KeyFile is the key file to use for the database. This is optional.

certFile string

CertFile is the cert file to use for the database. This is optional.

caFile string

CaFile is the ca file to use for the database. This is optional.

extraArgs string[]

ExtraArgs are additional arguments to pass to Kine.

external object
8 nested properties
enabled boolean

Enabled defines if the database should be used.

dataSource string

DataSource is the kine dataSource to use for the database. This depends on the database format. This is optional for the external database. Examples:

  • mysql: mysql://username:password@tcp(hostname:3306)/vcluster
  • postgres: postgres://username:password@hostname:5432/vcluster
identityProvider string

IdentityProvider is the kine identity provider to use when generating temporary authentication tokens for enhanced security. This is optional for the external database. Examples:

  • aws: RDS IAM Authentication
keyFile string

KeyFile is the key file to use for the database. This is optional.

certFile string

CertFile is the cert file to use for the database. This is optional.

caFile string

CaFile is the ca file to use for the database. This is optional.

extraArgs string[]

ExtraArgs are additional arguments to pass to Kine.

connector string

Connector specifies a secret located in a connected vCluster Platform that contains database server connection information to be used by Platform to create a database and database user for the vCluster. and non-privileged user. A kine endpoint should be created using the database and user on Platform registration. This is optional.

CNI object
flannel object
4 nested properties
enabled boolean

Enabled defines if Flannel should be enabled.

image string

Image is the image for Flannel main container.

initImage string

InitImage is the image for Flannel init container.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

CNIFlannel object
enabled boolean

Enabled defines if Flannel should be enabled.

image string

Image is the image for Flannel main container.

initImage string

InitImage is the image for Flannel init container.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

CentralAdmission object

ValidatingWebhooks are validating webhooks that should be enforced in the virtual cluster

MutatingWebhooks are mutating webhooks that should be enforced in the virtual cluster

CertManager object

CertManager reuses a host cert-manager and makes its CRDs from it available inside the vCluster

enabled boolean

Enabled defines if this option should be enabled.

sync object
2 nested properties
toHost object
2 nested properties
certificates object
issuers object
fromHost object
1 nested properties
clusterIssuers object
CertManagerSync object
toHost object
2 nested properties
certificates object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

issuers object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

fromHost object
1 nested properties
clusterIssuers object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

selector object
CertManagerSyncFromHost object
clusterIssuers object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

selector object
1 nested properties
labels Record<string, string>

Labels defines what labels should be looked for

CertManagerSyncToHost object
certificates object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

issuers object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

CloudControllerManager object
enabled boolean

Enabled defines if the embedded cloud controller manager should be enabled. This defaults to true, but can be disabled if you want to use an external cloud controller manager such as AWS or GCP. The cloud controller manager is responsible for setting the node's ip addresses as well as the provider id for the node and other node metadata.

ClusterIssuersSyncConfig object
enabled boolean

Enabled defines if this option should be enabled.

selector object
1 nested properties
labels Record<string, string>

Labels defines what labels should be looked for

ContainerdJoin object
enabled boolean

Enabled defines if containerd should be installed and configured by vCluster.

registry object
3 nested properties
configPath string

ConfigPath is the path to the containerd registry config.

mirrors Record<string, object>

Mirrors holds configuration for the containerd registry mirrors. E.g. myregistry.io:5000 or docker.io. See https://github.com/containerd/containerd/blob/main/docs/hosts.md for more details.

auth Record<string, object>

Auth holds configuration for the containerd registry auth. See https://github.com/containerd/containerd/blob/main/docs/cri/registry.md#configure-registry-credentials for more details.

pauseImage string

PauseImage is the image for the pause container.

ContainerdMirror object
server string

Server is the fallback server to use for the containerd registry mirror. E.g. https://registry-1.docker.io. See https://github.com/containerd/containerd/blob/main/docs/hosts.md for more details.

caCert string[]

CACert are paths to CA certificates to use for the containerd registry mirror.

skipVerify boolean

SkipVerify is a boolean to skip the certificate verification for the containerd registry mirror and allows http connections.

capabilities string[]

Capabilities is a list of capabilities to enable for the containerd registry mirror. If empty, will use pull and resolve capabilities.

overridePath boolean

OverridePath is a boolean to override the path for the containerd registry mirror.

Hosts holds configuration for the containerd registry mirror hosts. See https://github.com/containerd/containerd/blob/main/docs/hosts.md for more details.

ContainerdMirrorHost object
server string

Server is the server to use for the containerd registry mirror host. E.g. http://192.168.31.250:5000.

caCert string[]

CACert are paths to CA certificates to use for the containerd registry mirror host.

skipVerify boolean

SkipVerify is a boolean to skip the certificate verification for the containerd registry mirror and allows http connections.

capabilities string[]

Capabilities is a list of capabilities to enable for the containerd registry mirror. If empty, will use pull and resolve capabilities.

overridePath boolean

OverridePath is a boolean to override the path for the containerd registry mirror.

ContainerdRegistry object
configPath string

ConfigPath is the path to the containerd registry config.

mirrors Record<string, object>

Mirrors holds configuration for the containerd registry mirrors. E.g. myregistry.io:5000 or docker.io. See https://github.com/containerd/containerd/blob/main/docs/hosts.md for more details.

auth Record<string, object>

Auth holds configuration for the containerd registry auth. See https://github.com/containerd/containerd/blob/main/docs/cri/registry.md#configure-registry-credentials for more details.

ContainerdRegistryAuth object
username string

Username is the username for the containerd registry.

password string

Password is the password for the containerd registry.

identityToken string

IdentityToken is the token for the containerd registry.

auth string

Auth is the auth config for the containerd registry.

ControlPlane object
endpoint string

Endpoint is the endpoint of the virtual cluster. This is used to connect to the virtual cluster.

distro object
1 nested properties
k8s object
10 nested properties
enabled boolean

Enabled specifies if the K8s distro should be enabled. Only one distro can be enabled at the same time.

version string

Version is the Kubernetes version to use.

apiServer object
controllerManager object
scheduler object
image object
imagePullPolicy string

ImagePullPolicy is the pull policy for the distro image

env object[]

Env are extra environment variables to use for the main container and NOT the init container.

resources object

Resources for the distro init container

securityContext object

Security options can be used for the distro init container

standalone object
4 nested properties
enabled boolean

Enabled defines if standalone mode should be enabled.

dataDir string

DataDir defines the data directory for the standalone mode.

autoNodes object
3 nested properties
provider string

Provider is the node provider of the nodes in this pool.

quantity integer

Quantity is the number of nodes to deploy for standalone mode.

nodeTypeSelector Requirement[]

NodeTypeSelector filters the types of nodes that can be provisioned by this pool. All requirements must be met for a node type to be eligible.

joinNode object
8 nested properties
enabled boolean

Enabled defines if the standalone node should be joined into the cluster. If false, only the control plane binaries will be executed and no node will show up in the actual cluster.

preInstallCommands string[]

PreInstallCommands are commands that will be executed before containerd, kubelet etc. is installed.

preJoinCommands string[]

PreJoinCommands are commands that will be executed before kubeadm join is executed.

postJoinCommands string[]

PostJoinCommands are commands that will be executed after kubeadm join is executed.

containerd object
caCertPath string

CACertPath is the path to the SSL certificate authority used to secure communications between node and control-plane. Defaults to "/etc/kubernetes/pki/ca.crt".

skipPhases string[]

SkipPhases is a list of phases to skip during command execution. The list of phases can be obtained with the "kubeadm join --help" command.

nodeRegistration object
backingStore object
2 nested properties
etcd object
3 nested properties
embedded object
deploy object
external object
database object
2 nested properties
embedded object
external object
coredns object
8 nested properties
enabled boolean

Enabled defines if coredns is enabled

embedded boolean

Embedded defines if vCluster will start the embedded coredns service within the control-plane and not as a separate deployment. This is a PRO feature.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

service object
3 nested properties
spec object

Spec holds extra options for the coredns service

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

deployment object
10 nested properties
image string

Image is the coredns image to use

replicas integer

Replicas is the amount of coredns pods to run.

nodeSelector Record<string, string>

NodeSelector is the node selector to use for coredns.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

resources object
pods object
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the CoreDNS pod.

overwriteConfig string

OverwriteConfig can be used to overwrite the coredns config

overwriteManifests string

OverwriteManifests can be used to overwrite the coredns manifests used to deploy coredns

priorityClassName string

PriorityClassName specifies the priority class name for the CoreDNS pods.

proxy object
3 nested properties
bindAddress string

BindAddress under which vCluster will expose the proxy.

port integer

Port under which vCluster will expose the proxy. Changing port is currently not supported.

extraSANs string[]

ExtraSANs are extra hostnames to sign the vCluster proxy certificate for.

hostPathMapper object
2 nested properties
enabled boolean

Enabled specifies if the host path mapper will be used

central boolean

Central specifies if the central host path mapper will be used

ingress object
6 nested properties
enabled boolean

Enabled defines if the control plane ingress should be enabled

host string

Host is the host where vCluster will be reachable

pathType string

PathType is the path type of the ingress

spec object

Spec allows you to configure extra ingress options.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

tlsRoute object
7 nested properties
enabled boolean

Enabled defines if the control plane should be exposed via a gateway api tls route. Make sure to enable tls passthrough in the gateway via tls.mode to "Passthrough"

apiVersion string

APIVersion is the version of the gateway api tls route.

host string

Host is the host where vCluster will be reachable

parentRefs object[]

ParentRefs are the parent references for the TLS route

spec object

Spec allows you to configure extra tls route options.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

service object
6 nested properties
enabled boolean

Enabled defines if the control plane service should be enabled

spec object

Spec allows you to configure extra service options.

kubeletNodePort integer

KubeletNodePort is the node port where the fake kubelet is exposed. Defaults to 0.

httpsNodePort integer

HTTPSNodePort is the node port where https is exposed. Defaults to 0.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

statefulSet object
22 nested properties
highAvailability object
4 nested properties
replicas integer

Replicas is the amount of replicas to use for the statefulSet.

leaseDuration integer

LeaseDuration is the time to lease for the leader.

renewDeadline integer

RenewDeadline is the deadline to renew a lease for the leader.

retryPeriod integer

RetryPeriod is the time until a replica will retry to get a lease.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

scheduling object
6 nested properties
nodeSelector object

NodeSelector is the node selector to apply to the pod.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

priorityClassName string

PriorityClassName is the priority class name for the the pod.

podManagementPolicy string

PodManagementPolicy is the statefulSet pod management policy.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the pod.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

probes object
3 nested properties
livenessProbe object

LivenessProbe defines the configuration for the liveness probe.

readinessProbe object

ReadinessProbe defines the configuration for the readiness probe.

startupProbe object

StartupProbe defines the configuration for the startup probe.

persistence object
6 nested properties
volumeClaim object
volumeClaimTemplates object[]

VolumeClaimTemplates defines the volumeClaimTemplates for the statefulSet

dataVolume object[]

Allows you to override the dataVolume. Only works correctly if volumeClaim.enabled=false.

binariesVolume object[]

BinariesVolume defines a binaries volume that is used to retrieve distro specific executables to be run by the syncer controller. This volume doesn't need to be persistent.

addVolumes object[]

AddVolumes defines extra volumes for the pod

addVolumeMounts VolumeMount[]

AddVolumeMounts defines extra volume mounts for the container

enableServiceLinks boolean

EnableServiceLinks for the StatefulSet pod

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

pods object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

workingDir string

WorkingDir specifies in what folder the main process should get started.

command string[]

Command allows you to override the main command.

args string[]

Args allows you to override the main arguments.

env object[]

Env are additional environment variables for the statefulSet container.

dnsPolicy string

Set DNS policy for the pod.

dnsConfig object

PodDNSConfig defines the DNS parameters of a pod in addition to those generated from DNSPolicy.

3 nested properties
nameservers string[]

A list of DNS name server IP addresses. This will be appended to the base nameservers generated from DNSPolicy. Duplicated nameservers will be removed. +optional +listType=atomic

searches string[]

A list of DNS search domains for host-name lookup. This will be appended to the base search paths generated from DNSPolicy. Duplicated search paths will be removed. +optional +listType=atomic

A list of DNS resolver options. This will be merged with the base options generated from DNSPolicy. Duplicated entries will be removed. Resolution options given in Options will override those that appear in the base DNSPolicy. +optional +listType=atomic

initContainers array

InitContainers are additional init containers for the statefulSet.

sidecarContainers array

SidecarContainers are additional sidecar containers for the statefulSet.

hostAliases HostAlias[]

HostAliases allows you to add custom entries to the /etc/hosts file of each Pod created.

runtimeClassName string

RuntimeClassName is the runtime class to set for the statefulSet pods.

serviceMonitor object
3 nested properties
enabled boolean

Enabled configures if Helm should create the service monitor.

labels Record<string, string>

Labels are the extra labels to add to the service monitor.

annotations Record<string, string>

Annotations are the extra annotations to add to the service monitor.

advanced object
11 nested properties
defaultImageRegistry string

DefaultImageRegistry will be used as a prefix for all internal images deployed by vCluster or Helm. This makes it easy to upload all required vCluster images to a single private repository and set this value. Workload images are not affected by this.

virtualScheduler object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

serviceAccount object
5 nested properties
enabled boolean

Enabled specifies if the service account should get deployed.

name string

Name specifies what name to use for the service account.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

workloadServiceAccount object
5 nested properties
enabled boolean

Enabled specifies if the service account for the workloads should get deployed.

name string

Name specifies what name to use for the service account for the virtual cluster workloads.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the workload service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

headlessService object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

konnectivity object
2 nested properties
server object
agent object
registry object
3 nested properties
enabled boolean

Enabled defines if the embedded registry should be enabled.

anonymousPull boolean

AnonymousPull allows enabling anonymous pull for the embedded registry. This allows anybody to pull images from the registry without authentication.

config

Config is the regular docker registry config. See https://distribution.github.io/distribution/about/configuration/ for more details.

cloudControllerManager object
1 nested properties
enabled boolean

Enabled defines if the embedded cloud controller manager should be enabled. This defaults to true, but can be disabled if you want to use an external cloud controller manager such as AWS or GCP. The cloud controller manager is responsible for setting the node's ip addresses as well as the provider id for the node and other node metadata.

globalMetadata object
1 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

kubeVip object
3 nested properties
enabled boolean

Enabled defines if embedded kube-vip should be enabled.

interface string

Interface is the network interface on which the VIP is announced.

gateway string

Gateway is the gateway address in CIDR notation (e.g., 10.100.0.1/24). This is used to configure policy-based routing for the VIP and must include the subnet prefix.

podDisruptionBudget object
4 nested properties
enabled boolean

Enabled defines if the pod disruption budget should be enabled.

minAvailable

MinAvailable describes the minimal number or percentage of available pods.

maxUnavailable

MaxUnavailable describes the minimal number or percentage of unavailable pods.

unhealthyPodEvictionPolicy string

UnhealthyPodEvictionPolicy defines the criteria when unhealthy pods should be considered for eviction. Currently supported values are:

  • IfHealthyBudget - pods that are in the Running phase but not yet healthy are considered disrupted and may be evicted even if the PodDisruptionBudget criteria are not met.
  • AlwaysAllow - pods that are in the Running phase but not yet healthy are considered disrupted and can be evicted regardless of whether the criteria in a PDB is met.
ControlPlaneAdvanced object
defaultImageRegistry string

DefaultImageRegistry will be used as a prefix for all internal images deployed by vCluster or Helm. This makes it easy to upload all required vCluster images to a single private repository and set this value. Workload images are not affected by this.

virtualScheduler object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

serviceAccount object
5 nested properties
enabled boolean

Enabled specifies if the service account should get deployed.

name string

Name specifies what name to use for the service account.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

workloadServiceAccount object
5 nested properties
enabled boolean

Enabled specifies if the service account for the workloads should get deployed.

name string

Name specifies what name to use for the service account for the virtual cluster workloads.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the workload service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

headlessService object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

konnectivity object
2 nested properties
server object
2 nested properties
enabled boolean

Enabled defines if the konnectivity server should be enabled.

extraArgs string[]

ExtraArgs are additional arguments to pass to the konnectivity server.

agent object
9 nested properties
enabled boolean

Enabled defines if the konnectivity agent should be enabled.

replicas integer

Replicas is the number of replicas for the konnectivity agent.

image string

Image is the image for the konnectivity agent.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the konnectivity agent.

priorityClassName string

PriorityClassName is the priority class name for the konnectivity agent.

tolerations array

Tolerations is the tolerations for the konnectivity agent.

extraEnv array

ExtraEnv is the extra environment variables for the konnectivity agent.

extraArgs string[]

ExtraArgs are additional arguments to pass to the konnectivity agent.

registry object
3 nested properties
enabled boolean

Enabled defines if the embedded registry should be enabled.

anonymousPull boolean

AnonymousPull allows enabling anonymous pull for the embedded registry. This allows anybody to pull images from the registry without authentication.

config

Config is the regular docker registry config. See https://distribution.github.io/distribution/about/configuration/ for more details.

cloudControllerManager object
1 nested properties
enabled boolean

Enabled defines if the embedded cloud controller manager should be enabled. This defaults to true, but can be disabled if you want to use an external cloud controller manager such as AWS or GCP. The cloud controller manager is responsible for setting the node's ip addresses as well as the provider id for the node and other node metadata.

globalMetadata object
1 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

kubeVip object
3 nested properties
enabled boolean

Enabled defines if embedded kube-vip should be enabled.

interface string

Interface is the network interface on which the VIP is announced.

gateway string

Gateway is the gateway address in CIDR notation (e.g., 10.100.0.1/24). This is used to configure policy-based routing for the VIP and must include the subnet prefix.

podDisruptionBudget object
4 nested properties
enabled boolean

Enabled defines if the pod disruption budget should be enabled.

minAvailable

MinAvailable describes the minimal number or percentage of available pods.

maxUnavailable

MaxUnavailable describes the minimal number or percentage of unavailable pods.

unhealthyPodEvictionPolicy string

UnhealthyPodEvictionPolicy defines the criteria when unhealthy pods should be considered for eviction. Currently supported values are:

  • IfHealthyBudget - pods that are in the Running phase but not yet healthy are considered disrupted and may be evicted even if the PodDisruptionBudget criteria are not met.
  • AlwaysAllow - pods that are in the Running phase but not yet healthy are considered disrupted and can be evicted regardless of whether the criteria in a PDB is met.
ControlPlaneGlobalMetadata object
annotations Record<string, string>

Annotations are extra annotations for this resource.

ControlPlaneHeadlessService object
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

ControlPlaneHighAvailability object
replicas integer

Replicas is the amount of replicas to use for the statefulSet.

leaseDuration integer

LeaseDuration is the time to lease for the leader.

renewDeadline integer

RenewDeadline is the deadline to renew a lease for the leader.

retryPeriod integer

RetryPeriod is the time until a replica will retry to get a lease.

ControlPlaneIngress object
enabled boolean

Enabled defines if the control plane ingress should be enabled

host string

Host is the host where vCluster will be reachable

pathType string

PathType is the path type of the ingress

spec object

Spec allows you to configure extra ingress options.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

ControlPlanePersistence object
volumeClaim object
5 nested properties
enabled string | boolean

Enabled enables deploying a persistent volume claim. If auto, vCluster will automatically determine based on the chosen distro and other options if this is required.

accessModes string[]

AccessModes are the persistent volume claim access modes.

retentionPolicy string

RetentionPolicy is the persistent volume claim retention policy.

size string

Size is the persistent volume claim storage size.

storageClass string

StorageClass is the persistent volume claim storage class.

volumeClaimTemplates object[]

VolumeClaimTemplates defines the volumeClaimTemplates for the statefulSet

dataVolume object[]

Allows you to override the dataVolume. Only works correctly if volumeClaim.enabled=false.

binariesVolume object[]

BinariesVolume defines a binaries volume that is used to retrieve distro specific executables to be run by the syncer controller. This volume doesn't need to be persistent.

addVolumes object[]

AddVolumes defines extra volumes for the pod

addVolumeMounts VolumeMount[]

AddVolumeMounts defines extra volume mounts for the container

ControlPlaneProbes object
livenessProbe object

LivenessProbe defines the configuration for the liveness probe.

5 nested properties
enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures for the probe to be considered failed

initialDelaySeconds integer

Time (in seconds) to wait before starting the liveness probe

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

readinessProbe object

ReadinessProbe defines the configuration for the readiness probe.

4 nested properties
enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures for the probe to be considered failed

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

startupProbe object

StartupProbe defines the configuration for the startup probe.

4 nested properties
enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures allowed before failing the pod

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

ControlPlaneProxy object
bindAddress string

BindAddress under which vCluster will expose the proxy.

port integer

Port under which vCluster will expose the proxy. Changing port is currently not supported.

extraSANs string[]

ExtraSANs are extra hostnames to sign the vCluster proxy certificate for.

ControlPlaneScheduling object
nodeSelector object

NodeSelector is the node selector to apply to the pod.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

priorityClassName string

PriorityClassName is the priority class name for the the pod.

podManagementPolicy string

PodManagementPolicy is the statefulSet pod management policy.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the pod.

ControlPlaneSecurity object
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

ControlPlaneService object
enabled boolean

Enabled defines if the control plane service should be enabled

spec object

Spec allows you to configure extra service options.

kubeletNodePort integer

KubeletNodePort is the node port where the fake kubelet is exposed. Defaults to 0.

httpsNodePort integer

HTTPSNodePort is the node port where https is exposed. Defaults to 0.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

ControlPlaneServiceAccount object
enabled boolean

Enabled specifies if the service account should get deployed.

name string

Name specifies what name to use for the service account.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

ControlPlaneStatefulSet object
highAvailability object
4 nested properties
replicas integer

Replicas is the amount of replicas to use for the statefulSet.

leaseDuration integer

LeaseDuration is the time to lease for the leader.

renewDeadline integer

RenewDeadline is the deadline to renew a lease for the leader.

retryPeriod integer

RetryPeriod is the time until a replica will retry to get a lease.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

scheduling object
6 nested properties
nodeSelector object

NodeSelector is the node selector to apply to the pod.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

priorityClassName string

PriorityClassName is the priority class name for the the pod.

podManagementPolicy string

PodManagementPolicy is the statefulSet pod management policy.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the pod.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

probes object
3 nested properties
livenessProbe object

LivenessProbe defines the configuration for the liveness probe.

5 nested properties
enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures for the probe to be considered failed

initialDelaySeconds integer

Time (in seconds) to wait before starting the liveness probe

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

readinessProbe object

ReadinessProbe defines the configuration for the readiness probe.

4 nested properties
enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures for the probe to be considered failed

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

startupProbe object

StartupProbe defines the configuration for the startup probe.

4 nested properties
enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures allowed before failing the pod

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

persistence object
6 nested properties
volumeClaim object
5 nested properties
enabled string | boolean

Enabled enables deploying a persistent volume claim. If auto, vCluster will automatically determine based on the chosen distro and other options if this is required.

accessModes string[]

AccessModes are the persistent volume claim access modes.

retentionPolicy string

RetentionPolicy is the persistent volume claim retention policy.

size string

Size is the persistent volume claim storage size.

storageClass string

StorageClass is the persistent volume claim storage class.

volumeClaimTemplates object[]

VolumeClaimTemplates defines the volumeClaimTemplates for the statefulSet

dataVolume object[]

Allows you to override the dataVolume. Only works correctly if volumeClaim.enabled=false.

binariesVolume object[]

BinariesVolume defines a binaries volume that is used to retrieve distro specific executables to be run by the syncer controller. This volume doesn't need to be persistent.

addVolumes object[]

AddVolumes defines extra volumes for the pod

addVolumeMounts VolumeMount[]

AddVolumeMounts defines extra volume mounts for the container

enableServiceLinks boolean

EnableServiceLinks for the StatefulSet pod

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

pods object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

workingDir string

WorkingDir specifies in what folder the main process should get started.

command string[]

Command allows you to override the main command.

args string[]

Args allows you to override the main arguments.

env object[]

Env are additional environment variables for the statefulSet container.

dnsPolicy string

Set DNS policy for the pod.

dnsConfig object

PodDNSConfig defines the DNS parameters of a pod in addition to those generated from DNSPolicy.

3 nested properties
nameservers string[]

A list of DNS name server IP addresses. This will be appended to the base nameservers generated from DNSPolicy. Duplicated nameservers will be removed. +optional +listType=atomic

searches string[]

A list of DNS search domains for host-name lookup. This will be appended to the base search paths generated from DNSPolicy. Duplicated search paths will be removed. +optional +listType=atomic

A list of DNS resolver options. This will be merged with the base options generated from DNSPolicy. Duplicated entries will be removed. Resolution options given in Options will override those that appear in the base DNSPolicy. +optional +listType=atomic

initContainers array

InitContainers are additional init containers for the statefulSet.

sidecarContainers array

SidecarContainers are additional sidecar containers for the statefulSet.

hostAliases HostAlias[]

HostAliases allows you to add custom entries to the /etc/hosts file of each Pod created.

runtimeClassName string

RuntimeClassName is the runtime class to set for the statefulSet pods.

ControlPlaneTLSRoute object
enabled boolean

Enabled defines if the control plane should be exposed via a gateway api tls route. Make sure to enable tls passthrough in the gateway via tls.mode to "Passthrough"

apiVersion string

APIVersion is the version of the gateway api tls route.

host string

Host is the host where vCluster will be reachable

parentRefs object[]

ParentRefs are the parent references for the TLS route

spec object

Spec allows you to configure extra tls route options.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

ControlPlaneWorkloadServiceAccount object
enabled boolean

Enabled specifies if the service account for the workloads should get deployed.

name string

Name specifies what name to use for the service account for the virtual cluster workloads.

imagePullSecrets ImagePullSecretName[]

ImagePullSecrets defines extra image pull secrets for the workload service account.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

CoreDNS object
enabled boolean

Enabled defines if coredns is enabled

embedded boolean

Embedded defines if vCluster will start the embedded coredns service within the control-plane and not as a separate deployment. This is a PRO feature.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

service object
3 nested properties
spec object

Spec holds extra options for the coredns service

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

deployment object
10 nested properties
image string

Image is the coredns image to use

replicas integer

Replicas is the amount of coredns pods to run.

nodeSelector Record<string, string>

NodeSelector is the node selector to use for coredns.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

pods object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the CoreDNS pod.

overwriteConfig string

OverwriteConfig can be used to overwrite the coredns config

overwriteManifests string

OverwriteManifests can be used to overwrite the coredns manifests used to deploy coredns

priorityClassName string

PriorityClassName specifies the priority class name for the CoreDNS pods.

CoreDNSDeployment object
image string

Image is the coredns image to use

replicas integer

Replicas is the amount of coredns pods to run.

nodeSelector Record<string, string>

NodeSelector is the node selector to use for coredns.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

pods object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the CoreDNS pod.

CoreDNSService object
spec object

Spec holds extra options for the coredns service

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

CustomResourceProxy object
enabled boolean

Enabled defines if this resource proxy should be enabled

targetVirtualCluster object

VirtualClusterRef is a reference to a virtual cluster within the platform.

2 nested properties
name string required

Name is the name of the target virtual cluster.

minLength=1pattern=^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
project string

Project is the project of the target virtual cluster. If empty, defaults to the same project as the source vCluster.

pattern=^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
accessResources string

AccessResources defines which resources should be accessible in the proxy.

Database object
embedded object
7 nested properties
enabled boolean

Enabled defines if the database should be used.

dataSource string

DataSource is the kine dataSource to use for the database. This depends on the database format. This is optional for the external database. Examples:

  • mysql: mysql://username:password@tcp(hostname:3306)/vcluster
  • postgres: postgres://username:password@hostname:5432/vcluster
identityProvider string

IdentityProvider is the kine identity provider to use when generating temporary authentication tokens for enhanced security. This is optional for the external database. Examples:

  • aws: RDS IAM Authentication
keyFile string

KeyFile is the key file to use for the database. This is optional.

certFile string

CertFile is the cert file to use for the database. This is optional.

caFile string

CaFile is the ca file to use for the database. This is optional.

extraArgs string[]

ExtraArgs are additional arguments to pass to Kine.

external object
8 nested properties
enabled boolean

Enabled defines if the database should be used.

dataSource string

DataSource is the kine dataSource to use for the database. This depends on the database format. This is optional for the external database. Examples:

  • mysql: mysql://username:password@tcp(hostname:3306)/vcluster
  • postgres: postgres://username:password@hostname:5432/vcluster
identityProvider string

IdentityProvider is the kine identity provider to use when generating temporary authentication tokens for enhanced security. This is optional for the external database. Examples:

  • aws: RDS IAM Authentication
keyFile string

KeyFile is the key file to use for the database. This is optional.

certFile string

CertFile is the cert file to use for the database. This is optional.

caFile string

CaFile is the ca file to use for the database. This is optional.

extraArgs string[]

ExtraArgs are additional arguments to pass to Kine.

connector string

Connector specifies a secret located in a connected vCluster Platform that contains database server connection information to be used by Platform to create a database and database user for the vCluster. and non-privileged user. A kine endpoint should be created using the database and user on Platform registration. This is optional.

DatabaseKine object
enabled boolean

Enabled defines if the database should be used.

dataSource string

DataSource is the kine dataSource to use for the database. This depends on the database format. This is optional for the external database. Examples:

  • mysql: mysql://username:password@tcp(hostname:3306)/vcluster
  • postgres: postgres://username:password@hostname:5432/vcluster
identityProvider string

IdentityProvider is the kine identity provider to use when generating temporary authentication tokens for enhanced security. This is optional for the external database. Examples:

  • aws: RDS IAM Authentication
keyFile string

KeyFile is the key file to use for the database. This is optional.

certFile string

CertFile is the cert file to use for the database. This is optional.

caFile string

CaFile is the ca file to use for the database. This is optional.

extraArgs string[]

ExtraArgs are additional arguments to pass to Kine.

Deletion object

Deletion holds configuration for automatic vCluster deletion.

prevent boolean

Prevent prevents the vCluster from being deleted +optional

auto object

DeletionAuto holds automatic deletion configuration

1 nested properties
afterInactivity string

AfterInactivity specifies after how long of inactivity the virtual cluster will be deleted. Uses Go duration format (e.g., "720h" for 30 days). +optional

DeletionAuto object

DeletionAuto holds automatic deletion configuration

afterInactivity string

AfterInactivity specifies after how long of inactivity the virtual cluster will be deleted. Uses Go duration format (e.g., "720h" for 30 days). +optional

DenyRule object
name string

The name of the check.

namespaces string[]

Namespace describe a list of namespaces that will be affected by the check. An empty list means that all namespaces will be affected. In case of ClusterScoped rules, only the Namespace resource is affected.

Rules describes on which verbs and on what resources/subresources the webhook is enforced. The webhook is enforced if it matches any Rule. The version of the request must match the rule version exactly. Equivalent matching is not supported.

excludedUsers string[]

ExcludedUsers describe a list of users for which the checks will be skipped. Impersonation attempts on these users will still be subjected to the checks.

Deploy object
kubeProxy object
9 nested properties
enabled boolean

Enabled defines if the kube proxy should be enabled.

image string

Image is the image for the kube-proxy.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the kube-proxy.

priorityClassName string

PriorityClassName is the priority class name for the kube-proxy.

tolerations array

Tolerations is the tolerations for the kube-proxy.

extraEnv array

ExtraEnv is the extra environment variables for the kube-proxy.

extraArgs string[]

ExtraArgs are additional arguments to pass to the kube-proxy.

config object

Config is the config for the kube-proxy that will be merged into the default kube-proxy config. More information can be found here: https://kubernetes.io/docs/reference/config-api/kube-proxy-config.v1alpha1/#kubeproxy-config-k8s-io-v1alpha1-KubeProxyConfiguration

metallb object
4 nested properties
enabled boolean

Enabled defines if metallb should be enabled.

controllerImage string

ControllerImage is the image for metallb controller.

speakerImage string

SpeakerImage is the image for metallb speaker.

ipAddressPool object
2 nested properties
addresses string[]

Addresses is a list of IP addresses to use for the IP address pool.

l2Advertisement boolean

L2Advertisement defines if L2 advertisement should be enabled for the IP address pool.

cni object
1 nested properties
flannel object
4 nested properties
enabled boolean

Enabled defines if Flannel should be enabled.

image string

Image is the image for Flannel main container.

initImage string

InitImage is the image for Flannel init container.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

localPathProvisioner object
4 nested properties
enabled boolean

Enabled defines if LocalPathProvisioner should be enabled.

image string

Image is the image for local path provisioner.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodePath string

NodePath is the path on the node where to create the persistent volume directories.

ingressNginx object
2 nested properties
enabled boolean

Enabled defines if ingress-nginx should be enabled.

defaultIngressClass boolean

DefaultIngressClass defines if the deployed ingress class should be the default ingress class.

metricsServer object
1 nested properties
enabled boolean

Enabled defines if metrics server should be enabled.

volumeSnapshotController object

VolumeSnapshotController defines CSI volumes snapshot-controller configuration.

1 nested properties
enabled boolean

Enabled defines if the CSI volumes snapshot-controller should be enabled.

DeployMetricsServer object
enabled boolean

Enabled defines if metrics server should be enabled.

Distro object
k8s object
10 nested properties
enabled boolean

Enabled specifies if the K8s distro should be enabled. Only one distro can be enabled at the same time.

version string

Version is the Kubernetes version to use.

apiServer object
3 nested properties
enabled boolean

Enabled signals this container should be enabled.

command string[]

Command is the command to start the distro binary. This will override the existing command.

extraArgs string[]

ExtraArgs are additional arguments to pass to the distro binary.

controllerManager object
3 nested properties
enabled boolean

Enabled signals this container should be enabled.

command string[]

Command is the command to start the distro binary. This will override the existing command.

extraArgs string[]

ExtraArgs are additional arguments to pass to the distro binary.

scheduler object
3 nested properties
enabled boolean

Enabled signals this container should be enabled.

command string[]

Command is the command to start the distro binary. This will override the existing command.

extraArgs string[]

ExtraArgs are additional arguments to pass to the distro binary.

image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

imagePullPolicy string

ImagePullPolicy is the pull policy for the distro image

env object[]

Env are extra environment variables to use for the main container and NOT the init container.

resources object

Resources for the distro init container

securityContext object

Security options can be used for the distro init container

DistroContainerEnabled object
enabled boolean

Enabled signals this container should be enabled.

command string[]

Command is the command to start the distro binary. This will override the existing command.

extraArgs string[]

ExtraArgs are additional arguments to pass to the distro binary.

DistroK8s object
enabled boolean

Enabled specifies if the K8s distro should be enabled. Only one distro can be enabled at the same time.

version string

Version is the Kubernetes version to use.

apiServer object
3 nested properties
enabled boolean

Enabled signals this container should be enabled.

command string[]

Command is the command to start the distro binary. This will override the existing command.

extraArgs string[]

ExtraArgs are additional arguments to pass to the distro binary.

controllerManager object
3 nested properties
enabled boolean

Enabled signals this container should be enabled.

command string[]

Command is the command to start the distro binary. This will override the existing command.

extraArgs string[]

ExtraArgs are additional arguments to pass to the distro binary.

scheduler object
3 nested properties
enabled boolean

Enabled signals this container should be enabled.

command string[]

Command is the command to start the distro binary. This will override the existing command.

extraArgs string[]

ExtraArgs are additional arguments to pass to the distro binary.

image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

imagePullPolicy string

ImagePullPolicy is the pull policy for the distro image

env object[]

Env are extra environment variables to use for the main container and NOT the init container.

resources object

Resources for the distro init container

securityContext object

Security options can be used for the distro init container

DynamicNodePool object
name string required

Name is the name of this NodePool

nodeTypeSelector Requirement[]

NodeTypeSelector filters the types of nodes that can be provisioned by this pool. All requirements must be met for a node type to be eligible.

Taints are the taints to apply to the nodes in this pool.

nodeLabels Record<string, string>

NodeLabels are the labels to apply to the nodes in this pool.

limits Record<string, string>

Limits specify the maximum resources that can be provisioned by this node pool, mapping to the 'limits' field in Karpenter's NodePool API.

disruption object
3 nested properties
consolidateAfter string

ConsolidateAfter is the duration the controller will wait before attempting to terminate nodes that are underutilized. Refer to ConsolidationPolicy for how underutilization is considered.

consolidationPolicy string

ConsolidationPolicy describes which nodes Karpenter can disrupt through its consolidation algorithm. This policy defaults to "WhenEmptyOrUnderutilized" if not specified

Budgets is a list of Budgets. If there are multiple active budgets, Karpenter uses the most restrictive value. If left undefined, this will default to one budget with a value to 10%.

terminationGracePeriod string

TerminationGracePeriod is the maximum duration the controller will wait before forcefully deleting the pods on a node, measured from when deletion is first initiated.

Warning: this feature takes precedence over a Pod's terminationGracePeriodSeconds value, and bypasses any blocked PDBs or the karpenter.sh/do-not-disrupt annotation.

This field is intended to be used by cluster administrators to enforce that nodes can be cycled within a given time period. When set, drifted nodes will begin draining even if there are pods blocking eviction. Draining will respect PDBs and the do-not-disrupt annotation until the TGP is reached.

Karpenter will preemptively delete pods so their terminationGracePeriodSeconds align with the node's terminationGracePeriod. If a pod would be terminated without being granted its full terminationGracePeriodSeconds prior to the node timeout, that pod will be deleted at T = node timeout - pod terminationGracePeriodSeconds.

The feature can also be used to allow maximum time limits for long-running jobs which can delay node termination with preStop hooks. Defaults to 30s. Set to Never to wait indefinitely for pods to be drained.

expireAfter string

The amount of time a Node can live on the cluster before being removed

weight integer

Weight is the weight of this node pool.

DynamicNodePoolDisruption object
consolidateAfter string

ConsolidateAfter is the duration the controller will wait before attempting to terminate nodes that are underutilized. Refer to ConsolidationPolicy for how underutilization is considered.

consolidationPolicy string

ConsolidationPolicy describes which nodes Karpenter can disrupt through its consolidation algorithm. This policy defaults to "WhenEmptyOrUnderutilized" if not specified

Budgets is a list of Budgets. If there are multiple active budgets, Karpenter uses the most restrictive value. If left undefined, this will default to one budget with a value to 10%.

DynamicNodePoolDisruptionBudget object
nodes string

Nodes dictates the maximum number of NodeClaims owned by this NodePool that can be terminating at once. This is calculated by counting nodes that have a deletion timestamp set, or are actively being deleted by Karpenter. This field is required when specifying a budget.

schedule string

Schedule specifies when a budget begins being active, following the upstream cronjob syntax. If omitted, the budget is always active. Timezones are not supported.

duration string

Duration determines how long a Budget is active since each Schedule hit. Only minutes and hours are accepted, as cron does not work in seconds. If omitted, the budget is always active. This is required if Schedule is set.

EnableAutoSwitch object
enabled string | boolean

Enabled defines if this option should be enabled.

EnableAutoSwitchWithPatches object
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

EnableAutoSwitchWithPatchesAndSelector object
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
EnableSwitch object
enabled boolean

Enabled defines if this option should be enabled.

EnableSwitchSelector object
selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
enabled boolean

Enabled defines if this option should be enabled.

EnableSwitchWithPatches object
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

EnableSwitchWithPatchesAndSelector object
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
EnableSwitchWithResourcesMappings object
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
1 nested properties
byName Record<string, string>

ByName is a map of host-object-namespace/host-object-name: virtual-object-namespace/virtual-object-name. There are several wildcards supported:

  1. To match all objects in host namespace and sync them to different namespace in vCluster: byName: "foo/": "foo-in-virtual/"
  2. To match specific object in the host namespace and sync it to the same namespace with the same name: byName: "foo/my-object": "foo/my-object"
  3. To match specific object in the host namespace and sync it to the same namespace with different name: byName: "foo/my-object": "foo/my-virtual-object"
  4. To match all objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "": "my-virtual-namespace/*"
  5. To match specific objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "/my-object": "my-virtual-namespace/my-object"
Etcd object
embedded object
4 nested properties
enabled boolean

Enabled defines if the embedded etcd should be used.

migrateFromDeployedEtcd boolean

MigrateFromDeployedEtcd signals that vCluster should migrate from the deployed external etcd to embedded etcd.

snapshotCount integer

SnapshotCount defines the number of snapshots to keep for the embedded etcd. Defaults to 10000 if less than 1.

extraArgs string[]

ExtraArgs are additional arguments to pass to the embedded etcd.

deploy object
4 nested properties
enabled boolean

Enabled defines that an external etcd should be deployed.

statefulSet object
14 nested properties
enabled boolean

Enabled defines if the statefulSet should be deployed

enableServiceLinks boolean

EnableServiceLinks for the StatefulSet pod

image object
imagePullPolicy string

ImagePullPolicy is the pull policy for the external etcd image

env object[]

Env are extra environment variables

extraArgs string[]

ExtraArgs are appended to the etcd command.

resources object
pods object
highAvailability object
scheduling object
security object
persistence object
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

service object
2 nested properties
enabled boolean

Enabled defines if the etcd service should be deployed

annotations Record<string, string>

Annotations are extra annotations for the external etcd service

headlessService object
1 nested properties
annotations Record<string, string>

Annotations are extra annotations for the external etcd headless service

external object
3 nested properties
enabled boolean

Enabled defines if the external etcd should be used.

endpoint string

Endpoint holds the endpoint of the external etcd server, e.g. my-example-service:2379

tls object

EtcdExternalTLS defines tls for external etcd server

3 nested properties
caFile string

CaFile is the path to the ca file

certFile string

CertFile is the path to the cert file

keyFile string

KeyFile is the path to the key file

EtcdDeploy object
enabled boolean

Enabled defines that an external etcd should be deployed.

statefulSet object
14 nested properties
enabled boolean

Enabled defines if the statefulSet should be deployed

enableServiceLinks boolean

EnableServiceLinks for the StatefulSet pod

image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

imagePullPolicy string

ImagePullPolicy is the pull policy for the external etcd image

env object[]

Env are extra environment variables

extraArgs string[]

ExtraArgs are appended to the etcd command.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

pods object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

highAvailability object
1 nested properties
replicas integer

Replicas are the amount of pods to use.

scheduling object
6 nested properties
nodeSelector object

NodeSelector is the node selector to apply to the pod.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

priorityClassName string

PriorityClassName is the priority class name for the the pod.

podManagementPolicy string

PodManagementPolicy is the statefulSet pod management policy.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the pod.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

persistence object
4 nested properties
volumeClaim object
volumeClaimTemplates object[]

VolumeClaimTemplates defines the volumeClaimTemplates for the statefulSet

addVolumes object[]

AddVolumes defines extra volumes for the pod

addVolumeMounts VolumeMount[]

AddVolumeMounts defines extra volume mounts for the container

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

service object
2 nested properties
enabled boolean

Enabled defines if the etcd service should be deployed

annotations Record<string, string>

Annotations are extra annotations for the external etcd service

headlessService object
1 nested properties
annotations Record<string, string>

Annotations are extra annotations for the external etcd headless service

EtcdDeployHeadlessService object
annotations Record<string, string>

Annotations are extra annotations for the external etcd headless service

EtcdDeployService object
enabled boolean

Enabled defines if the etcd service should be deployed

annotations Record<string, string>

Annotations are extra annotations for the external etcd service

EtcdDeployStatefulSet object
enabled boolean

Enabled defines if the statefulSet should be deployed

enableServiceLinks boolean

EnableServiceLinks for the StatefulSet pod

image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

imagePullPolicy string

ImagePullPolicy is the pull policy for the external etcd image

env object[]

Env are extra environment variables

extraArgs string[]

ExtraArgs are appended to the etcd command.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

pods object
2 nested properties
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

highAvailability object
1 nested properties
replicas integer

Replicas are the amount of pods to use.

scheduling object
6 nested properties
nodeSelector object

NodeSelector is the node selector to apply to the pod.

affinity object

Affinity is the affinity to apply to the pod.

tolerations object[]

Tolerations are the tolerations to apply to the pod.

priorityClassName string

PriorityClassName is the priority class name for the the pod.

podManagementPolicy string

PodManagementPolicy is the statefulSet pod management policy.

topologySpreadConstraints array

TopologySpreadConstraints are the topology spread constraints for the pod.

security object
2 nested properties
podSecurityContext object

PodSecurityContext specifies security context options on the pod level.

containerSecurityContext object

ContainerSecurityContext specifies security context options on the container level.

persistence object
4 nested properties
volumeClaim object
5 nested properties
enabled boolean

Enabled enables deploying a persistent volume claim.

accessModes string[]

AccessModes are the persistent volume claim access modes.

retentionPolicy string

RetentionPolicy is the persistent volume claim retention policy.

size string

Size is the persistent volume claim storage size.

storageClass string

StorageClass is the persistent volume claim storage class.

volumeClaimTemplates object[]

VolumeClaimTemplates defines the volumeClaimTemplates for the statefulSet

addVolumes object[]

AddVolumes defines extra volumes for the pod

addVolumeMounts VolumeMount[]

AddVolumeMounts defines extra volume mounts for the container

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

EtcdEmbedded object
enabled boolean

Enabled defines if the embedded etcd should be used.

migrateFromDeployedEtcd boolean

MigrateFromDeployedEtcd signals that vCluster should migrate from the deployed external etcd to embedded etcd.

snapshotCount integer

SnapshotCount defines the number of snapshots to keep for the embedded etcd. Defaults to 10000 if less than 1.

extraArgs string[]

ExtraArgs are additional arguments to pass to the embedded etcd.

EtcdExternal object
enabled boolean

Enabled defines if the external etcd should be used.

endpoint string

Endpoint holds the endpoint of the external etcd server, e.g. my-example-service:2379

tls object

EtcdExternalTLS defines tls for external etcd server

3 nested properties
caFile string

CaFile is the path to the ca file

certFile string

CertFile is the path to the cert file

keyFile string

KeyFile is the path to the key file

EtcdExternalTLS object

EtcdExternalTLS defines tls for external etcd server

caFile string

CaFile is the path to the ca file

certFile string

CertFile is the path to the cert file

keyFile string

KeyFile is the path to the key file

Experimental object
deploy object
2 nested properties
host object
2 nested properties
manifests string

Manifests are raw Kubernetes manifests that should get applied within the host cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the host cluster.

vcluster object
3 nested properties
manifests string

Manifests are raw Kubernetes manifests that should get applied within the virtual cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the virtual cluster.

Helm are Helm charts that should get deployed into the virtual cluster

syncSettings object
3 nested properties
setOwner boolean

SetOwner specifies if vCluster should set an owner reference on the synced objects to the vCluster service. This allows for easy garbage collection.

hostMetricsBindAddress string

HostMetricsBindAddress is the bind address for the local manager

virtualMetricsBindAddress string

VirtualMetricsBindAddress is the bind address for the virtual manager

virtualClusterKubeConfig object
5 nested properties
kubeConfig string

KubeConfig is the virtual cluster kubeconfig path.

serverCAKey string

ServerCAKey is the server ca key path.

serverCACert string

ServerCAKey is the server ca cert path.

clientCACert string

ServerCAKey is the client ca cert path.

requestHeaderCACert string

RequestHeaderCACert is the request header ca cert path.

denyProxyRequests DenyRule[]

DenyProxyRequests denies certain requests in the vCluster proxy.

proxy object
1 nested properties
customResources Record<string, object>

CustomResources is a map of resource keys (format: "kind.apiGroup/version") to proxy configuration

docker object
10 nested properties
image string

Image defines the image to use for the container. Defaults to ghcr.io/loft-sh/vm-container.

ports string[]

Ports defines extra port mappings to be added to the container.

volumes string[]

Volumes defines extra volumes to be added to the container.

env string[]

Env defines extra environment variables to be added to the container. Use key=value.

args string[]

Args defines extra arguments to be added to the docker run command of the container.

enabled boolean

Enabled defines if the vCluster was deployed using Docker. This is automatically set by vCluster and should not be set by the user.

network string

Network defines the network to use for the vCluster. If not specified, the a network will be created for the vCluster.

Nodes defines the nodes of the vCluster.

registryProxy object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

loadBalancer object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

forwardPorts boolean

ForwardPorts defines if the load balancer ips should be made available locally via port forwarding. This will be only done if necessary for example on macos when using docker desktop.

NodeMonitors allows you to create a service monitor for each node.

ExperimentalDeploy object
host object
2 nested properties
manifests string

Manifests are raw Kubernetes manifests that should get applied within the host cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the host cluster.

vcluster object
3 nested properties
manifests string

Manifests are raw Kubernetes manifests that should get applied within the virtual cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the virtual cluster.

Helm are Helm charts that should get deployed into the virtual cluster

ExperimentalDeployHelm object
chart object
6 nested properties
name string
repo string
insecure boolean
version string
username string
password string
release object
2 nested properties
name string

Name of the release

namespace string

Namespace of the release

values string

Values defines what values should get used.

timeout string

Timeout defines the timeout for Helm

bundle string

Bundle allows to compress the Helm chart and specify this instead of an online chart

ExperimentalDeployHelmChart object
name string
repo string
insecure boolean
version string
username string
password string
ExperimentalDeployHelmRelease object
name string

Name of the release

namespace string

Namespace of the release

ExperimentalDeployHost object
manifests string

Manifests are raw Kubernetes manifests that should get applied within the host cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the host cluster.

ExperimentalDeployVCluster object
manifests string

Manifests are raw Kubernetes manifests that should get applied within the virtual cluster.

manifestsTemplate string

ManifestsTemplate is a Kubernetes manifest template that will be rendered with vCluster values before applying it within the virtual cluster.

Helm are Helm charts that should get deployed into the virtual cluster

ExperimentalDocker object
image string

Image defines the image to use for the container. Defaults to ghcr.io/loft-sh/vm-container.

ports string[]

Ports defines extra port mappings to be added to the container.

volumes string[]

Volumes defines extra volumes to be added to the container.

env string[]

Env defines extra environment variables to be added to the container. Use key=value.

args string[]

Args defines extra arguments to be added to the docker run command of the container.

enabled boolean

Enabled defines if the vCluster was deployed using Docker. This is automatically set by vCluster and should not be set by the user.

network string

Network defines the network to use for the vCluster. If not specified, the a network will be created for the vCluster.

Nodes defines the nodes of the vCluster.

registryProxy object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

loadBalancer object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

forwardPorts boolean

ForwardPorts defines if the load balancer ips should be made available locally via port forwarding. This will be only done if necessary for example on macos when using docker desktop.

ExperimentalDockerLoadBalancer object
enabled boolean

Enabled defines if this option should be enabled.

forwardPorts boolean

ForwardPorts defines if the load balancer ips should be made available locally via port forwarding. This will be only done if necessary for example on macos when using docker desktop.

ExperimentalDockerNode object
image string

Image defines the image to use for the container. Defaults to ghcr.io/loft-sh/vm-container.

ports string[]

Ports defines extra port mappings to be added to the container.

volumes string[]

Volumes defines extra volumes to be added to the container.

env string[]

Env defines extra environment variables to be added to the container. Use key=value.

args string[]

Args defines extra arguments to be added to the docker run command of the container.

name string

Name defines the name of the node. If not specified, a random name will be generated.

ExperimentalNodeMonitor object
name string

Name is the name of the monitor. It will be suffixed with the node name.

nodeSelector Record<string, string>

NodeSelector defines the node selector for the service monitor.

Endpoints is a list of endpoints to add to the service monitor. By default, vCluster will relabel the node and instance label to the node name.

spec object

Spec allows you to configure extra service monitor options that will be merged into the spec.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

ExperimentalNodeServiceMonitorEndpoint object
path string

Path is the kubelet path of the endpoint. vCluster will prepend /api/v1/nodes/NODE_NAME to the path.

params Record<string, string[]>

Params allows you to configure extra parameters to add to the endpoint.

extraRelabelings object[]

ExtraRelabelings allows you to configure extra relabelings to add to the endpoint. By default, vCluster will relabel the node and instance label to the node name.

metricsRelabelings object[]

MetricsRelabelings allows you to configure extra metrics relabelings to add to the endpoint.

interval string

Interval is the interval at which to scrape the endpoint.

scrapeTimeout string

ScrapeTimeout is the timeout for the scrape of the endpoint.

ExperimentalSyncSettings object
setOwner boolean

SetOwner specifies if vCluster should set an owner reference on the synced objects to the vCluster service. This allows for easy garbage collection.

hostMetricsBindAddress string

HostMetricsBindAddress is the bind address for the local manager

virtualMetricsBindAddress string

VirtualMetricsBindAddress is the bind address for the virtual manager

ExportKubeConfig object

ExportKubeConfig describes how vCluster should export the vCluster kubeconfig.

context string

Context is the name of the context within the generated kubeconfig to use.

server string

Override the default https://localhost:8443 and specify a custom hostname for the generated kubeconfig.

insecure boolean

If tls should get skipped for the server

serviceAccount object
3 nested properties
name string

Name of the service account to be used to generate a service account token instead of the default certificates.

namespace string

Namespace of the service account to be used to generate a service account token instead of the default certificates. If omitted, will use the kube-system namespace.

clusterRole string

ClusterRole to assign to the service account.

secret object

Declare in which host cluster secret vCluster should store the generated virtual cluster kubeconfig.

2 nested properties
name string

Name is the name of the secret where the kubeconfig should get stored.

namespace string

Namespace where vCluster should store the kubeconfig secret. If this is not equal to the namespace where you deployed vCluster, you need to make sure vCluster has access to this other namespace.

AdditionalSecrets specifies the additional host cluster secrets in which vCluster will store the generated virtual cluster kubeconfigs.

ExportKubeConfigAdditionalSecretReference object

ExportKubeConfigAdditionalSecretReference defines the additional host cluster secret in which vCluster stores the generated virtual cluster kubeconfigs.

context string

Context is the name of the context within the generated kubeconfig to use.

server string

Override the default https://localhost:8443 and specify a custom hostname for the generated kubeconfig.

insecure boolean

If tls should get skipped for the server

serviceAccount object
3 nested properties
name string

Name of the service account to be used to generate a service account token instead of the default certificates.

namespace string

Namespace of the service account to be used to generate a service account token instead of the default certificates. If omitted, will use the kube-system namespace.

clusterRole string

ClusterRole to assign to the service account.

name string

Name is the name of the secret where the kubeconfig is stored.

namespace string

Namespace where vCluster stores the kubeconfig secret. If this is not equal to the namespace where you deployed vCluster, you need to make sure vCluster has access to this other namespace.

ExportKubeConfigSecretReference object

Declare in which host cluster secret vCluster should store the generated virtual cluster kubeconfig.

name string

Name is the name of the secret where the kubeconfig should get stored.

namespace string

Namespace where vCluster should store the kubeconfig secret. If this is not equal to the namespace where you deployed vCluster, you need to make sure vCluster has access to this other namespace.

ExportKubeConfigServiceAccount object
name string

Name of the service account to be used to generate a service account token instead of the default certificates.

namespace string

Namespace of the service account to be used to generate a service account token instead of the default certificates. If omitted, will use the kube-system namespace.

clusterRole string

ClusterRole to assign to the service account.

ExternalDatabaseKine object
enabled boolean

Enabled defines if the database should be used.

dataSource string

DataSource is the kine dataSource to use for the database. This depends on the database format. This is optional for the external database. Examples:

  • mysql: mysql://username:password@tcp(hostname:3306)/vcluster
  • postgres: postgres://username:password@hostname:5432/vcluster
identityProvider string

IdentityProvider is the kine identity provider to use when generating temporary authentication tokens for enhanced security. This is optional for the external database. Examples:

  • aws: RDS IAM Authentication
keyFile string

KeyFile is the key file to use for the database. This is optional.

certFile string

CertFile is the cert file to use for the database. This is optional.

caFile string

CaFile is the ca file to use for the database. This is optional.

extraArgs string[]

ExtraArgs are additional arguments to pass to Kine.

connector string

Connector specifies a secret located in a connected vCluster Platform that contains database server connection information to be used by Platform to create a database and database user for the vCluster. and non-privileged user. A kine endpoint should be created using the database and user on Platform registration. This is optional.

ExternalEtcdHighAvailability object
replicas integer

Replicas are the amount of pods to use.

ExternalEtcdPersistence object
volumeClaim object
5 nested properties
enabled boolean

Enabled enables deploying a persistent volume claim.

accessModes string[]

AccessModes are the persistent volume claim access modes.

retentionPolicy string

RetentionPolicy is the persistent volume claim retention policy.

size string

Size is the persistent volume claim storage size.

storageClass string

StorageClass is the persistent volume claim storage class.

volumeClaimTemplates object[]

VolumeClaimTemplates defines the volumeClaimTemplates for the statefulSet

addVolumes object[]

AddVolumes defines extra volumes for the pod

addVolumeMounts VolumeMount[]

AddVolumeMounts defines extra volume mounts for the container

ExternalEtcdPersistenceVolumeClaim object
enabled boolean

Enabled enables deploying a persistent volume claim.

accessModes string[]

AccessModes are the persistent volume claim access modes.

retentionPolicy string

RetentionPolicy is the persistent volume claim retention policy.

size string

Size is the persistent volume claim storage size.

storageClass string

StorageClass is the persistent volume claim storage class.

ExternalSecrets object

ExternalSecrets reuses a host external secret operator and makes certain CRDs from it available inside the vCluster

enabled boolean

Enabled defines whether the external secret integration is enabled or not

version string

Version defines the version of the external secrets operator to use. If empty, the storage version will be used.

webhook object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object
2 nested properties
toHost object
2 nested properties
externalSecrets object
stores object
fromHost object
1 nested properties
clusterStores object
ExternalSecretsSync object
toHost object
2 nested properties
externalSecrets object
1 nested properties
selector object
stores object
2 nested properties
selector object
enabled boolean

Enabled defines if this option should be enabled.

fromHost object
1 nested properties
clusterStores object
2 nested properties
selector object
enabled boolean

Enabled defines if this option should be enabled.

ExternalSecretsSyncFromHostConfig object
clusterStores object
2 nested properties
selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
enabled boolean

Enabled defines if this option should be enabled.

ExternalSecretsSyncToHostConfig object
externalSecrets object
1 nested properties
selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
stores object
2 nested properties
selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
enabled boolean

Enabled defines if this option should be enabled.

FromHostMappings object
byName Record<string, string>

ByName is a map of host-object-namespace/host-object-name: virtual-object-namespace/virtual-object-name. There are several wildcards supported:

  1. To match all objects in host namespace and sync them to different namespace in vCluster: byName: "foo/": "foo-in-virtual/"
  2. To match specific object in the host namespace and sync it to the same namespace with the same name: byName: "foo/my-object": "foo/my-object"
  3. To match specific object in the host namespace and sync it to the same namespace with different name: byName: "foo/my-object": "foo/my-virtual-object"
  4. To match all objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "": "my-virtual-namespace/*"
  5. To match specific objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "/my-object": "my-virtual-namespace/my-object"
HostAlias object
ip string
hostnames string[]
HostPathMapper object
enabled boolean

Enabled specifies if the host path mapper will be used

central boolean

Central specifies if the central host path mapper will be used

HybridScheduling object
enabled boolean

Enabled specifies if hybrid scheduling is enabled.

hostSchedulers string[]

HostSchedulers is a list of schedulers that are deployed on the host cluster.

IPBlock object

IPBlock describes a particular CIDR (Ex.

cidr string

CIDR defines the allowed workload public egress destination. Valid examples are "0.0.0.0/0", "192.168.1.0/24" or "2001:db8::/64"

except string[]

Except is a slice of CIDRs that should not be included. Items outside the cidr range will be rejected. Valid examples are "192.168.1.0/24" or "2001:db8::/64". +optional

Image object
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

ImagePullSecretName object
name string

Name of the image pull secret to use.

IngressNginx object
enabled boolean

Enabled defines if ingress-nginx should be enabled.

defaultIngressClass boolean

DefaultIngressClass defines if the deployed ingress class should be the default ingress class.

Integrations object

Integrations holds config for vCluster integrations with other operators or tools running on the host cluster

metricsServer object

MetricsServer reuses the metrics server from the host cluster within the vCluster.

4 nested properties
enabled boolean

Enabled signals the metrics server integration should be enabled.

apiService object

APIService holds configuration related to the api server

1 nested properties
service object

APIServiceService holds the service name and namespace of the host apiservice.

nodes boolean

Nodes defines if metrics-server nodes api should get proxied from host to virtual cluster.

pods boolean

Pods defines if metrics-server pods api should get proxied from host to virtual cluster.

kubeVirt object

KubeVirt reuses a host kubevirt and makes certain CRDs from it available inside the vCluster

4 nested properties
enabled boolean

Enabled signals if the integration should be enabled

apiService object

APIService holds configuration related to the api server

1 nested properties
service object

APIServiceService holds the service name and namespace of the host apiservice.

webhook object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object

KubeVirtSync are the crds that are supported by this integration

6 nested properties
dataVolumes object
virtualMachineInstanceMigrations object
virtualMachineInstances object
virtualMachines object
virtualMachineClones object
virtualMachinePools object
externalSecrets object

ExternalSecrets reuses a host external secret operator and makes certain CRDs from it available inside the vCluster

4 nested properties
enabled boolean

Enabled defines whether the external secret integration is enabled or not

version string

Version defines the version of the external secrets operator to use. If empty, the storage version will be used.

webhook object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object
2 nested properties
toHost object
fromHost object
certManager object

CertManager reuses a host cert-manager and makes its CRDs from it available inside the vCluster

2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object
2 nested properties
toHost object
fromHost object
istio object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object
1 nested properties
toHost object
netris object

NetrisIntegration holds netris integration configuration.

3 nested properties
enabled boolean

Enabled defines if netris integration is enabled +optional

connector string

Connector specifies the netris connector name +optional

kubeVip object

NetrisKubeVipConfig holds kube-vip configuration for netris integration

3 nested properties
serverCluster string

ServerCluster specifies the server cluster name +optional

bridge string

Bridge specifies the bridge interface name +optional

ipRange string

IPRange specifies the IP range for kube-vip +optional

Istio object
enabled boolean

Enabled defines if this option should be enabled.

sync object
1 nested properties
toHost object
3 nested properties
destinationRules object
gateways object
virtualServices object
IstioSync object
toHost object
3 nested properties
destinationRules object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

gateways object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualServices object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

IstioSyncToHost object
destinationRules object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

gateways object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualServices object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

JoinConfiguration object
preInstallCommands string[]

PreInstallCommands are commands that will be executed before containerd, kubelet etc. is installed.

preJoinCommands string[]

PreJoinCommands are commands that will be executed before kubeadm join is executed.

postJoinCommands string[]

PostJoinCommands are commands that will be executed after kubeadm join is executed.

containerd object
3 nested properties
enabled boolean

Enabled defines if containerd should be installed and configured by vCluster.

registry object
3 nested properties
configPath string

ConfigPath is the path to the containerd registry config.

mirrors Record<string, object>

Mirrors holds configuration for the containerd registry mirrors. E.g. myregistry.io:5000 or docker.io. See https://github.com/containerd/containerd/blob/main/docs/hosts.md for more details.

auth Record<string, object>

Auth holds configuration for the containerd registry auth. See https://github.com/containerd/containerd/blob/main/docs/cri/registry.md#configure-registry-credentials for more details.

pauseImage string

PauseImage is the image for the pause container.

caCertPath string

CACertPath is the path to the SSL certificate authority used to secure communications between node and control-plane. Defaults to "/etc/kubernetes/pki/ca.crt".

skipPhases string[]

SkipPhases is a list of phases to skip during command execution. The list of phases can be obtained with the "kubeadm join --help" command.

nodeRegistration object
5 nested properties
criSocket string

CRI socket is the socket for the CRI.

kubeletExtraArgs KubeletExtraArg[]

KubeletExtraArgs passes through extra arguments to the kubelet. The arguments here are passed to the kubelet command line via the environment file kubeadm writes at runtime for the kubelet to source. This overrides the generic base-level configuration in the kubelet-config ConfigMap Flags have higher priority when parsing. These values are local and specific to the node kubeadm is executing on. An argument name in this list is the flag name as it appears on the command line except without leading dash(es). Extra arguments will override existing default arguments. Duplicate extra arguments are allowed.

Taints are additional taints to set for the kubelet.

ignorePreflightErrors string[]

IgnorePreflightErrors provides a slice of pre-flight errors to be ignored when the current node is registered, e.g. 'IsPrivilegedUser,Swap'. Value 'all' ignores errors from all checks.

imagePullPolicy string

ImagePullPolicy specifies the policy for image pulling during kubeadm "init" and "join" operations. The value of this field must be one of "Always", "IfNotPresent" or "Never". If this field is unset kubeadm will default it to "IfNotPresent", or pull the required images if not present on the host.

Konnectivity object
server object
2 nested properties
enabled boolean

Enabled defines if the konnectivity server should be enabled.

extraArgs string[]

ExtraArgs are additional arguments to pass to the konnectivity server.

agent object
9 nested properties
enabled boolean

Enabled defines if the konnectivity agent should be enabled.

replicas integer

Replicas is the number of replicas for the konnectivity agent.

image string

Image is the image for the konnectivity agent.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the konnectivity agent.

priorityClassName string

PriorityClassName is the priority class name for the konnectivity agent.

tolerations array

Tolerations is the tolerations for the konnectivity agent.

extraEnv array

ExtraEnv is the extra environment variables for the konnectivity agent.

extraArgs string[]

ExtraArgs are additional arguments to pass to the konnectivity agent.

KonnectivityAgent object
enabled boolean

Enabled defines if the konnectivity agent should be enabled.

replicas integer

Replicas is the number of replicas for the konnectivity agent.

image string

Image is the image for the konnectivity agent.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the konnectivity agent.

priorityClassName string

PriorityClassName is the priority class name for the konnectivity agent.

tolerations array

Tolerations is the tolerations for the konnectivity agent.

extraEnv array

ExtraEnv is the extra environment variables for the konnectivity agent.

extraArgs string[]

ExtraArgs are additional arguments to pass to the konnectivity agent.

KonnectivityServer object
enabled boolean

Enabled defines if the konnectivity server should be enabled.

extraArgs string[]

ExtraArgs are additional arguments to pass to the konnectivity server.

KubeProxy object
enabled boolean

Enabled defines if the kube proxy should be enabled.

image string

Image is the image for the kube-proxy.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the kube-proxy.

priorityClassName string

PriorityClassName is the priority class name for the kube-proxy.

tolerations array

Tolerations is the tolerations for the kube-proxy.

extraEnv array

ExtraEnv is the extra environment variables for the kube-proxy.

extraArgs string[]

ExtraArgs are additional arguments to pass to the kube-proxy.

config object

Config is the config for the kube-proxy that will be merged into the default kube-proxy config. More information can be found here: https://kubernetes.io/docs/reference/config-api/kube-proxy-config.v1alpha1/#kubeproxy-config-k8s-io-v1alpha1-KubeProxyConfiguration

KubeVip object
enabled boolean

Enabled defines if embedded kube-vip should be enabled.

interface string

Interface is the network interface on which the VIP is announced.

gateway string

Gateway is the gateway address in CIDR notation (e.g., 10.100.0.1/24). This is used to configure policy-based routing for the VIP and must include the subnet prefix.

KubeVirt object

KubeVirt reuses a host kubevirt and makes certain CRDs from it available inside the vCluster

enabled boolean

Enabled signals if the integration should be enabled

apiService object

APIService holds configuration related to the api server

1 nested properties
service object

APIServiceService holds the service name and namespace of the host apiservice.

3 nested properties
name string

Name is the name of the host service of the apiservice.

namespace string

Namespace is the name of the host service of the apiservice.

port integer

Port is the target port on the host service to connect to.

webhook object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

sync object

KubeVirtSync are the crds that are supported by this integration

6 nested properties
dataVolumes object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachineInstanceMigrations object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachineInstances object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachines object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachineClones object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachinePools object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

KubeVirtSync object

KubeVirtSync are the crds that are supported by this integration

dataVolumes object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachineInstanceMigrations object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachineInstances object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachines object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachineClones object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

virtualMachinePools object
1 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Kubelet object
config object

Config is the config for the kubelet that will be merged into the default kubelet config. More information can be found here: https://kubernetes.io/docs/reference/config-api/kubelet-config.v1beta1/#kubelet-config-k8s-io-v1beta1-KubeletConfiguration

KubeletExtraArg object

KubeletExtraArg represents an argument with a name and a value.

name string

Name is the name of the argument.

value string

Value is the value of the argument.

KubeletJoinTaint object
key string

Required. The taint key to be applied to a node.

value string

The taint value corresponding to the taint key. +optional

effect string

Required. The effect of the taint on pods that do not tolerate the taint. Valid effects are NoSchedule, PreferNoSchedule and NoExecute.

LabelSelector object
labels Record<string, string>

Labels defines what labels should be looked for

LabelSelectorRequirement object
key string
operator string
values string[]
LabelsAndAnnotations object
annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

LimitRange object
enabled string | boolean

Enabled defines if the limit range should be deployed by vCluster. "auto" means that if resourceQuota is enabled, the limitRange will be enabled as well.

default object

Default are the default limits for the limit range

defaultRequest object

DefaultRequest are the default request options for the limit range

max object

Max are the max limits for the limit range

min object

Min are the min limits for the limit range

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

LivenessProbe object

LivenessProbe defines the configuration for the liveness probe.

enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures for the probe to be considered failed

initialDelaySeconds integer

Time (in seconds) to wait before starting the liveness probe

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

LocalPathProvisioner object
enabled boolean

Enabled defines if LocalPathProvisioner should be enabled.

image string

Image is the image for local path provisioner.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodePath string

NodePath is the path on the node where to create the persistent volume directories.

Logging object

Logging holds the log encoding details

encoding string

Encoding specifies the format of vCluster logs, it can either be json or console.

Metallb object
enabled boolean

Enabled defines if metallb should be enabled.

controllerImage string

ControllerImage is the image for metallb controller.

speakerImage string

SpeakerImage is the image for metallb speaker.

ipAddressPool object
2 nested properties
addresses string[]

Addresses is a list of IP addresses to use for the IP address pool.

l2Advertisement boolean

L2Advertisement defines if L2 advertisement should be enabled for the IP address pool.

MetallbIPAddressPool object
addresses string[]

Addresses is a list of IP addresses to use for the IP address pool.

l2Advertisement boolean

L2Advertisement defines if L2 advertisement should be enabled for the IP address pool.

MetricsServer object

MetricsServer reuses the metrics server from the host cluster within the vCluster.

enabled boolean

Enabled signals the metrics server integration should be enabled.

apiService object

APIService holds configuration related to the api server

1 nested properties
service object

APIServiceService holds the service name and namespace of the host apiservice.

3 nested properties
name string

Name is the name of the host service of the apiservice.

namespace string

Namespace is the name of the host service of the apiservice.

port integer

Port is the target port on the host service to connect to.

nodes boolean

Nodes defines if metrics-server nodes api should get proxied from host to virtual cluster.

pods boolean

Pods defines if metrics-server pods api should get proxied from host to virtual cluster.

MutatingWebhook object
reinvocationPolicy string

reinvocationPolicy indicates whether this webhook should be called multiple times as part of a single admission evaluation. Allowed values are "Never" and "IfNeeded".

name string

The name of the admission webhook. Name should be fully qualified, e.g., imagepolicy.kubernetes.io, where "imagepolicy" is the name of the webhook, and kubernetes.io is the name of the organization.

clientConfig object

ValidatingWebhookClientConfig contains the information to make a TLS connection with the webhook

3 nested properties
url string

URL gives the location of the webhook, in standard URL form (scheme://host:port/path). Exactly one of url or service must be specified.

service object
4 nested properties
namespace string

Namespace is the namespace of the service.

name string

Name is the name of the service.

path string

Path is an optional URL path which will be sent in any request to this service.

port integer

If specified, the port on the service that hosting webhook. Default to 443 for backward compatibility. port should be a valid port number (1-65535, inclusive).

caBundle string

CABundle is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.

rules array

Rules describes what operations on what resources/subresources the webhook cares about. The webhook cares about an operation if it matches any Rule.

failurePolicy string

FailurePolicy defines how unrecognized errors from the admission endpoint are handled - allowed values are Ignore or Fail. Defaults to Fail.

matchPolicy string

matchPolicy defines how the "rules" list is used to match incoming requests. Allowed values are "Exact" or "Equivalent".

namespaceSelector

NamespaceSelector decides whether to run the webhook on an object based on whether the namespace for that object matches the selector. If the object itself is a namespace, the matching is performed on object.metadata.labels. If the object is another cluster scoped resource, it never skips the webhook.

objectSelector

ObjectSelector decides whether to run the webhook based on if the object has matching labels. objectSelector is evaluated against both the oldObject and newObject that would be sent to the webhook, and is considered to match if either object matches the selector.

sideEffects string

SideEffects states whether this webhook has side effects.

timeoutSeconds integer

TimeoutSeconds specifies the timeout for this webhook.

admissionReviewVersions string[]

AdmissionReviewVersions is an ordered list of preferred AdmissionReview versions the Webhook expects.

matchConditions array

MatchConditions is a list of conditions that must be met for a request to be sent to this webhook. Match conditions filter requests that have already been matched by the rules, namespaceSelector, and objectSelector. An empty list of matchConditions matches all requests. There are a maximum of 64 match conditions allowed.

MutatingWebhookConfiguration object
kind string

Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to.

apiVersion string

APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values.

metadata object
3 nested properties
name string

Name must be unique within a namespace. Is required when creating resources, although some resources may allow a client to request the generation of an appropriate name automatically. Name is primarily intended for creation idempotence and configuration definition.

labels Record<string, string>

Map of string keys and values that can be used to organize and categorize (scope and select) objects. May match selectors of replication controllers and services.

annotations Record<string, string>

Annotations is an unstructured key value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata.

Webhooks is a list of webhooks and the affected resources and operations.

NetrisIntegration object

NetrisIntegration holds netris integration configuration.

enabled boolean

Enabled defines if netris integration is enabled +optional

connector string

Connector specifies the netris connector name +optional

kubeVip object

NetrisKubeVipConfig holds kube-vip configuration for netris integration

3 nested properties
serverCluster string

ServerCluster specifies the server cluster name +optional

bridge string

Bridge specifies the bridge interface name +optional

ipRange string

IPRange specifies the IP range for kube-vip +optional

NetrisKubeVipConfig object

NetrisKubeVipConfig holds kube-vip configuration for netris integration

serverCluster string

ServerCluster specifies the server cluster name +optional

bridge string

Bridge specifies the bridge interface name +optional

ipRange string

IPRange specifies the IP range for kube-vip +optional

NetworkPolicy object
enabled boolean

Enabled defines if the network policy should be deployed by vCluster.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

fallbackDns string

FallbackDNS is the fallback DNS server to use if the virtual cluster does not have a DNS server.

controlPlane object
2 nested properties

Ingress rules for the vCluster control plane.

Egress rules for the vCluster control plane.

workload object
3 nested properties
publicEgress object
3 nested properties
enabled boolean

Enabled defines if the workload public egress should be enabled or disabled.

cidr string

CIDR defines the allowed workload public egress destination. Valid examples are "0.0.0.0/0", "192.168.1.0/24" or "2001:db8::/64"

except string[]

Except is a slice of CIDRs that should not be included. Items outside the cidr range will be rejected. Valid examples are "192.168.1.0/24" or "2001:db8::/64". +optional

Ingress rules for the vCluster workloads.

Egress rules for the vCluster workloads.

NetworkPolicyControlPlane object

Ingress rules for the vCluster control plane.

Egress rules for the vCluster control plane.

NetworkPolicyEgressRule object

NetworkPolicyEgressRule describes a particular set of traffic that is allowed out of pods matched by a NetworkPolicySpec's podSelector.

ports is a list of destination ports for outgoing traffic. Each item in this list is combined using a logical OR. If this field is empty or missing, this rule matches all ports (traffic not restricted by port). If this field is present and contains at least one item, then this rule allows traffic only if the traffic matches at least one port in the list. +optional +listType=atomic

to is a list of destinations for outgoing traffic of pods selected for this rule. Items in this list are combined using a logical OR operation. If this field is empty or missing, this rule matches all destinations (traffic not restricted by destination). If this field is present and contains at least one item, this rule allows traffic only if the traffic matches at least one item in the to list. +optional +listType=atomic

NetworkPolicyIngressRule object

NetworkPolicyIngressRule describes a particular set of traffic that is allowed to the pods matched by a NetworkPolicySpec's podSelector.

ports is a list of ports which should be made accessible on the pods selected for this rule. Each item in this list is combined using a logical OR. If this field is empty or missing, this rule matches all ports (traffic not restricted by port). If this field is present and contains at least one item, then this rule allows traffic only if the traffic matches at least one port in the list. +optional +listType=atomic

from is a list of sources which should be able to access the pods selected for this rule. Items in this list are combined using a logical OR operation. If this field is empty or missing, this rule matches all sources (traffic not restricted by source). If this field is present and contains at least one item, this rule allows traffic only if the traffic matches at least one item in the from list. +optional +listType=atomic

NetworkPolicyPeer object

NetworkPolicyPeer describes a peer to allow traffic to/from.

podSelector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
namespaceSelector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
ipBlock object

IPBlock describes a particular CIDR (Ex.

2 nested properties
cidr string

CIDR defines the allowed workload public egress destination. Valid examples are "0.0.0.0/0", "192.168.1.0/24" or "2001:db8::/64"

except string[]

Except is a slice of CIDRs that should not be included. Items outside the cidr range will be rejected. Valid examples are "192.168.1.0/24" or "2001:db8::/64". +optional

NetworkPolicyPort object

NetworkPolicyPort describes a port to allow traffic on

protocol string

protocol represents the protocol (TCP, UDP, or SCTP) which traffic must match. If not specified, this field defaults to TCP. +optional

port

port represents the port on the given protocol. This can either be a numerical or named port on a pod. If this field is not provided, this matches all port names and numbers. If present, only traffic on the specified protocol AND port will be matched. +optional

endPort integer

endPort indicates that the range of ports from port to endPort if set, inclusive, should be allowed by the policy. This field cannot be defined if the port field is not defined or if the port field is defined as a named (string) port. The endPort must be equal or greater than port. +optional

NetworkPolicyWorkload object
publicEgress object
3 nested properties
enabled boolean

Enabled defines if the workload public egress should be enabled or disabled.

cidr string

CIDR defines the allowed workload public egress destination. Valid examples are "0.0.0.0/0", "192.168.1.0/24" or "2001:db8::/64"

except string[]

Except is a slice of CIDRs that should not be included. Items outside the cidr range will be rejected. Valid examples are "192.168.1.0/24" or "2001:db8::/64". +optional

Ingress rules for the vCluster workloads.

Egress rules for the vCluster workloads.

NetworkPolicyWorkloadPublicEgress object
enabled boolean

Enabled defines if the workload public egress should be enabled or disabled.

cidr string

CIDR defines the allowed workload public egress destination. Valid examples are "0.0.0.0/0", "192.168.1.0/24" or "2001:db8::/64"

except string[]

Except is a slice of CIDRs that should not be included. Items outside the cidr range will be rejected. Valid examples are "192.168.1.0/24" or "2001:db8::/64". +optional

NetworkProxyKubelets object
byHostname boolean

ByHostname will add a special vCluster hostname to the nodes where the node can be reached at. This doesn't work for all applications, e.g. Prometheus requires a node IP.

byIP boolean

ByIP will create a separate service in the host cluster for every node that will point to virtual cluster and will be used to route traffic.

Networking object
serviceCIDR string

ServiceCIDR holds the service cidr for the virtual cluster. This should only be set if privateNodes.enabled is true or vCluster cannot detect the host service cidr.

podCIDR string

PodCIDR holds the pod cidr for the virtual cluster. This should only be set if privateNodes.enabled is true.

replicateServices object
2 nested properties

ToHost defines the services that should get synced from virtual cluster to the host cluster. If services are synced to a different namespace than the virtual cluster is in, additional permissions for the other namespace are required.

fromHost ServiceMapping[]

FromHost defines the services that should get synced from the host to the virtual cluster.

resolveDNS ResolveDNS[]

ResolveDNS allows to define extra DNS rules. This only works if embedded coredns is configured.

advanced object
3 nested properties
clusterDomain string

ClusterDomain is the Kubernetes cluster domain to use within the virtual cluster.

fallbackHostCluster boolean

FallbackHostCluster allows to fallback dns to the host cluster. This is useful if you want to reach host services without any other modification. You will need to provide a namespace for the service, e.g. my-other-service.my-other-namespace

proxyKubelets object
2 nested properties
byHostname boolean

ByHostname will add a special vCluster hostname to the nodes where the node can be reached at. This doesn't work for all applications, e.g. Prometheus requires a node IP.

byIP boolean

ByIP will create a separate service in the host cluster for every node that will point to virtual cluster and will be used to route traffic.

NetworkingAdvanced object
clusterDomain string

ClusterDomain is the Kubernetes cluster domain to use within the virtual cluster.

fallbackHostCluster boolean

FallbackHostCluster allows to fallback dns to the host cluster. This is useful if you want to reach host services without any other modification. You will need to provide a namespace for the service, e.g. my-other-service.my-other-namespace

proxyKubelets object
2 nested properties
byHostname boolean

ByHostname will add a special vCluster hostname to the nodes where the node can be reached at. This doesn't work for all applications, e.g. Prometheus requires a node IP.

byIP boolean

ByIP will create a separate service in the host cluster for every node that will point to virtual cluster and will be used to route traffic.

NodeRegistration object
criSocket string

CRI socket is the socket for the CRI.

kubeletExtraArgs KubeletExtraArg[]

KubeletExtraArgs passes through extra arguments to the kubelet. The arguments here are passed to the kubelet command line via the environment file kubeadm writes at runtime for the kubelet to source. This overrides the generic base-level configuration in the kubelet-config ConfigMap Flags have higher priority when parsing. These values are local and specific to the node kubeadm is executing on. An argument name in this list is the flag name as it appears on the command line except without leading dash(es). Extra arguments will override existing default arguments. Duplicate extra arguments are allowed.

Taints are additional taints to set for the kubelet.

ignorePreflightErrors string[]

IgnorePreflightErrors provides a slice of pre-flight errors to be ignored when the current node is registered, e.g. 'IsPrivilegedUser,Swap'. Value 'all' ignores errors from all checks.

imagePullPolicy string

ImagePullPolicy specifies the policy for image pulling during kubeadm "init" and "join" operations. The value of this field must be one of "Always", "IfNotPresent" or "Never". If this field is unset kubeadm will default it to "IfNotPresent", or pull the required images if not present on the host.

ObjectMeta object
name string

Name must be unique within a namespace. Is required when creating resources, although some resources may allow a client to request the generation of an appropriate name automatically. Name is primarily intended for creation idempotence and configuration definition.

labels Record<string, string>

Map of string keys and values that can be used to organize and categorize (scope and select) objects. May match selectors of replication controllers and services.

annotations Record<string, string>

Annotations is an unstructured key value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata.

Platform object

Platform holds vCluster Platform specific configuration.

apiKey object

PlatformAPIKey defines where to find the platform access key.

3 nested properties
secretName string

SecretName is the name of the secret where the platform access key is stored. This defaults to vcluster-platform-api-key if undefined. +optional

namespace string

Namespace defines the namespace where the access key secret should be retrieved from. If this is not equal to the namespace where the vCluster instance is deployed, you need to make sure vCluster has access to this other namespace. +optional

createRBAC boolean

CreateRBAC will automatically create the necessary RBAC roles and role bindings to allow vCluster to read the secret specified in the above namespace, if specified. This defaults to true. +optional

project string

Project specifies which platform project the vcluster should be imported to +optional

PlatformAPIKey object

PlatformAPIKey defines where to find the platform access key.

secretName string

SecretName is the name of the secret where the platform access key is stored. This defaults to vcluster-platform-api-key if undefined. +optional

namespace string

Namespace defines the namespace where the access key secret should be retrieved from. If this is not equal to the namespace where the vCluster instance is deployed, you need to make sure vCluster has access to this other namespace. +optional

createRBAC boolean

CreateRBAC will automatically create the necessary RBAC roles and role bindings to allow vCluster to read the secret specified in the above namespace, if specified. This defaults to true. +optional

Plugin object
name string

Name is the name of the init-container and NOT the plugin name

image string

Image is the container image that should be used for the plugin

imagePullPolicy string

ImagePullPolicy is the pull policy to use for the container image

config object

Config is the plugin config to use. This can be arbitrary config used for the plugin.

rbac object
2 nested properties
role object
1 nested properties
extraRules RBACPolicyRule[]

ExtraRules are extra rbac permissions roles that will be added to role or cluster role

clusterRole object
1 nested properties
extraRules RBACPolicyRule[]

ExtraRules are extra rbac permissions roles that will be added to role or cluster role

command string[]

Command is the command that should be used for the init container

args string[]

Args are the arguments that should be used for the init container

securityContext object

SecurityContext is the container security context used for the init container

resources object

Resources are the container resources used for the init container

volumeMounts array

VolumeMounts are extra volume mounts for the init container

version string

Version is the plugin version, this is only needed for legacy plugins.

env array
envFrom array
lifecycle object
livenessProbe object
readinessProbe object
startupProbe object
workingDir string
optional boolean
Plugins object
name string

Name is the name of the init-container and NOT the plugin name

image string

Image is the container image that should be used for the plugin

imagePullPolicy string

ImagePullPolicy is the pull policy to use for the container image

config object

Config is the plugin config to use. This can be arbitrary config used for the plugin.

rbac object
2 nested properties
role object
1 nested properties
extraRules RBACPolicyRule[]

ExtraRules are extra rbac permissions roles that will be added to role or cluster role

clusterRole object
1 nested properties
extraRules RBACPolicyRule[]

ExtraRules are extra rbac permissions roles that will be added to role or cluster role

command string[]

Command is the command that should be used for the init container

args string[]

Args are the arguments that should be used for the init container

securityContext object

SecurityContext is the container security context used for the init container

resources object

Resources are the container resources used for the init container

volumeMounts array

VolumeMounts are extra volume mounts for the init container

PluginsExtraRules object
extraRules RBACPolicyRule[]

ExtraRules are extra rbac permissions roles that will be added to role or cluster role

PluginsRBAC object
role object
1 nested properties
extraRules RBACPolicyRule[]

ExtraRules are extra rbac permissions roles that will be added to role or cluster role

clusterRole object
1 nested properties
extraRules RBACPolicyRule[]

ExtraRules are extra rbac permissions roles that will be added to role or cluster role

PodDNSConfig object

PodDNSConfig defines the DNS parameters of a pod in addition to those generated from DNSPolicy.

nameservers string[]

A list of DNS name server IP addresses. This will be appended to the base nameservers generated from DNSPolicy. Duplicated nameservers will be removed. +optional +listType=atomic

searches string[]

A list of DNS search domains for host-name lookup. This will be appended to the base search paths generated from DNSPolicy. Duplicated search paths will be removed. +optional +listType=atomic

A list of DNS resolver options. This will be merged with the base options generated from DNSPolicy. Duplicated entries will be removed. Resolution options given in Options will override those that appear in the base DNSPolicy. +optional +listType=atomic

PodDNSConfigOption object

PodDNSConfigOption defines DNS resolver options of a pod.

name string

Required.

value string

+optional

PodDisruptionBudget object
enabled boolean

Enabled defines if the pod disruption budget should be enabled.

minAvailable

MinAvailable describes the minimal number or percentage of available pods.

maxUnavailable

MaxUnavailable describes the minimal number or percentage of unavailable pods.

unhealthyPodEvictionPolicy string

UnhealthyPodEvictionPolicy defines the criteria when unhealthy pods should be considered for eviction. Currently supported values are:

  • IfHealthyBudget - pods that are in the Running phase but not yet healthy are considered disrupted and may be evicted even if the PodDisruptionBudget criteria are not met.
  • AlwaysAllow - pods that are in the Running phase but not yet healthy are considered disrupted and can be evicted regardless of whether the criteria in a PDB is met.
Policies object
networkPolicy object
6 nested properties
enabled boolean

Enabled defines if the network policy should be deployed by vCluster.

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

fallbackDns string

FallbackDNS is the fallback DNS server to use if the virtual cluster does not have a DNS server.

controlPlane object
2 nested properties

Ingress rules for the vCluster control plane.

Egress rules for the vCluster control plane.

workload object
3 nested properties
publicEgress object

Ingress rules for the vCluster workloads.

Egress rules for the vCluster workloads.

podSecurityStandard string

PodSecurityStandard that can be enforced can be one of: empty (""), baseline, restricted or privileged

resourceQuota object
6 nested properties
enabled string | boolean

Enabled defines if the resource quota should be enabled. "auto" means that if limitRange is enabled, the resourceQuota will be enabled as well.

quota object

Quota are the quota options

scopeSelector object

ScopeSelector is the resource quota scope selector

scopes string[]

Scopes are the resource quota scopes

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

limitRange object
7 nested properties
enabled string | boolean

Enabled defines if the limit range should be deployed by vCluster. "auto" means that if resourceQuota is enabled, the limitRange will be enabled as well.

default object

Default are the default limits for the limit range

defaultRequest object

DefaultRequest are the default request options for the limit range

max object

Max are the max limits for the limit range

min object

Min are the min limits for the limit range

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

centralAdmission object
2 nested properties

ValidatingWebhooks are validating webhooks that should be enforced in the virtual cluster

MutatingWebhooks are mutating webhooks that should be enforced in the virtual cluster

PrivateNodes object

PrivateNodes enables private nodes for vCluster.

enabled boolean

Enabled defines if dedicated nodes should be enabled.

kubelet object
1 nested properties
config object

Config is the config for the kubelet that will be merged into the default kubelet config. More information can be found here: https://kubernetes.io/docs/reference/config-api/kubelet-config.v1beta1/#kubelet-config-k8s-io-v1beta1-KubeletConfiguration

autoUpgrade object
7 nested properties
enabled boolean

Enabled defines if auto upgrade should be enabled.

image string

Image is the image for the auto upgrade pod started by vCluster. If empty defaults to the controlPlane.statefulSet.image.

imagePullPolicy string

ImagePullPolicy is the policy how to pull the image.

nodeSelector Record<string, string>

NodeSelector is the node selector for the auto upgrade. If empty will select all worker nodes.

binariesPath string

BinariesPath is the base path for the kubeadm binaries. Defaults to /usr/local/bin

cniBinariesPath string

CNIBinariesPath is the base path for the CNI binaries. Defaults to /opt/cni/bin

concurrency integer

Concurrency is the number of nodes that can be upgraded at the same time.

joinNode object
7 nested properties
preInstallCommands string[]

PreInstallCommands are commands that will be executed before containerd, kubelet etc. is installed.

preJoinCommands string[]

PreJoinCommands are commands that will be executed before kubeadm join is executed.

postJoinCommands string[]

PostJoinCommands are commands that will be executed after kubeadm join is executed.

containerd object
3 nested properties
enabled boolean

Enabled defines if containerd should be installed and configured by vCluster.

registry object
pauseImage string

PauseImage is the image for the pause container.

caCertPath string

CACertPath is the path to the SSL certificate authority used to secure communications between node and control-plane. Defaults to "/etc/kubernetes/pki/ca.crt".

skipPhases string[]

SkipPhases is a list of phases to skip during command execution. The list of phases can be obtained with the "kubeadm join --help" command.

nodeRegistration object
5 nested properties
criSocket string

CRI socket is the socket for the CRI.

kubeletExtraArgs KubeletExtraArg[]

KubeletExtraArgs passes through extra arguments to the kubelet. The arguments here are passed to the kubelet command line via the environment file kubeadm writes at runtime for the kubelet to source. This overrides the generic base-level configuration in the kubelet-config ConfigMap Flags have higher priority when parsing. These values are local and specific to the node kubeadm is executing on. An argument name in this list is the flag name as it appears on the command line except without leading dash(es). Extra arguments will override existing default arguments. Duplicate extra arguments are allowed.

Taints are additional taints to set for the kubelet.

ignorePreflightErrors string[]

IgnorePreflightErrors provides a slice of pre-flight errors to be ignored when the current node is registered, e.g. 'IsPrivilegedUser,Swap'. Value 'all' ignores errors from all checks.

imagePullPolicy string

ImagePullPolicy specifies the policy for image pulling during kubeadm "init" and "join" operations. The value of this field must be one of "Always", "IfNotPresent" or "Never". If this field is unset kubeadm will default it to "IfNotPresent", or pull the required images if not present on the host.

AutoNodes stores auto nodes configuration.

vpn object
2 nested properties
enabled boolean

Enabled defines if the private nodes vpn should be enabled.

nodeToNode object
1 nested properties
enabled boolean

Enabled defines if the node to node vpn should be enabled.

PrivateNodesAutoNodes object

PrivateNodesAutoNodes defines auto nodes

provider string required

Provider is the node provider of the nodes in this pool.

properties Record<string, string>

Properties are the node provider properties. This is a simple key value map and can contain things like region, subscription, etc. that is then used by the node provider to create the nodes and node environment.

Static defines static node pools. Static node pools have a fixed size and are not scaled automatically.

Dynamic defines dynamic node pools. Dynamic node pools are scaled automatically based on the requirements within the cluster. Karpenter is used under the hood to handle the scheduling of the nodes.

PrivateNodesVPN object
enabled boolean

Enabled defines if the private nodes vpn should be enabled.

nodeToNode object
1 nested properties
enabled boolean

Enabled defines if the node to node vpn should be enabled.

PrivateNodesVPNNodeToNode object
enabled boolean

Enabled defines if the node to node vpn should be enabled.

Proxy object
customResources Record<string, object>

CustomResources is a map of resource keys (format: "kind.apiGroup/version") to proxy configuration

RBAC object
role object
3 nested properties
enabled boolean

Enabled defines if the role should be enabled or disabled.

extraRules object[]

ExtraRules will add rules to the role.

overwriteRules object[]

OverwriteRules will overwrite the role rules completely.

clusterRole object
3 nested properties
enabled string | boolean

Enabled defines if the cluster role should be enabled or disabled. If auto, vCluster automatically determines whether the virtual cluster requires a cluster role.

extraRules object[]

ExtraRules will add rules to the cluster role.

overwriteRules object[]

OverwriteRules will overwrite the cluster role rules completely.

enableVolumeSnapshotRules object
1 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

RBACClusterRole object
enabled string | boolean

Enabled defines if the cluster role should be enabled or disabled. If auto, vCluster automatically determines whether the virtual cluster requires a cluster role.

extraRules object[]

ExtraRules will add rules to the cluster role.

overwriteRules object[]

OverwriteRules will overwrite the cluster role rules completely.

RBACPolicyRule object
verbs string[]

Verbs is a list of Verbs that apply to ALL the ResourceKinds contained in this rule. '*' represents all verbs.

apiGroups string[]

APIGroups is the name of the APIGroup that contains the resources. If multiple API groups are specified, any action requested against one of the enumerated resources in any API group will be allowed. "" represents the core API group and "*" represents all API groups.

resources string[]

Resources is a list of resources this rule applies to. '*' represents all resources.

resourceNames string[]

ResourceNames is an optional white list of names that the rule applies to. An empty set means that everything is allowed.

nonResourceURLs string[]

NonResourceURLs is a set of partial urls that a user should have access to. *s are allowed, but only as the full, final step in the path Since non-resource URLs are not namespaced, this field is only applicable for ClusterRoles referenced from a ClusterRoleBinding. Rules can either apply to API resources (such as "pods" or "secrets") or non-resource URL paths (such as "/api"), but not both.

RBACRole object
enabled boolean

Enabled defines if the role should be enabled or disabled.

extraRules object[]

ExtraRules will add rules to the role.

overwriteRules object[]

OverwriteRules will overwrite the role rules completely.

ReadinessProbe object

ReadinessProbe defines the configuration for the readiness probe.

enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures for the probe to be considered failed

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

Registry object
enabled boolean

Enabled defines if the embedded registry should be enabled.

anonymousPull boolean

AnonymousPull allows enabling anonymous pull for the embedded registry. This allows anybody to pull images from the registry without authentication.

config

Config is the regular docker registry config. See https://distribution.github.io/distribution/about/configuration/ for more details.

ReplicateServices object

ToHost defines the services that should get synced from virtual cluster to the host cluster. If services are synced to a different namespace than the virtual cluster is in, additional permissions for the other namespace are required.

fromHost ServiceMapping[]

FromHost defines the services that should get synced from the host to the virtual cluster.

Requirement object

KarpenterRequirement defines a scheduling requirement for a dynamic node pool.

property string required

Property is the property on the node type to select.

operator string

Operator is the comparison operator, such as "In", "NotIn", "Exists". If empty, defaults to "In".

values string[]

Values is the list of values to use for comparison. This is mutually exclusive with value.

value string

Value is the value to use for comparison. This is mutually exclusive with values.

ResolveDNS object
hostname string

Hostname is the hostname within the vCluster that should be resolved from.

service string

Service is the virtual cluster service that should be resolved from.

namespace string

Namespace is the virtual cluster namespace that should be resolved from.

target object
5 nested properties
hostname string

Hostname to use as a DNS target

ip string

IP to use as a DNS target

hostService string

HostService to target, format is hostNamespace/hostService

hostNamespace string

HostNamespace to target

vClusterService string

VClusterService format is hostNamespace/vClusterName/vClusterNamespace/vClusterService

ResolveDNSTarget object
hostname string

Hostname to use as a DNS target

ip string

IP to use as a DNS target

hostService string

HostService to target, format is hostNamespace/hostService

hostNamespace string

HostNamespace to target

vClusterService string

VClusterService format is hostNamespace/vClusterName/vClusterNamespace/vClusterService

ResourceQuota object
enabled string | boolean

Enabled defines if the resource quota should be enabled. "auto" means that if limitRange is enabled, the resourceQuota will be enabled as well.

quota object

Quota are the quota options

scopeSelector object

ScopeSelector is the resource quota scope selector

scopes string[]

Scopes are the resource quota scopes

annotations Record<string, string>

Annotations are extra annotations for this resource.

labels Record<string, string>

Labels are extra labels for this resource.

Resources object
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

RuleWithVerbs object
apiGroups string[]

APIGroups is the API groups the resources belong to. '*' is all groups.

apiVersions string[]

APIVersions is the API versions the resources belong to. '*' is all versions.

resources string[]

Resources is a list of resources this rule applies to.

scope string

Scope specifies the scope of this rule.

operations string[]

Verb is the kube verb associated with the request for API requests, not the http verb. This includes things like list and watch. For non-resource requests, this is the lowercase http verb. If '*' is present, the length of the slice must be one.

SelectorConfig object
selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
ServiceMapping object
from string

From is the service that should get synced. Can be either in the form name or namespace/name.

to string

To is the target service that it should get synced to. Can be either in the form name or namespace/name.

ServiceMonitor object
enabled boolean

Enabled configures if Helm should create the service monitor.

labels Record<string, string>

Labels are the extra labels to add to the service monitor.

annotations Record<string, string>

Annotations are the extra annotations to add to the service monitor.

Sleep object

Sleep holds configuration for automatically putting the virtual cluster to sleep.

auto object

SleepAuto holds configuration for automatic sleep and wakeup

5 nested properties
afterInactivity string

AfterInactivity represents how long a vCluster can be idle before workloads are automatically put to sleep

schedule string

Schedule represents a cron schedule for when to sleep workloads

exclude object

SleepAutoExclusion holds conifiguration for excluding workloads from sleeping by label(s)

1 nested properties
selector object
wakeup object

SleepAutoWakeup holds the cron schedule to wake workloads automatically

1 nested properties
schedule string
timezone string

Timezone specifies time zone used for scheduled sleep operations. Defaults to UTC. Accepts the same format as time.LoadLocation() in Go (https://pkg.go.dev/time#LoadLocation). The value should be a location name corresponding to a file in the IANA Time Zone database, such as "America/New_York". +optional

SleepAuto object

SleepAuto holds configuration for automatic sleep and wakeup

afterInactivity string

AfterInactivity represents how long a vCluster can be idle before workloads are automatically put to sleep

schedule string

Schedule represents a cron schedule for when to sleep workloads

exclude object

SleepAutoExclusion holds conifiguration for excluding workloads from sleeping by label(s)

1 nested properties
selector object
1 nested properties
labels Record<string, string>

Labels defines what labels should be looked for

wakeup object

SleepAutoWakeup holds the cron schedule to wake workloads automatically

1 nested properties
schedule string
timezone string

Timezone specifies time zone used for scheduled sleep operations. Defaults to UTC. Accepts the same format as time.LoadLocation() in Go (https://pkg.go.dev/time#LoadLocation). The value should be a location name corresponding to a file in the IANA Time Zone database, such as "America/New_York". +optional

SleepAutoExclusion object

SleepAutoExclusion holds conifiguration for excluding workloads from sleeping by label(s)

selector object
1 nested properties
labels Record<string, string>

Labels defines what labels should be looked for

SleepAutoWakeup object

SleepAutoWakeup holds the cron schedule to wake workloads automatically

schedule string
SnapshotRetention object

SnapshotRetention holds snapshot retention configuration

period integer

Period defines the number of days a snapshot will be kept +optional

maxSnapshots integer

MaxSnapshots defines the number of snapshots that can be taken +optional

SnapshotSecretCredential object

SnapshotSecretCredential holds secret reference for credentials

secretName string

SecretName is the secret name with credential +optional

secretNamespace string

SecretNamespace is the secret namespace with credential +optional

SnapshotStorage object

SnapshotStorage holds snapshot storage configuration

type string

Type specifies supported type of storage services for a snapshot S3/OCI/Container, see https://www.vcluster.com/docs/vcluster/manage/backup-restore#store-snapshots-in-s3-buckets +optional

s3 object

SnapshotStorageS3 holds S3 storage configuration

2 nested properties
url string

Url specifies url to the storage service +optional

credential object

SnapshotSecretCredential holds secret reference for credentials

2 nested properties
secretName string

SecretName is the secret name with credential +optional

secretNamespace string

SecretNamespace is the secret namespace with credential +optional

oci object

SnapshotStorageOCI holds OCI registry storage configuration

4 nested properties
repository string

Repository OCI repository to store the snapshot +optional

credential object

SnapshotSecretCredential holds secret reference for credentials

2 nested properties
secretName string

SecretName is the secret name with credential +optional

secretNamespace string

SecretNamespace is the secret namespace with credential +optional

username string

Username to authenticate with the OCI registry +optional

password string

Password to authenticate with the OCI registry +optional

container object

SnapshotStorageContainer holds container local storage configuration

2 nested properties
path string

Path specifies directory to store the snapshot +optional

volume object

SnapshotStorageContainerVolume holds volume mount configuration

2 nested properties
name string

Name to be used to mount the volume +optional

path string

Path to the volume mount +optional

SnapshotStorageContainer object

SnapshotStorageContainer holds container local storage configuration

path string

Path specifies directory to store the snapshot +optional

volume object

SnapshotStorageContainerVolume holds volume mount configuration

2 nested properties
name string

Name to be used to mount the volume +optional

path string

Path to the volume mount +optional

SnapshotStorageContainerVolume object

SnapshotStorageContainerVolume holds volume mount configuration

name string

Name to be used to mount the volume +optional

path string

Path to the volume mount +optional

SnapshotStorageOCI object

SnapshotStorageOCI holds OCI registry storage configuration

repository string

Repository OCI repository to store the snapshot +optional

credential object

SnapshotSecretCredential holds secret reference for credentials

2 nested properties
secretName string

SecretName is the secret name with credential +optional

secretNamespace string

SecretNamespace is the secret namespace with credential +optional

username string

Username to authenticate with the OCI registry +optional

password string

Password to authenticate with the OCI registry +optional

SnapshotStorageS3 object

SnapshotStorageS3 holds S3 storage configuration

url string

Url specifies url to the storage service +optional

credential object

SnapshotSecretCredential holds secret reference for credentials

2 nested properties
secretName string

SecretName is the secret name with credential +optional

secretNamespace string

SecretNamespace is the secret namespace with credential +optional

SnapshotVolumes object

SnapshotVolumes holds volume snapshot configuration

enabled boolean

Enabled specifies whether a snapshot should also include volumes in the snapshot +optional

Snapshots object

Snapshots holds configuration for automatic vCluster snapshots.

auto object

SnapshotsAuto holds automatic snapshot scheduling and retention configuration

5 nested properties
schedule string

Schedule specifies a scheduled time in Cron format, see https://en.wikipedia.org/wiki/Cron for a virtual cluster snapshot to be taken +optional

timezone string

Timezone specifies time zone used for scheduled snapshot operations. Defaults to UTC. Accepts the same format as time.LoadLocation() in Go (https://pkg.go.dev/time#LoadLocation). The value should be a location name corresponding to a file in the IANA Time Zone database, such as "America/New_York". +optional

retention object

SnapshotRetention holds snapshot retention configuration

2 nested properties
period integer

Period defines the number of days a snapshot will be kept +optional

maxSnapshots integer

MaxSnapshots defines the number of snapshots that can be taken +optional

storage object

SnapshotStorage holds snapshot storage configuration

4 nested properties
type string

Type specifies supported type of storage services for a snapshot S3/OCI/Container, see https://www.vcluster.com/docs/vcluster/manage/backup-restore#store-snapshots-in-s3-buckets +optional

s3 object

SnapshotStorageS3 holds S3 storage configuration

oci object

SnapshotStorageOCI holds OCI registry storage configuration

container object

SnapshotStorageContainer holds container local storage configuration

volumes object

SnapshotVolumes holds volume snapshot configuration

1 nested properties
enabled boolean

Enabled specifies whether a snapshot should also include volumes in the snapshot +optional

SnapshotsAuto object

SnapshotsAuto holds automatic snapshot scheduling and retention configuration

schedule string

Schedule specifies a scheduled time in Cron format, see https://en.wikipedia.org/wiki/Cron for a virtual cluster snapshot to be taken +optional

timezone string

Timezone specifies time zone used for scheduled snapshot operations. Defaults to UTC. Accepts the same format as time.LoadLocation() in Go (https://pkg.go.dev/time#LoadLocation). The value should be a location name corresponding to a file in the IANA Time Zone database, such as "America/New_York". +optional

retention object

SnapshotRetention holds snapshot retention configuration

2 nested properties
period integer

Period defines the number of days a snapshot will be kept +optional

maxSnapshots integer

MaxSnapshots defines the number of snapshots that can be taken +optional

storage object

SnapshotStorage holds snapshot storage configuration

4 nested properties
type string

Type specifies supported type of storage services for a snapshot S3/OCI/Container, see https://www.vcluster.com/docs/vcluster/manage/backup-restore#store-snapshots-in-s3-buckets +optional

s3 object

SnapshotStorageS3 holds S3 storage configuration

2 nested properties
url string

Url specifies url to the storage service +optional

credential object

SnapshotSecretCredential holds secret reference for credentials

oci object

SnapshotStorageOCI holds OCI registry storage configuration

4 nested properties
repository string

Repository OCI repository to store the snapshot +optional

credential object

SnapshotSecretCredential holds secret reference for credentials

username string

Username to authenticate with the OCI registry +optional

password string

Password to authenticate with the OCI registry +optional

container object

SnapshotStorageContainer holds container local storage configuration

2 nested properties
path string

Path specifies directory to store the snapshot +optional

volume object

SnapshotStorageContainerVolume holds volume mount configuration

volumes object

SnapshotVolumes holds volume snapshot configuration

1 nested properties
enabled boolean

Enabled specifies whether a snapshot should also include volumes in the snapshot +optional

Standalone object
enabled boolean

Enabled defines if standalone mode should be enabled.

dataDir string

DataDir defines the data directory for the standalone mode.

autoNodes object
3 nested properties
provider string

Provider is the node provider of the nodes in this pool.

quantity integer

Quantity is the number of nodes to deploy for standalone mode.

nodeTypeSelector Requirement[]

NodeTypeSelector filters the types of nodes that can be provisioned by this pool. All requirements must be met for a node type to be eligible.

joinNode object
8 nested properties
enabled boolean

Enabled defines if the standalone node should be joined into the cluster. If false, only the control plane binaries will be executed and no node will show up in the actual cluster.

preInstallCommands string[]

PreInstallCommands are commands that will be executed before containerd, kubelet etc. is installed.

preJoinCommands string[]

PreJoinCommands are commands that will be executed before kubeadm join is executed.

postJoinCommands string[]

PostJoinCommands are commands that will be executed after kubeadm join is executed.

containerd object
3 nested properties
enabled boolean

Enabled defines if containerd should be installed and configured by vCluster.

registry object
pauseImage string

PauseImage is the image for the pause container.

caCertPath string

CACertPath is the path to the SSL certificate authority used to secure communications between node and control-plane. Defaults to "/etc/kubernetes/pki/ca.crt".

skipPhases string[]

SkipPhases is a list of phases to skip during command execution. The list of phases can be obtained with the "kubeadm join --help" command.

nodeRegistration object
5 nested properties
criSocket string

CRI socket is the socket for the CRI.

kubeletExtraArgs KubeletExtraArg[]

KubeletExtraArgs passes through extra arguments to the kubelet. The arguments here are passed to the kubelet command line via the environment file kubeadm writes at runtime for the kubelet to source. This overrides the generic base-level configuration in the kubelet-config ConfigMap Flags have higher priority when parsing. These values are local and specific to the node kubeadm is executing on. An argument name in this list is the flag name as it appears on the command line except without leading dash(es). Extra arguments will override existing default arguments. Duplicate extra arguments are allowed.

Taints are additional taints to set for the kubelet.

ignorePreflightErrors string[]

IgnorePreflightErrors provides a slice of pre-flight errors to be ignored when the current node is registered, e.g. 'IsPrivilegedUser,Swap'. Value 'all' ignores errors from all checks.

imagePullPolicy string

ImagePullPolicy specifies the policy for image pulling during kubeadm "init" and "join" operations. The value of this field must be one of "Always", "IfNotPresent" or "Never". If this field is unset kubeadm will default it to "IfNotPresent", or pull the required images if not present on the host.

StandaloneAutoNodes object
provider string

Provider is the node provider of the nodes in this pool.

quantity integer

Quantity is the number of nodes to deploy for standalone mode.

nodeTypeSelector Requirement[]

NodeTypeSelector filters the types of nodes that can be provisioned by this pool. All requirements must be met for a node type to be eligible.

StandaloneJoinNode object
enabled boolean

Enabled defines if the standalone node should be joined into the cluster. If false, only the control plane binaries will be executed and no node will show up in the actual cluster.

preInstallCommands string[]

PreInstallCommands are commands that will be executed before containerd, kubelet etc. is installed.

preJoinCommands string[]

PreJoinCommands are commands that will be executed before kubeadm join is executed.

postJoinCommands string[]

PostJoinCommands are commands that will be executed after kubeadm join is executed.

containerd object
3 nested properties
enabled boolean

Enabled defines if containerd should be installed and configured by vCluster.

registry object
3 nested properties
configPath string

ConfigPath is the path to the containerd registry config.

mirrors Record<string, object>

Mirrors holds configuration for the containerd registry mirrors. E.g. myregistry.io:5000 or docker.io. See https://github.com/containerd/containerd/blob/main/docs/hosts.md for more details.

auth Record<string, object>

Auth holds configuration for the containerd registry auth. See https://github.com/containerd/containerd/blob/main/docs/cri/registry.md#configure-registry-credentials for more details.

pauseImage string

PauseImage is the image for the pause container.

caCertPath string

CACertPath is the path to the SSL certificate authority used to secure communications between node and control-plane. Defaults to "/etc/kubernetes/pki/ca.crt".

skipPhases string[]

SkipPhases is a list of phases to skip during command execution. The list of phases can be obtained with the "kubeadm join --help" command.

nodeRegistration object
5 nested properties
criSocket string

CRI socket is the socket for the CRI.

kubeletExtraArgs KubeletExtraArg[]

KubeletExtraArgs passes through extra arguments to the kubelet. The arguments here are passed to the kubelet command line via the environment file kubeadm writes at runtime for the kubelet to source. This overrides the generic base-level configuration in the kubelet-config ConfigMap Flags have higher priority when parsing. These values are local and specific to the node kubeadm is executing on. An argument name in this list is the flag name as it appears on the command line except without leading dash(es). Extra arguments will override existing default arguments. Duplicate extra arguments are allowed.

Taints are additional taints to set for the kubelet.

ignorePreflightErrors string[]

IgnorePreflightErrors provides a slice of pre-flight errors to be ignored when the current node is registered, e.g. 'IsPrivilegedUser,Swap'. Value 'all' ignores errors from all checks.

imagePullPolicy string

ImagePullPolicy specifies the policy for image pulling during kubeadm "init" and "join" operations. The value of this field must be one of "Always", "IfNotPresent" or "Never". If this field is unset kubeadm will default it to "IfNotPresent", or pull the required images if not present on the host.

StandardLabelSelector object
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
StartupProbe object

StartupProbe defines the configuration for the startup probe.

enabled boolean

Enabled defines if this option should be enabled.

failureThreshold integer

Number of consecutive failures allowed before failing the pod

timeoutSeconds integer

Maximum duration (in seconds) that the probe will wait for a response.

periodSeconds integer

Frequency (in seconds) to perform the probe

StaticNodePool object
name string required

Name is the name of this static nodePool

quantity integer required

Quantity is the number of desired nodes in this pool.

nodeTypeSelector Requirement[]

NodeTypeSelector filters the types of nodes that can be provisioned by this pool. All requirements must be met for a node type to be eligible.

Taints are the taints to apply to the nodes in this pool.

nodeLabels Record<string, string>

NodeLabels are the labels to apply to the nodes in this pool.

terminationGracePeriod string

TerminationGracePeriod is the maximum duration the controller will wait before forcefully deleting the pods on a node, measured from when deletion is first initiated.

Warning: this feature takes precedence over a Pod's terminationGracePeriodSeconds value, and bypasses any blocked PDBs or the karpenter.sh/do-not-disrupt annotation.

This field is intended to be used by cluster administrators to enforce that nodes can be cycled within a given time period. When set, drifted nodes will begin draining even if there are pods blocking eviction. Draining will respect PDBs and the do-not-disrupt annotation until the TGP is reached.

Karpenter will preemptively delete pods so their terminationGracePeriodSeconds align with the node's terminationGracePeriod. If a pod would be terminated without being granted its full terminationGracePeriodSeconds prior to the node timeout, that pod will be deleted at T = node timeout - pod terminationGracePeriodSeconds.

The feature can also be used to allow maximum time limits for long-running jobs which can delay node termination with preStop hooks. Defaults to 30s. Set to Never to wait indefinitely for pods to be drained.

Sync object
toHost object
20 nested properties
pods object
9 nested properties
enabled boolean

Enabled defines if pod syncing should be enabled.

translateImage Record<string, string>

TranslateImage maps an image to another image that should be used instead. For example this can be used to rewrite a certain image that is used within the virtual cluster to be another image on the host cluster

enforceTolerations string[]

EnforceTolerations will add the specified tolerations to all pods synced by the virtual cluster.

useSecretsForSATokens boolean

UseSecretsForSATokens will use secrets to save the generated service account tokens by virtual cluster instead of using a pod annotation.

runtimeClassName string

RuntimeClassName is the runtime class to set for synced pods.

priorityClassName string

PriorityClassName is the priority class to set for synced pods.

rewriteHosts object

Patches patch the resource according to the provided specification.

hybridScheduling object
secrets object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

all boolean

All defines if all resources of that type should get synced or only the necessary ones that are needed.

Patches patch the resource according to the provided specification.

configMaps object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

all boolean

All defines if all resources of that type should get synced or only the necessary ones that are needed.

Patches patch the resource according to the provided specification.

ingresses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

services object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

endpoints object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

endpointSlices object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

networkPolicies object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

persistentVolumeClaims object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

persistentVolumes object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

volumeSnapshots object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

volumeSnapshotContents object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

storageClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

serviceAccounts object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

podDisruptionBudgets object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

priorityClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

customResources Record<string, object>

CustomResources defines what custom resources should get synced from the virtual cluster to the host cluster. vCluster will copy the definition automatically from host cluster to virtual cluster on startup. vCluster will also automatically add any required RBAC permissions to the vCluster role for this to work.

namespaces object

SyncToHostNamespaces defines how namespaces should be synced from the virtual cluster to the host cluster.

5 nested properties
enabled boolean required

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
mappingsOnly boolean

MappingsOnly defines if creation of namespaces not matched by mappings should be allowed.

extraLabels Record<string, string>

ExtraLabels are additional labels to add to the namespace in the host cluster.

resourceClaims object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

resourceClaimTemplates object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

fromHost object
14 nested properties
nodes object
5 nested properties
enabled boolean

Enabled specifies if syncing real nodes should be enabled. If this is disabled, vCluster will create fake nodes instead.

syncBackChanges boolean

SyncBackChanges enables syncing labels and taints from the virtual cluster to the host cluster. If this is enabled someone within the virtual cluster will be able to change the labels and taints of the host cluster node.

clearImageStatus boolean

ClearImageStatus will erase the image status when syncing a node. This allows to hide images that are pulled by the node.

selector object

Patches patch the resource according to the provided specification.

events object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

ingressClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
runtimeClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
priorityClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
storageClasses object
3 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
csiNodes object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

csiDrivers object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

csiStorageCapacities object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

customResources Record<string, object>

CustomResources defines what custom resources should get synced read-only to the virtual cluster from the host cluster. vCluster will automatically add any required RBAC to the vCluster cluster role.

volumeSnapshotClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

configMaps object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
secrets object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
deviceClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
SyncAllResource object
enabled boolean

Enabled defines if this option should be enabled.

all boolean

All defines if all resources of that type should get synced or only the necessary ones that are needed.

Patches patch the resource according to the provided specification.

SyncFromHost object
nodes object
5 nested properties
enabled boolean

Enabled specifies if syncing real nodes should be enabled. If this is disabled, vCluster will create fake nodes instead.

syncBackChanges boolean

SyncBackChanges enables syncing labels and taints from the virtual cluster to the host cluster. If this is enabled someone within the virtual cluster will be able to change the labels and taints of the host cluster node.

clearImageStatus boolean

ClearImageStatus will erase the image status when syncing a node. This allows to hide images that are pulled by the node.

selector object
2 nested properties
all boolean

All specifies if all nodes should get synced by vCluster from the host to the virtual cluster or only the ones where pods are assigned to.

labels Record<string, string>

Labels are the node labels used to sync nodes from host cluster to virtual cluster. This will also set the node selector when syncing a pod from virtual cluster to host cluster to the same value.

Patches patch the resource according to the provided specification.

events object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

ingressClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
runtimeClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
priorityClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
storageClasses object
3 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
csiNodes object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

csiDrivers object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

csiStorageCapacities object
2 nested properties
enabled string | boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

customResources Record<string, object>

CustomResources defines what custom resources should get synced read-only to the virtual cluster from the host cluster. vCluster will automatically add any required RBAC to the vCluster cluster role.

volumeSnapshotClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

configMaps object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
1 nested properties
byName Record<string, string>

ByName is a map of host-object-namespace/host-object-name: virtual-object-namespace/virtual-object-name. There are several wildcards supported:

  1. To match all objects in host namespace and sync them to different namespace in vCluster: byName: "foo/": "foo-in-virtual/"
  2. To match specific object in the host namespace and sync it to the same namespace with the same name: byName: "foo/my-object": "foo/my-object"
  3. To match specific object in the host namespace and sync it to the same namespace with different name: byName: "foo/my-object": "foo/my-virtual-object"
  4. To match all objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "": "my-virtual-namespace/*"
  5. To match specific objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "/my-object": "my-virtual-namespace/my-object"
secrets object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
1 nested properties
byName Record<string, string>

ByName is a map of host-object-namespace/host-object-name: virtual-object-namespace/virtual-object-name. There are several wildcards supported:

  1. To match all objects in host namespace and sync them to different namespace in vCluster: byName: "foo/": "foo-in-virtual/"
  2. To match specific object in the host namespace and sync it to the same namespace with the same name: byName: "foo/my-object": "foo/my-object"
  3. To match specific object in the host namespace and sync it to the same namespace with different name: byName: "foo/my-object": "foo/my-virtual-object"
  4. To match all objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "": "my-virtual-namespace/*"
  5. To match specific objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "/my-object": "my-virtual-namespace/my-object"
deviceClasses object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

selector object
2 nested properties
matchLabels Record<string, string>
matchExpressions LabelSelectorRequirement[]
SyncFromHostCustomResource object
enabled boolean required

Enabled defines if this option should be enabled.

scope string required

Scope defines the scope of the resource

Patches patch the resource according to the provided specification.

mappings object
1 nested properties
byName Record<string, string>

ByName is a map of host-object-namespace/host-object-name: virtual-object-namespace/virtual-object-name. There are several wildcards supported:

  1. To match all objects in host namespace and sync them to different namespace in vCluster: byName: "foo/": "foo-in-virtual/"
  2. To match specific object in the host namespace and sync it to the same namespace with the same name: byName: "foo/my-object": "foo/my-object"
  3. To match specific object in the host namespace and sync it to the same namespace with different name: byName: "foo/my-object": "foo/my-virtual-object"
  4. To match all objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "": "my-virtual-namespace/*"
  5. To match specific objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "/my-object": "my-virtual-namespace/my-object"
SyncNodeSelector object
all boolean

All specifies if all nodes should get synced by vCluster from the host to the virtual cluster or only the ones where pods are assigned to.

labels Record<string, string>

Labels are the node labels used to sync nodes from host cluster to virtual cluster. This will also set the node selector when syncing a pod from virtual cluster to host cluster to the same value.

SyncNodes object
enabled boolean

Enabled specifies if syncing real nodes should be enabled. If this is disabled, vCluster will create fake nodes instead.

syncBackChanges boolean

SyncBackChanges enables syncing labels and taints from the virtual cluster to the host cluster. If this is enabled someone within the virtual cluster will be able to change the labels and taints of the host cluster node.

clearImageStatus boolean

ClearImageStatus will erase the image status when syncing a node. This allows to hide images that are pulled by the node.

selector object
2 nested properties
all boolean

All specifies if all nodes should get synced by vCluster from the host to the virtual cluster or only the ones where pods are assigned to.

labels Record<string, string>

Labels are the node labels used to sync nodes from host cluster to virtual cluster. This will also set the node selector when syncing a pod from virtual cluster to host cluster to the same value.

Patches patch the resource according to the provided specification.

SyncPods object
enabled boolean

Enabled defines if pod syncing should be enabled.

translateImage Record<string, string>

TranslateImage maps an image to another image that should be used instead. For example this can be used to rewrite a certain image that is used within the virtual cluster to be another image on the host cluster

enforceTolerations string[]

EnforceTolerations will add the specified tolerations to all pods synced by the virtual cluster.

useSecretsForSATokens boolean

UseSecretsForSATokens will use secrets to save the generated service account tokens by virtual cluster instead of using a pod annotation.

runtimeClassName string

RuntimeClassName is the runtime class to set for synced pods.

priorityClassName string

PriorityClassName is the priority class to set for synced pods.

rewriteHosts object
2 nested properties
enabled boolean

Enabled specifies if rewriting stateful set pods should be enabled.

initContainer object
2 nested properties
image object
resources object

Patches patch the resource according to the provided specification.

hybridScheduling object
2 nested properties
enabled boolean

Enabled specifies if hybrid scheduling is enabled.

hostSchedulers string[]

HostSchedulers is a list of schedulers that are deployed on the host cluster.

SyncRewriteHosts object
enabled boolean

Enabled specifies if rewriting stateful set pods should be enabled.

initContainer object
2 nested properties
image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

SyncRewriteHostsInitContainer object
image object
3 nested properties
registry string

Registry is the registry of the container image, e.g. my-registry.com or ghcr.io. This setting can be globally overridden via the controlPlane.advanced.defaultImageRegistry option. Empty means docker hub.

repository string

Repository is the repository of the container image, e.g. my-repo/my-image

tag string

Tag is the tag of the container image, and is the default version.

resources object
2 nested properties
limits object

Limits are resource limits for the container

requests object

Requests are minimal resources that will be consumed by the container

SyncToHost object
pods object
9 nested properties
enabled boolean

Enabled defines if pod syncing should be enabled.

translateImage Record<string, string>

TranslateImage maps an image to another image that should be used instead. For example this can be used to rewrite a certain image that is used within the virtual cluster to be another image on the host cluster

enforceTolerations string[]

EnforceTolerations will add the specified tolerations to all pods synced by the virtual cluster.

useSecretsForSATokens boolean

UseSecretsForSATokens will use secrets to save the generated service account tokens by virtual cluster instead of using a pod annotation.

runtimeClassName string

RuntimeClassName is the runtime class to set for synced pods.

priorityClassName string

PriorityClassName is the priority class to set for synced pods.

rewriteHosts object
2 nested properties
enabled boolean

Enabled specifies if rewriting stateful set pods should be enabled.

initContainer object

Patches patch the resource according to the provided specification.

hybridScheduling object
2 nested properties
enabled boolean

Enabled specifies if hybrid scheduling is enabled.

hostSchedulers string[]

HostSchedulers is a list of schedulers that are deployed on the host cluster.

secrets object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

all boolean

All defines if all resources of that type should get synced or only the necessary ones that are needed.

Patches patch the resource according to the provided specification.

configMaps object
3 nested properties
enabled boolean

Enabled defines if this option should be enabled.

all boolean

All defines if all resources of that type should get synced or only the necessary ones that are needed.

Patches patch the resource according to the provided specification.

ingresses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

services object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

endpoints object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

endpointSlices object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

networkPolicies object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

persistentVolumeClaims object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

persistentVolumes object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

volumeSnapshots object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

volumeSnapshotContents object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

storageClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

serviceAccounts object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

podDisruptionBudgets object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

priorityClasses object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

customResources Record<string, object>

CustomResources defines what custom resources should get synced from the virtual cluster to the host cluster. vCluster will copy the definition automatically from host cluster to virtual cluster on startup. vCluster will also automatically add any required RBAC permissions to the vCluster role for this to work.

namespaces object

SyncToHostNamespaces defines how namespaces should be synced from the virtual cluster to the host cluster.

5 nested properties
enabled boolean required

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
1 nested properties
byName Record<string, string>

ByName is a map of host-object-namespace/host-object-name: virtual-object-namespace/virtual-object-name. There are several wildcards supported:

  1. To match all objects in host namespace and sync them to different namespace in vCluster: byName: "foo/": "foo-in-virtual/"
  2. To match specific object in the host namespace and sync it to the same namespace with the same name: byName: "foo/my-object": "foo/my-object"
  3. To match specific object in the host namespace and sync it to the same namespace with different name: byName: "foo/my-object": "foo/my-virtual-object"
  4. To match all objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "": "my-virtual-namespace/*"
  5. To match specific objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "/my-object": "my-virtual-namespace/my-object"
mappingsOnly boolean

MappingsOnly defines if creation of namespaces not matched by mappings should be allowed.

extraLabels Record<string, string>

ExtraLabels are additional labels to add to the namespace in the host cluster.

resourceClaims object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

resourceClaimTemplates object
2 nested properties
enabled boolean

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

SyncToHostCustomResource object
enabled boolean required

Enabled defines if this option should be enabled.

scope string

Scope defines the scope of the resource. If undefined, will use Namespaced. Currently only Namespaced is supported.

Patches patch the resource according to the provided specification.

SyncToHostNamespaces object

SyncToHostNamespaces defines how namespaces should be synced from the virtual cluster to the host cluster.

enabled boolean required

Enabled defines if this option should be enabled.

Patches patch the resource according to the provided specification.

mappings object
1 nested properties
byName Record<string, string>

ByName is a map of host-object-namespace/host-object-name: virtual-object-namespace/virtual-object-name. There are several wildcards supported:

  1. To match all objects in host namespace and sync them to different namespace in vCluster: byName: "foo/": "foo-in-virtual/"
  2. To match specific object in the host namespace and sync it to the same namespace with the same name: byName: "foo/my-object": "foo/my-object"
  3. To match specific object in the host namespace and sync it to the same namespace with different name: byName: "foo/my-object": "foo/my-virtual-object"
  4. To match all objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "": "my-virtual-namespace/*"
  5. To match specific objects in the vCluster host namespace and sync them to a different namespace in vCluster: byName: "/my-object": "my-virtual-namespace/my-object"
mappingsOnly boolean

MappingsOnly defines if creation of namespaces not matched by mappings should be allowed.

extraLabels Record<string, string>

ExtraLabels are additional labels to add to the namespace in the host cluster.

Telemetry object
enabled boolean

Enabled specifies that the telemetry for the vCluster control plane should be enabled.

instanceCreator string
machineID string
platformUserID string
platformInstanceID string
TranslatePatch object
path string required

Path is the path within the patch to target. If the path is not found within the patch, the patch is not applied.

expression string

Expression transforms the value according to the given JavaScript expression.

reverseExpression string

ReverseExpression transforms the value according to the given JavaScript expression.

reference object
6 nested properties
apiVersion string required

APIVersion is the apiVersion of the referenced object.

kind string required

Kind is the kind of the referenced object.

apiVersionPath string

APIVersionPath is optional relative path to use to determine the kind. If APIVersionPath is not found, will fallback to apiVersion.

kindPath string

KindPath is the optional relative path to use to determine the kind. If KindPath is not found, will fallback to kind.

namePath string

NamePath is the optional relative path to the reference name within the object.

namespacePath string

NamespacePath is the optional relative path to the reference namespace within the object. If omitted or not found, namespacePath equals to the metadata.namespace path of the object.

labels object
TranslatePatchLabels object
TranslatePatchReference object
apiVersion string required

APIVersion is the apiVersion of the referenced object.

kind string required

Kind is the kind of the referenced object.

apiVersionPath string

APIVersionPath is optional relative path to use to determine the kind. If APIVersionPath is not found, will fallback to apiVersion.

kindPath string

KindPath is the optional relative path to use to determine the kind. If KindPath is not found, will fallback to kind.

namePath string

NamePath is the optional relative path to the reference name within the object.

namespacePath string

NamespacePath is the optional relative path to the reference namespace within the object. If omitted or not found, namespacePath equals to the metadata.namespace path of the object.

ValidatingWebhook object
name string

The name of the admission webhook. Name should be fully qualified, e.g., imagepolicy.kubernetes.io, where "imagepolicy" is the name of the webhook, and kubernetes.io is the name of the organization.

clientConfig object

ValidatingWebhookClientConfig contains the information to make a TLS connection with the webhook

3 nested properties
url string

URL gives the location of the webhook, in standard URL form (scheme://host:port/path). Exactly one of url or service must be specified.

service object
4 nested properties
namespace string

Namespace is the namespace of the service.

name string

Name is the name of the service.

path string

Path is an optional URL path which will be sent in any request to this service.

port integer

If specified, the port on the service that hosting webhook. Default to 443 for backward compatibility. port should be a valid port number (1-65535, inclusive).

caBundle string

CABundle is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.

rules array

Rules describes what operations on what resources/subresources the webhook cares about. The webhook cares about an operation if it matches any Rule.

failurePolicy string

FailurePolicy defines how unrecognized errors from the admission endpoint are handled - allowed values are Ignore or Fail. Defaults to Fail.

matchPolicy string

matchPolicy defines how the "rules" list is used to match incoming requests. Allowed values are "Exact" or "Equivalent".

namespaceSelector

NamespaceSelector decides whether to run the webhook on an object based on whether the namespace for that object matches the selector. If the object itself is a namespace, the matching is performed on object.metadata.labels. If the object is another cluster scoped resource, it never skips the webhook.

objectSelector

ObjectSelector decides whether to run the webhook based on if the object has matching labels. objectSelector is evaluated against both the oldObject and newObject that would be sent to the webhook, and is considered to match if either object matches the selector.

sideEffects string

SideEffects states whether this webhook has side effects.

timeoutSeconds integer

TimeoutSeconds specifies the timeout for this webhook.

admissionReviewVersions string[]

AdmissionReviewVersions is an ordered list of preferred AdmissionReview versions the Webhook expects.

matchConditions array

MatchConditions is a list of conditions that must be met for a request to be sent to this webhook. Match conditions filter requests that have already been matched by the rules, namespaceSelector, and objectSelector. An empty list of matchConditions matches all requests. There are a maximum of 64 match conditions allowed.

ValidatingWebhookClientConfig object

ValidatingWebhookClientConfig contains the information to make a TLS connection with the webhook

url string

URL gives the location of the webhook, in standard URL form (scheme://host:port/path). Exactly one of url or service must be specified.

service object
4 nested properties
namespace string

Namespace is the namespace of the service.

name string

Name is the name of the service.

path string

Path is an optional URL path which will be sent in any request to this service.

port integer

If specified, the port on the service that hosting webhook. Default to 443 for backward compatibility. port should be a valid port number (1-65535, inclusive).

caBundle string

CABundle is a PEM encoded CA bundle which will be used to validate the webhook's server certificate. If unspecified, system trust roots on the apiserver are used.

ValidatingWebhookConfiguration object
kind string

Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to.

apiVersion string

APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values.

metadata object
3 nested properties
name string

Name must be unique within a namespace. Is required when creating resources, although some resources may allow a client to request the generation of an appropriate name automatically. Name is primarily intended for creation idempotence and configuration definition.

labels Record<string, string>

Map of string keys and values that can be used to organize and categorize (scope and select) objects. May match selectors of replication controllers and services.

annotations Record<string, string>

Annotations is an unstructured key value map stored with a resource that may be set by external tools to store and retrieve arbitrary metadata.

Webhooks is a list of webhooks and the affected resources and operations.

ValidatingWebhookServiceReference object
namespace string

Namespace is the namespace of the service.

name string

Name is the name of the service.

path string

Path is an optional URL path which will be sent in any request to this service.

port integer

If specified, the port on the service that hosting webhook. Default to 443 for backward compatibility. port should be a valid port number (1-65535, inclusive).

VirtualClusterKubeConfig object
kubeConfig string

KubeConfig is the virtual cluster kubeconfig path.

serverCAKey string

ServerCAKey is the server ca key path.

serverCACert string

ServerCAKey is the server ca cert path.

clientCACert string

ServerCAKey is the client ca cert path.

requestHeaderCACert string

RequestHeaderCACert is the request header ca cert path.

VirtualClusterRef object

VirtualClusterRef is a reference to a virtual cluster within the platform.

name string required

Name is the name of the target virtual cluster.

minLength=1pattern=^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
project string

Project is the project of the target virtual cluster. If empty, defaults to the same project as the source vCluster.

pattern=^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
VolumeClaim object
enabled string | boolean

Enabled enables deploying a persistent volume claim. If auto, vCluster will automatically determine based on the chosen distro and other options if this is required.

accessModes string[]

AccessModes are the persistent volume claim access modes.

retentionPolicy string

RetentionPolicy is the persistent volume claim retention policy.

size string

Size is the persistent volume claim storage size.

storageClass string

StorageClass is the persistent volume claim storage class.

VolumeMount object

VolumeMount describes a mounting of a Volume within a container.

name string

This must match the Name of a Volume.

readOnly boolean

Mounted read-only if true, read-write otherwise (false or unspecified). Defaults to false.

mountPath string

Path within the container at which the volume should be mounted. Must not contain ':'.

subPath string

Path within the volume from which the container's volume should be mounted. Defaults to "" (volume's root).

mountPropagation string

mountPropagation determines how mounts are propagated from the host to container and the other way around. When not set, MountPropagationNone is used. This field is beta in 1.10.

subPathExpr string

Expanded path within the volume from which the container's volume should be mounted. Behaves similarly to SubPath but environment variable references $(VAR_NAME) are expanded using the container's environment. Defaults to "" (volume's root). SubPathExpr and SubPath are mutually exclusive.

VolumeSnapshotController object

VolumeSnapshotController defines CSI volumes snapshot-controller configuration.

enabled boolean

Enabled defines if the CSI volumes snapshot-controller should be enabled.