Virtual Cluster Templates
Loft allows you to create templates for virtual clusters. Virtual cluster templates are optional templates that a user can choose to apply when creating a virtual cluster.
Common use cases for virtual cluster templates may be:
- Adding development tooling to a virtual cluster
- Deploying pre-populated databases with test data
- Equipping new virtual clusters with optional credentials, CRDs, etc.
Working with Virtual Cluster Templates
1. Create Virtual Cluster Template
- Go to the Virtual Clusters view using the menu on the left
- Switch to the Virtual Cluster Templates tab
- Click the button to create a new virtual cluster template
- In the drawer that appears on the right, use the field Display Name to specify a Name for your virtual cluster template
- Specify any of these options: labels, annotations, virtual cluster version, helm values and apps to deployed
- Expand the Space Template should be applied for the underlying host namespace if being created as part of the virtual clusters creation process section to specify which
- On the very bottom, click on the button to create this virtual cluster template
2. Create Virtual Cluster Based On Template
- UI
- CLI
- Go to the Virtual Clusters view using the menu on the left
- Click on the button
- Use the field Virtual Cluster Template to select a template to use for creating this virtual cluster
- Use the field Display Name to define the name of this space and optionally specify other settings
- Click on the button at the very bottom
Retrieve a kube-context for this virtual cluster using Loft CLI:
loft use vcluster [vcluster-name]
To use a virtual cluster template to create a virtual cluster using Loft CLI, run:
loft create vcluster [vcluster-name] --template [template-name]
Kube-Context
Running loft create vcluster
will automatically add a kube-context to your kube-config file, so you can immediately run kubectl
commands right after creating a virtual cluster.
Configuration
Metadata
Display Name
data:image/s3,"s3://crabby-images/49604/496047998ae43d5442d7383ced271eef934ea34a" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.displayName (type: string)
Kubernetes Name
data:image/s3,"s3://crabby-images/a902a/a902a23606a9ab4b8ef62bebb81a3fc6aa1a998d" alt=""
JSONPath in VirtualClusterTemplate CRD:
metadata.name (type: string)
Description
data:image/s3,"s3://crabby-images/5d0d1/5d0d1b0542b8e22d498adcf30499085bbcaff115" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.description (type: string)
Labels
data:image/s3,"s3://crabby-images/342e0/342e050a581627209dc443cc23a34fb19d7b446e" alt=""
JSONPath in VirtualClusterTemplate CRD:
metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/e99a8/e99a8f824c297e9e2c94571a0e678dd2ab1823ab" alt=""
JSONPath in VirtualClusterTemplate CRD:
metadata.annotations (type: map[string]string)
Template For Virtual Clusters
Labels
data:image/s3,"s3://crabby-images/2c4e5/2c4e54f84c62cec889ec23699e21f69e99680168" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.template.metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/fca0d/fca0dae30edc787e225dc6e8b3334549f6a84230" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.template.metadata.annotations (type: map[string]string)
Version
data:image/s3,"s3://crabby-images/fb692/fb692fb0c77064b5fcda7757488ed001938a1f5e" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.template.helmRelease.chart.version (type: string)
Helm Values
data:image/s3,"s3://crabby-images/78a5e/78a5e095375d4392a1f23c484b83209e05da217e" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.template.helmRelease.values (type: {})
Apps
data:image/s3,"s3://crabby-images/109c0/109c045d8d86c1254717787469dde6c13d4f7190" alt=""
Namespaces For Apps
Space Template
data:image/s3,"s3://crabby-images/a5213/a52130fb0211b2c17531a99d8c492923f5707b44" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.spaceTemplateRef (type: string)
Access To Virtual Cluster Template
data:image/s3,"s3://crabby-images/9760e/9760ef9c23bb5c280dc1a7afd48cadf15c7196f5" alt=""
JSONPath in VirtualClusterTemplate CRD:
spec.access (type: Access[])