Skip to content

Commit

Permalink
write kubestash setup doc
Browse files Browse the repository at this point in the history
Signed-off-by: Anisur Rahman <[email protected]>
  • Loading branch information
anisurrahman75 committed Mar 6, 2024
1 parent b5758a2 commit cf2ff85
Show file tree
Hide file tree
Showing 12 changed files with 259 additions and 409 deletions.
22 changes: 11 additions & 11 deletions docs/setup/README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
---
title: Setup | Stash
description: Setup guides for Stash by AppsCode
title: Setup | KubeStash
description: Setup guides for KubeStash by AppsCode
menu:
docs_{{ .version }}:
identifier: setup-readme
Expand All @@ -18,19 +18,19 @@ aliases:
# Setup

<div style="text-align: center;">
<a class="button is-info is-medium is-active has-text-weight-normal" href="/docs/setup/install/stash/index.md" style="background:#FC6011; width: 18rem;">Install Stash</a>
<a class="button is-info is-medium is-active has-text-weight-normal" href="/docs/setup/install/kubestash/index.md" style="background:#FC6011; width: 18rem;">Install KubeStash</a>
</div>
<br>

The setup section contains instructions for installing the Stash and its various components in Kubernetes. This section has been divided into the following sub-sections:
The setup section contains instructions for installing the KubeStash and its various components in Kubernetes. This section has been divided into the following sub-sections:

- **Install Stash:** Installation instructions for Stash and its various components.
- [Stash operator](/docs/setup/install/stash/index.md): Installation instructions for Stash operator.
- [Stash kubectl Plugin](/docs/setup/install/kubectl-plugin/index.md): Installation instructions for Stash `kubectl` plugin.
- **Install KubeStash:** Installation instructions for KubeStash and its various components.
- [KubeStash operator](/docs/setup/install/kubestash/index.md): Installation instructions for KubeStash operator.
- [KubeStash kubectl Plugin](/docs/setup/install/kubectl-plugin/index.md): Installation instructions for kubeStash `kubectl` plugin.
- [Troubleshooting](/docs/setup/install/troubleshooting/index.md): Troubleshooting guide for various installation problems.

- **Uninstall Stash:** Uninstallation instructions for Stash and its various components.
- [Stash operator](/docs/setup/uninstall/stash/index.md): Uninstallation instructions for Stash operator.
- [Stash kubectl Plugin](/docs/setup/uninstall/kubectl-plugin/index.md): Uninstallation instructions for Stash `kubectl` plugin.
- **Uninstall KubeStash:** Uninstallation instructions for KubeStash and its various components.
- [KubeStash operator](/docs/setup/uninstall/kubestash/index.md): Uninstallation instructions for KubeStash operator.
- [KubeStash kubectl Plugin](/docs/setup/uninstall/kubectl-plugin/index.md): Uninstallation instructions for KubeStash `kubectl` plugin.

- [Upgrading Stash](/docs/setup/upgrade/index.md): Instruction for updating Stash license and upgrading between various Stash versions.
- [Upgrading KubeStash](/docs/setup/upgrade/index.md): Instruction for updating KubeStash license and upgrading between various KubeStash versions.
2 changes: 1 addition & 1 deletion docs/setup/_index.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: Setup | Stash
title: Setup | KubeStash
menu:
docs_{{ .version }}:
identifier: setup
Expand Down
50 changes: 25 additions & 25 deletions docs/setup/install/kubectl-plugin/index.md
Original file line number Diff line number Diff line change
@@ -1,24 +1,24 @@
---
title: Install Stash kubectl Plugin
description: Installation guide for Stash kubectl Plugin
title: Install KubeStash kubectl Plugin
description: Installation guide for KubeStash kubectl Plugin
menu:
docs_{{ .version }}:
identifier: install-stash-kubectl-plugin
name: Stash kubectl Plugin
identifier: install-kubestash-kubectl-plugin
name: KubeStash kubectl Plugin
parent: installation-guide
weight: 30
product_name: kubestash
menu_name: docs_{{ .version }}
section_menu_id: setup
---

# Install Stash kubectl Plugin
# Install KubeStash kubectl Plugin

Stash provides a `kubectl` plugin to interact with Stash resources.
KubeStash provides a `kubectl` plugin to interact with KubeStash resources.

## Install using Krew

Stash `kubectl` plugin can be installed using Krew. [Krew](https://krew.sigs.k8s.io/) is the plugin manager for kubectl command-line tool. To install follow the steps below:
KubeStash `kubectl` plugin can be installed using Krew. [Krew](https://krew.sigs.k8s.io/) is the plugin manager for kubectl command-line tool. To install follow the steps below:

- Install `krew` following the steps [here](https://krew.sigs.k8s.io/docs/user-guide/setup/install/).

Expand All @@ -37,46 +37,46 @@ kubectl krew index list
kubectl krew update
```

- Install Stash `kubectl` plugin following the commands below:
- Install Kubestash `kubectl` plugin following the commands below:

```bash
kubectl krew install appscode/stash
kubectl stash version
kubectl krew install appscode/kubestash
kubectl kubestash version
```

- If Stash `kubectl` plugin is already installed, run the following command to upgrade the plugin:
- If KubeStash `kubectl` plugin is already installed, run the following command to upgrade the plugin:

```bash
kubectl krew upgrade
kubectl stash version
kubectl kubestash version
```

## Install using pre-built binary

You can download the pre-build binaries from [stashed/cli](https://github.com/kubestash/cli/releases) releases and put it into one of your installation directory denoted by `$PATH` variable.
You can download the pre-build binaries from [kubestash/cli](https://github.com/kubestash/cli/releases) releases and put it into one of your installation directory denoted by `$PATH` variable.

Here is a simple Linux command to install the latest 64-bit Linux binary directly into your `/usr/local/bin` directory:

```bash
# Linux amd 64-bit
curl -o kubectl-stash.tar.gz -fsSL https://github.com/kubestash/cli/releases/download/{{< param "info.cli" >}}/kubectl-stash-linux-amd64.tar.gz \
&& tar zxvf kubectl-stash.tar.gz \
&& chmod +x kubectl-stash-linux-amd64 \
&& sudo mv kubectl-stash-linux-amd64 /usr/local/bin/kubectl-stash \
&& rm kubectl-stash.tar.gz LICENSE.md
curl -o kubectl-kubestash.tar.gz -fsSL https://github.com/kubestash/cli/releases/download/{{< param "info.cli" >}}/kubectl-kubestash-linux-amd64.tar.gz \
&& tar zxvf kubectl-kubestash.tar.gz \
&& chmod +x kubectl-kubestash-linux-amd64 \
&& sudo mv kubectl-kubestash-linux-amd64 /usr/local/bin/kubectl-kubestash \
&& rm kubectl-kubestash.tar.gz LICENSE.md

# Mac OSX 64-bit
curl -o kubectl-stash.tar.gz -fsSL https://github.com/kubestash/cli/releases/download/{{< param "info.cli" >}}/kubectl-stash-darwin-amd64.tar.gz \
&& tar zxvf kubectl-stash.tar.gz \
&& chmod +x kubectl-stash-darwin-amd64 \
&& sudo mv kubectl-stash-darwin-amd64 /usr/local/bin/kubectl-stash \
&& rm kubectl-stash.tar.gz LICENSE.md
curl -o kubectl-kubestash.tar.gz -fsSL https://github.com/kubestash/cli/releases/download/{{< param "info.cli" >}}/kubectl-kubestash-darwin-amd64.tar.gz \
&& tar zxvf kubectl-kubestash.tar.gz \
&& chmod +x kubectl-kubestash-darwin-amd64 \
&& sudo mv kubectl-kubestash-darwin-amd64 /usr/local/bin/kubectl-kubestash \
&& rm kubectl-kubestash.tar.gz LICENSE.md
```

If you prefer to install kubectl Stash cli from source code, make sure that your go development environment has been setup properly. Then, just run:
If you prefer to install kubectl kubestash cli from source code, make sure that your go development environment has been setup properly. Then, just run:

```bash
go get github.com/kubestash/cli/...
```

>Please note that this will install Stash cli from master branch which might include breaking and/or undocumented changes.
> Please note that this will install kubestash cli from master branch which might include breaking and/or undocumented changes.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
139 changes: 139 additions & 0 deletions docs/setup/install/kubestash/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,139 @@
---
title: Install KubeStash
description: Installation guide for KubeStash
menu:
docs_{{ .version }}:
identifier: install-kubestash-enterprise
name: KubeStash
parent: installation-guide
weight: 20
product_name: kubestash
menu_name: docs_{{ .version }}
section_menu_id: setup
---

# Install KubeStash

## Get a Free License

Download a FREE license from [AppsCode License Server](https://appscode.com/issue-license?p=stash).

> KubeStash licensing process has been designed to work with CI/CD workflow. You can automatically obtain a license from your CI/CD pipeline by following the guide from [here](https://github.com/appscode/offline-license-server#offline-license-server).
## Install

KubeStash operator can be installed as a Helm chart or simply as Kubernetes manifests.

<ul class="nav nav-tabs" id="installerTab" role="tablist">
<li class="nav-item">
<a class="nav-link active" id="helm3-tab" data-toggle="tab" href="#helm3" role="tab" aria-controls="helm3" aria-selected="true">Helm 3 (Recommended)</a>
</li>
<li class="nav-item">
<a class="nav-link" id="script-tab" data-toggle="tab" href="#script" role="tab" aria-controls="script" aria-selected="false">YAML</a>
</li>
</ul>
<div class="tab-content" id="installerTabContent">
<div class="tab-pane fade show active" id="helm3" role="tabpanel" aria-labelledby="helm3-tab">

## Using Helm 3

KubeStash can be installed via [Helm](https://helm.sh/) using the [chart](https://github.com/kubestash/installer/tree/master/charts/kubestash) from [AppsCode Charts Repository](https://github.com/appscode/charts). To install the chart with the release name `kubestash`:

```bash
$ helm install kubestash oci://ghcr.io/appscode-charts/kubestash \
--version {{< param "info.version" >}} \
--namespace kubestash --create-namespace \
--set-file global.license=/path/to/the/license.txt \
--wait --burst-limit=10000 --debug
```

To see the detailed configuration options, visit [here](https://github.com/kubestash/installer/tree/master/charts/kubestash).

</div>
<div class="tab-pane fade" id="script" role="tabpanel" aria-labelledby="script-tab">

### Using YAML

If you prefer to not use Helm, you can generate YAMLs from KubeStash chart and deploy using `kubectl`. Here we are going to show the prodecure using Helm 3.

```bash
$ helm template kubestash oci://ghcr.io/appscode-charts/kubestash \
--version {{< param "info.version" >}} \
--namespace kubestash --create-namespace \
--set-file global.license=/path/to/the/license.txt | kubectl apply -f -
```

To see the detailed configuration options, visit [here](https://github.com/kubestash/installer/tree/master/charts/kubestash).

</div>
</div>

### Verify installation

To check if KubeStash operator pods have started, run the following command:

```bash
$ kubectl get pods --all-namespaces -l app.kubernetes.io/name=kubestash-operator --watch
NAMESPACE NAME READY STATUS RESTARTS AGE
kubestash kubestash-kubestash-operator-fcd8bf7c6-psjs6 2/2 Running 0 5m49s
```

Once the operator pod is running, you can cancel the above command by typing `Ctrl+C`.

Now, to confirm CRD groups have been registered by the operator, run the following command:
```bash
$ kubectl get crd -l app.kubernetes.io/name=kubestash
NAME CREATED AT
addons.addons.kubestash.com 2023-12-07T06:27:41Z
backupbatches.core.kubestash.com 2023-12-07T06:27:41Z
backupblueprints.core.kubestash.com 2023-12-07T06:27:41Z
backupconfigurations.core.kubestash.com 2023-12-07T06:40:37Z
backupsessions.core.kubestash.com 2023-12-07T06:40:37Z
backupstorages.storage.kubestash.com 2023-12-07T06:40:37Z
functions.addons.kubestash.com 2023-12-07T06:27:41Z
hooktemplates.core.kubestash.com 2023-12-07T06:27:42Z
repositories.storage.kubestash.com 2023-12-07T06:40:37Z
restoresessions.core.kubestash.com 2023-12-07T06:27:42Z
retentionpolicies.storage.kubestash.com 2023-12-07T06:27:42Z
snapshots.storage.kubestash.com 2023-12-07T06:40:37Z
```

### Verify Addons

KubeStash automatically installs the necessary Addons for workload, pvc backup & restore. Verify that the Addons have been installed using the following command.

```bash
$ kubectl get addons.addons.kubestash.com
NAME AGE
kubedump-addon 7m1s
pvc-addon 7m1s
workload-addon 7m1s
```

As you can see from the above output that KubeStash has created `Addon` objects.

### Verify Functions

KubeStash also automatically installs the necessary functions for the corresponding installed addons. Verify that the functions have been installed using the following command.

```bash
$ kubectl get functions.addons.kubestash.com
NAME AGE
kubedump-backup 7m25s
pvc-backup 7m25s
pvc-restore 7m25s
volumesnapshot-backup 7m25s
volumesnapshot-restore 7m25s
workload-backup 7m25s
workload-restore 7m25s
```

As you can see from the above output that KubeStash has created `Functions` objects.

Now, you are ready to [take your first backup](/docs/guides/README.md) using KubeStash.

## Purchase KubeStash License

If you are interested in purchasing KubeStash license, please contact us via [email protected] for further discussion. You can also set up a meeting via our [calendly link](https://calendly.com/appscode/intro).

If you are willing to purchase KubeStash license but need more time to test in your dev cluster, feel free to contact [email protected]. We will be happy to extend your trial period.
Binary file not shown.
Loading

0 comments on commit cf2ff85

Please sign in to comment.