Create a virtual cluster from a template
Each virtual cluster that is created in the platform belongs to a project. There are two primary ways which virtual clusters can be created: from a template or manually.
Virtual clusters created from a template settings. Standard project users (non project admins) are only allowed to create virtual clusters from templates that the project admin has allowed. This ensures that virtual clusters in each project adhere to the standards set by the project admin.
Project admins and platform admins can create virtual clusters manually, that is without a template.
Once you have created a virtual cluster template you can then refer to that template when creating a new virtual cluster. All template configurations will be automatically applied to the newly created virtual cluster. Virtual clusters referring to templates can be created in the UI or via the vCluster CLI.
- UI
- CLI
- From the project drop-down menu (top left corner), select the project you'd like to create the virtual cluster in. 
- Click on Virtual Clusters. 
- Click the button. 
- In the pop-up box, select your template from the template drop down menu. 
- [Optional] Select the cluster in which to create the virtual cluster. 
- [Optional] Add a name for your virtual cluster. 
- Click the to continue. 
- Retrieve a kube-context for a virtual cluster using the CLI: - vcluster connect [vcluster-name] --project [project-name] --driver platform
When creating a virtual cluster from the vCluster CLI, you will need to provide the name of the project in which to deploy the virtual cluster, and the name of template to use:
vcluster create [vcluster-name] --project [project-name] --template [template-name] --driver platform
If you omit specifying a template, vCluster Platform will automatically select one for you (if there is a default template in the project specified) or prompt you to select a template.
Running vcluster create will automatically add a kube-context to your kube-config file,
so you can immediately run kubectl commands right after creating a virtual cluster.
Template Version Strings​
Regardless of how you create a virtual cluster from a template, either by the UI or the CLI, you will be prompted to provide a template version string. If you do not provide this string, the latest
version will be automatically selected for you. If you do provide the string though, you can
do something very neat -- you can set any of the MAJOR, MINOR, PATCH version components to an
X wildcard character. This allows the virtual cluster to be automatically updated to a more recent
template version that matches your provided template string.
For example, given a template with a version of 1.0.0, and a virtual cluster created from this template with a version string "1.X.X". Adding a new template version "1.1.0", will cause this virtual cluster to be automatically updated. Whereas adding a new version "2.0.0", will not cause the virtual cluster to be upgraded.
This is a very handy way to keep virtual clusters up to date with the latest templates without having to manually upgrade them.
Note that you can even set the version to "X.X.X" to always have your virtual cluster updated to the latest template version.
The platform uses Helm to manage virtual clusters. If your cluster is running in an air-gapped environment, you may host Helm charts in an OCI compatible private registry. To use a private registry for virtual clusters there are several configuration options:
- Configure the platform for offline Helm charts
- Configure the Helm chart repository and authentication for each virtual cluster.
- Configure the Helm chart repository and authentication using virtual cluster templates.