Contribute to vCluster Docs
This docs website is built using Docusaurus v3, a modern static website generator.
Quick start with DevPodβ
Use DevPod to quickly set up a complete development environment and start contributing.
- Install DevPod for your operating system.
- Once installed, click the following to open this repository in DevPod:
This will automatically set up all dependencies and configurations needed for working on the documentation, including:
- Node.js and npm for running the development server
- The Vale linter for checking documentation style and grammar
- VS Code extensions for Vale and ESLint
- Pre-configured settings for the documentation workflow
Manual deploymentβ
Fork the vCluster docs repository and clone your fork locally
git clone https://github.com/<your username>/vcluster-docs
then run the following command to install dependencies:
npm install
This repository requires Node.js version 18.0 or higher.
Local developmentβ
Run the following command to start a local development server:
npm run start
This command opens http://localhost:3000/docs in your default browser. Most changes are reflected live without having to restart the server. Note that this command doesn't always catch build errors.
Buildβ
After finishing your changes, run the following command to test production build locally:
npm run build
This command generates static content into the build directory and can be
served using any static contents hosting service.
You can run the following command to serve the built website locally:
npm run serve
Before making a pull request, it's recommended to run this command to fix any broken links that may have been introduced.
Style guideβ
Most of the style guide rules is enforced by vale linter. See the
style guide automation section for more information.
The vCluster docs use the following style guides in this order:
- Google developer documentation style guide
- Kubernetes Documentation Style Guide for Kubernetes terms.
Page titles follow sentence case. Capitalize Kubernetes objects according to the K8s style guide.
Core principlesβ
Here are some core principles to keep in mind when writing documentation:
- 
Active voice creates stronger documentation and helps with translations - write "deploy the configuration" instead of "the configuration was deployed". 
- 
Using sentence case in headings makes content more approachable - write "Getting started with providers" instead of "Getting Started with Providers". 
- 
Keep sentences under 25 words to improve readability and SEO performance - break down complex ideas into digestible chunks. 
- 
Write in present tense - say "this command installs" rather than "this command will install". Docs refer to actions that happen in the present as users read them. 
- 
Use contractions (don't, isn't, can't) for better clarity - "don't" stands out more than "do not" when expressing negatives. 
- 
Avoid Latin phrases (e.g., i.e., etc.) - choose plain English alternatives that all readers can understand easily. 
- 
Never use terms like "easy," "simple," or "obvious" as they can undermine reader confidence and create unnecessary pressure. 
- 
Create descriptive link text - instead of "click here," explain where the link leads, such as "view the installation guide". 
- 
Spell out acronyms on first use unless they're universally known in technical contexts. 
Consistency and document flowβ
When creating new documentation, review similar existing documents to maintain consistent flow and structure. For example, see how platform deployment documentation follows a standard pattern in the Quick Start Guide. This helps readers navigate documentation intuitively since they know what to expect.
Documents of the same kind should use consistent header levels and structure. All installation guides should use the same header hierarchy and naming conventions to help users navigate between different installation options.
Docusaurus admonitions should be used consistently throughout the documentation to highlight important information.
:::note[Additional context: The `vcluster create` command automatically creates]
a new namespace if it doesn't exist. :::
:::tip[Use `vcluster` CLI to quickly deploy a virtual cluster. :::]
:::info[The default configuration uses minimal resources suitable for testing.]
:::
:::warning[Ensure your Kubernetes cluster has sufficient available memory before]
deploying vCluster. :::
:::danger[Do not delete the vCluster pod. :::]
Oxford commaβ
Use the Oxford comma (serial comma) before the last item when listing 3 or more items in a sentence.
- Do Not: vCluster requires a, b and c.
- Do: vCluster requires a, b, and c.
See Scribbr's article on the Oxford comma for a detailed explanation and examples.
Code blocksβ
Use <> to indicate placeholders in code blocks. For example:
kubectl get pods <pod-name>
Interactive code blocksβ
For code blocks that contain values users need to customize, use the InterpolatedCodeBlock component instead of regular code blocks. This allows users to edit values directly in the documentation.
Using local variables (user can edit each instance):
import InterpolatedCodeBlock from '@site/src/components/InterpolatedCodeBlock';
<InterpolatedCodeBlock
  code={`kubectl create namespace [[VAR:NAMESPACE:my-namespace]]`}
  language="bash"
/>
Using global variables (define once, use everywhere on the page):
import PageVariables from '@site/src/components/PageVariables';
import InterpolatedCodeBlock from '@site/src/components/InterpolatedCodeBlock';
<PageVariables VCLUSTER_VERSION="0.25.0" REGISTRY="ecr.io/myteam" />
<InterpolatedCodeBlock
  code={`export VCLUSTER_VERSION=[[GLOBAL:VCLUSTER_VERSION]]
export REGISTRY=[[GLOBAL:REGISTRY]]`}
  language="bash"
/>
This eliminates repeated export statements across multiple code blocks. Use PageVariables when the same values (like version numbers or registry URLs) appear in multiple code examples on a page.
Notes:
- Place PageVariablesbefore any code blocks that use those variables
- Can be placed anywhere on the page (doesn't have to be at the top)
- Multiple PageVariablescomponents will merge together
Formatting and variablesβ
To make code blocks easier to work with, consider adding variables and use here docs to make it easier to copy and paste code snippets.
Using a variable in a code block:
$POD_NAME = pod-name
kubectl get pods $POD_NAME
Creating a file using a here doc:
cat <<EOF > vcluster.yaml
controlPlane:
  # Deploy etcd instead of using the embedded SQLite
  backingStore:
    etcd:
      deploy:
        enabled: true
        statefulSet:
          highAvailability:
            replicas: 3
  # Deploy vCluster with 3 replicas
  statefulSet:
    highAvailability:
      replicas: 3
EOF
Applying a Kubernetes manifest using docs:
cat << EOF | kubectl apply -f -
apiVersion: v1
kind: Pod
metadata:
  name: example-pod
  labels:
    app: nginx
spec:
  containers:
  - name: nginx
    image: nginx:1.21
    ports:
    - containerPort: 80
EOF
[!NOTE] here docs support is available in most shells, including bash, zsh, and fish, however in shells other than bash, the syntax may vary.
Highlight lines of codeβ
Use inline comments in the code to highlight lines. See .
vCluster termsβ
LoftLabs is the company. Do not use "Loft" or "Loft Platform" to refer to vCluster products.
"vCluster" is a trademark. There are strict legal frameworks around how to use a trademark, for example, it cannot be used in plural. Do not use "vClusters".
Never use vCluster or vClusters when talking about a virtual cluster or clusters that vCluster creates. Use virtual clusters.
Productsβ
- vCluster: open source project that helps you create virtual clusters
- vCluster Pro: a single enhanced/paid/upgraded virtual cluster that uses Pro functionality (as labeled "Pro")
- vCluster Platform: the management platform and UI for managing open source and commercial vCluster instances
CLIβ
The command line interface name is vcluster.
Abbreviations for Kubernetes distrosβ
- Lightweight Kubernetes: K3s
- Kubernetes: K8s
- Zero Friction Kubernetes: k0s Note that k0s is the only Kubernetes distro to use a lower case 'k'
- AWS Elastic Kubernetes Service: EKS
Other product termsβ
Style guide automationβ
To maintain quality and consistency in our technical documentation, we use vale as a linter to automatically enforce style guidelines.
[!NOTE] The CI workflow automatically runs Vale on pull requests that change specific documentation files, including
.mdxand.mdfiles in theplatform,vcluster, andvcluster_versioned_docsdirectories.
What is Vale?β
Vale is an open-source, command-line linter that helps you enforce style and grammar rules in written documentation. Itβs highly configurable, allowing you to define custom rules that suit your projectβs needs. By integrating it into our CI pipeline, contributors can receive real-time feedback on their documentation during pull requests.
Running Vale locallyβ
Vale offers multiple installation methods suitable for different operating systems:
- macOS: brew install vale
- Windows: choco install vale
- Linux: brew install valeor use another package manager
- Docker: docker pull jdkato/vale
Individual files or folders can be linted
- To check all files (this may take some time): vale .
- To check a specific file: vale path/to/file.mdx
- To check a specific folder including subfolders: vale /path/to/folder
Running vale locally allows us to check our documentation before submitting a
pull request. This helps catch style issues early and streamlines the review
process.
Pluginsβ
VSCode and Neovim have vale plugins that can be installed to lint files as you
write them.
[!NOTE] If you're using DevPod with the "Open in DevPod" link above, Vale and the VS Code extension are automatically installed and configured for you!
- VS Code Vale plugin.
- Neovim setup:
- Install mason.nvim and add vale_ls LSP. Configure and use like any other LSP.
- Install vale_lson start withlazy.nvimreturn {
 "williamboman/mason.nvim",
 optional = true,
 opts = function(_, opts)
 if type(opts.ensure_installed) == "table" then
 vim.list_extend(opts.ensure_installed, { "vale_ls" })
 end
 end,
 }
 
[!IMPORTANT] Currently
valeoperates under MinAlertLevel = warning This means all warnings are treated as errors and will fail the CI. You are encouraged to set theMinAlertLeveltosuggestionin your local.vale.inito take advantage of the full range of Vale's capabilities. You can easily copy the.vale.inifile from the root of the repository and run linter withvale --config="/path/to/your/.vale.ini".
Controlling Vale rulesβ
Disabling all rules
- 
Use these HTML-style comments to control Vale checking: <!-- vale off --> // Stops all Vale checks
 <!-- vale on --> // Resumes Vale checks
- 
Example usage: <!-- vale off -->
 <!-- this section ignores all Vale rules -->
 This content won't be checked by Vale.
 <!-- vale on -->
Disabling specific rules
- Target individual rules with this syntax:
<!-- vale RuleName = NO --> // Disables one rule
 <!-- vale RuleName = YES --> // Re-enables that rule
Important formatting requirements:
- 
Use capital "YES" and "NO" 
- 
Include spaces around the equals sign 
- 
Specify the full rule name 
- 
Example usage: <!-- vale Google.Contractions = NO -->
 This section ignores only the contractions rule
 <!-- vale Google.Contractions = YES -->