Skip to content

Commit

Permalink
Added CLI changes and updated loft migration page
Browse files Browse the repository at this point in the history
  • Loading branch information
deniseschannon committed Aug 13, 2024
1 parent 0bd8316 commit c1f2d52
Show file tree
Hide file tree
Showing 2 changed files with 186 additions and 17 deletions.
164 changes: 164 additions & 0 deletions vcluster/cli/0-20-cli-changes.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,164 @@
---
title: v0.20 CLI Updates
sidebar_label: v0.20 Changes
sidebar_position: 1
---

With the breaking changes introduced in v0.20, the vCluster CLI was also updated to match with the direction that we are going.

There were also two signicant CLI changes that influenced the changes in the `vcluster` CLI.

1. The `loft` CLI, which was used to manage the platform (formerly known as loft) was deprecated and no longer supported, so all commands in the `loft` CLI were moved into the `vcluster` CLI.
2. The `vcluster pro` command was renamed to `vcluster platform`.

With these two signifcant changes, there were duplicate functionality from the older CLI (`loft`) and vCluster command (`vcluster pro`) that were merged as `vcluster platform`.

## New Commands in v0.20.0

* `vcluster convert` : Convert virtual cluster config values - This command is used to convert pre-v0.20 values.yaml files to the new vcluster.yaml
format. More details on how to convert your pre v0.20 `values.yaml` can be found in our [dedicated migration guide](../reference/migrations/0-20-migration/).

* `vcluster set` : Set configuration

* `vcluster use` : vCluster use subcommand - This command allows you to switch between the drivers (helm or platform).

## Renamed Commands from vCluster CLI v0.19.x

* `vcluster import` was renamed to `vcluster platform add` : Adds a cluster or vCluster to vCluster platform

* `vcluster get` was renamed to `vcluster platform get` : Retrieves and displays information

## New Commands that were used in `vcluster pro` and `loft`

* `loft credits` was renamed to `vcluster credits` : Saves the OSS credits

* `loft generate` was replaced with `vcluster platform create` and `vcluster platform set`

* `loft import` was renamed to `vcluster platform add` : Adds a cluster or vCluster` to vCluster platform


### Changed Subcommands

* `vcluster pro token` / `loft token` was renamed to `vcluster platform access-key` 

* `vcluster pro connect` was renamed to `vcluster platform connect` with additional context.

* `vcluster pro generate` was removed and replaced with `vcluster platform create` and `vcluster platform set`

### Renamed Commands from `loft` CLI to `vcluster platform` CLI

This is a list of commands that formerly in the `loft` CLI and now renamed in `vcluster` under `vcluster platform`. All funcationality remains the same.

* `vcluster platform backup` : Backup subcommands

* `vcluster platform connect` : Connects a cluster to vCluster Platform. 

* `vcluster platform create` : Creates vCluster platform resources

* `vcluster platform delete` : Deletes vCluster platform resources

* `vcluster platform get` : Retrieves and displays information

* `vcluster platform list` : Lists configuration

* `vcluster platform reset` : Reset configuration

* `vcluster platform set` : Set configuration

* `vcluster platform share` : Shares a virtual cluster/namespace with another vCluster platform user or team

* `vcluster platform sleep` : Put a virtual cluster/namespace to sleep

* `vcluster platform start` : Start a loft instance and connect via port-forwarding

* `vcluster platform wakeup` : Wake up a virtual cluster/namespace



## Flag Differences

### New Global Flag

•  `--config` string : The vcluster CLI config to use (will be created if it does not exist)

### New Flags within Each Command

`vcluster connect`

* `--driver` string : Specifies the driver to use for managing the virtual cluster (helm or platform).

`vcluster create`

* `--add` : Automatically adds the virtual cluster to the current vCluster platform when using the helm driver (default true).

* `--background-proxy` : Uses a background-proxy to access the vCluster if docker is installed and reachable (default true).

* `--create-context` : Creates a kube context for the space (default true).

* `--description` string : Description to show in the platform UI for this virtual cluster. 

* `--display-name` string : Display name to show in the platform UI for this virtual cluster.

* `--driver` string : Specifies the driver to use for managing the virtual cluster (helm or platform).

* `--parameters` string : Uses a file for the parameters if a template is used.

* `--print` : Prints the context to the console if enabled.

* `--recreate` : Deletes an existing virtual cluster with the same name before creating a new one.

* `--set-parameter` stringArray : Sets specific parameters if a template is used.

* `--skip-wait` : Does not wait until the virtual cluster is running if true. 

* `--switch-context` : Switches the current context to the new context (default true).

* `--team` string : Specifies the team to create the space for. 

* `--use` : Uses the virtual cluster if it's already there. 

* `--user` string : Specifies the user to create the space for. 

`vcluster delete`

* `--delete-context` : Deletes the corresponding kube context if there is any (default true).

* `--driver` string : Specifies the driver to use for managing the virtual cluster (helm or platform).

`vcluster list`

* `--driver` string : Specifies the driver to use for managing the virtual cluster (helm or platform).

`vcluster login` 

* `--use-driver` string : Switches the vCluster driver between platform and helm. 

`vcluster pause`

* `--driver` string : Specifies the driver for the virtual cluster (helm or platform).

`vcluster resume`:

* `--driver` string : Specifies the driver for the virtual cluster (helm or platform).   

### Dropped Flags within Each Command

`vcluster connect`

* `--kube-config` string: This flag was used to specify the file to write the created kube config to. The default value was "./kubeconfig.yaml". 

* `--kube-config-context-name` string: This flag was used to override the context name of the generated virtual cluster kube config with a specified name. 

* `--update-current`: This flag was used to update the current kube config if set to true. The default value was true. 

`vcluster create`

* `--disable-pro`: This flag was used to prevent vcluster from trying to create a vCluster.Pro. It could also be used with 'vcluster logout' to prevent vCluster from creating any pro clusters. In v0.20.0, the images used are the pro images and in order to use the OSS images, you'll need to replace the images as part of the vcluster.yaml.

* `--distro` string: This flag was used to specify the Kubernetes distro to use for the virtual cluster. Allowed distros were k3s, k0s, k8s, eks, with the default being "k3s". In v0.20.0, configuring the distro is now in the vcluster.yaml with the default being "k8s".

* `--extra-values` strings: This flag was deprecated and used to specify extra values. It was replaced by the  --values  flag.

* `--isolate` : This flag was used to run vcluster and its workloads in an isolated environment. In v0.20.0, running workloads in an isolated environment is [configured within vcluster.yaml](../deploy/topologies/isolated-workloads/).

* `--params` string: This flag was used to specify a file for the parameters if a template was used. It was replaced by the  --parameters string  flag.
39 changes: 22 additions & 17 deletions vcluster/reference/migrations/loft-cli-vcluster-cli-migration.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -28,18 +28,9 @@ mv /tmp/config.json $CONFIG_PATH

Now you can pass this path to `--config $CONFIG_PATH` or rely on **vCluster** CLI to use the default path `~/.vcluster/config.json`.

## Mapping of old loft CLI commands to vCluster CLI commands
## Mapping of old `loft` CLI commands to `vcluster` CLI commands

### cluster commands

| loft CLI | vCluster CLI |
|-----------------------------------|------------------------------------------------|
| `loft connect cluster` | `vcluster platform add cluster` |
| `loft list clusters` | `vcluster platform list clusters` |
| `loft use cluster` | `vcluster platform connect cluster` |
| `loft vars cluster` | `vcluster platform get current-cluster -o name`|

### vcluster commands
### vCluster Commands

| loft CLI | vCluster CLI | Alias | Comments |
|-----------------------------------|-------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
Expand All @@ -52,7 +43,7 @@ Now you can pass this path to `--config $CONFIG_PATH` or rely on **vCluster** CL
| `loft use vcluster` | `vcluster connect --driver=platform` | `vcluster platform connect vcluster` | Following flags have been **removed**:<br/>`--cluster` (vCluster platform handles this transparently in the background)<br/>`--space` (vCluster platform handles this transparently in the background)<br/>`--skip-wait`<br/>`--disable-direct-cluster-endpoint`<br/><br/>To obtain the kube config for the given virtual cluster issue the following:<br/>`vcluster connect myvcluster --print > /tmp/myvcluser-kube-config.yaml` |
| `loft wakeup vcluster` | `vcluster wakeup --driver=platform` | `vcluster platform wakeup vcluster`<br/>`vcluster resume --driver=platform` | |

### space commands
### Namespace Commands

| loft CLI | vCluster CLI | Comments |
|-----------------------------------|-------------------------------------------------|--------------------------------------------------------------------------------------------|
Expand All @@ -65,7 +56,16 @@ Now you can pass this path to `--config $CONFIG_PATH` or rely on **vCluster** CL
| `loft use space` | `vcluster platform connect namespace` | |
| `loft wakeup space` | `vcluster platform wakeup namespace` | |

### token, secret, password commands
### Cluster Commands

| loft CLI | vCluster CLI |
|-----------------------------------|------------------------------------------------|
| `loft connect cluster` | `vcluster platform add cluster` |
| `loft list clusters` | `vcluster platform list clusters` |
| `loft use cluster` | `vcluster platform connect cluster` |
| `loft vars cluster` | `vcluster platform get current-cluster -o name`|

### Token, Secret, Password Commands

| loft CLI | vCluster CLI |
|-----------------------------------|-------------------------------------------------|
Expand All @@ -76,34 +76,39 @@ Now you can pass this path to `--config $CONFIG_PATH` or rely on **vCluster** CL
| `loft reset password` | `vcluster platform reset password` |
| `loft token` | `vcluster platform access-key` |

### user and team commands
### User and Team Commands

| loft CLI | vCluster CLI |
|-----------------------------------|-------------------------------------------------|
| `loft get user` | `vcluster platform get current-user` |
| `loft list teams` | `vcluster platform list teams` |
| `loft vars username` | `vcluster platform get current-user -o name` |

### platform and management commands
### Platform and Management Commands

| loft CLI | vCluster CLI |
|-----------------------------------|-------------------------------------------------|
| `loft start` | `vcluster platform start` |
| `loft use management` | `vcluster platform connect management` |

### misc commands
### Miscellaneous Commands

| loft CLI | vCluster CLI |
|-----------------------------------|-------------------------------------------------|
| `loft backup` | `vcluster platform backup` |
| `loft credits` | `vcluster credits` |

### deleted commands
### Removed Commands

| loft CLI | vCluster CLI | Comments |
|-----------------------------------|-------------------------------------------------|-----------------------------------------|
| `loft defaults get` | - | **Removed** as it no longer has any use |
| `loft defaults set` | - | **Removed** as it no longer has any use |
| `loft defaults view` | - | **Removed** as it no longer has any use |
| `loft generate admin-kube-config` | - | **Removed** due to egress agent change |
| `loft completion` | - |**Removed** as it no longer has any use |
| `loft ui` | - |**Removed** as it no longer has any use |




0 comments on commit c1f2d52

Please sign in to comment.