Setup - HCloud

Setting up a Kubernetes Cluster with Hetzner Cloud (hcloud)

Deploy an umnanaged Kubernetes cluster in hcloud

Requirements

  1. hcloud account

  2. hcloud and hcloud credentials configured

  3. kubectl

  4. ansible

Steps

Firstly, clone and enter the cluster-launcher repository. All commands in this section are to be run inside this repo.

git clone https://gitlab.com/mayachain/devops/cluster-launcher
cd cluster-launcher

Then install the terraform CLI:

Install Terraform:

hcloud CLI

The hcloud CLI allows you to manage your hcloud services.

Use the package manager homebrew to install the hcloud CLI.

Kubernetes Control Tool

You must install and configure the Kubernetes CLI tool (kubectl). **To install kubectl** , follow these instructions, or choose a package manager based on your operating system.

Use the package manager homebrew to install kubectl.

wget && jq

You also need wget and jq, follow these instructions, or choose a package manager based on your operating system.

Use the package manager homebrew to install wget and jq Note: You most likely have these installed already.

Environment

Initialize the git submodule.

Use direnv, venv or whatever you prefer to manage a python environment inside the hcloud folder.

Install dependencies required by Python and Ansible Galaxy.

Deploy Kubernetes Cluster

Use the commands below to deploy an hcloud cluster:

During the deploy, you will be asked to enter information about your cluster:

  • Name

  • Token

  • Confirm yes

Deploying a cluster takes ~15 minutes

Quotas

If necessary, request a quota increase here.

CONFIGURE

Now that you've provisioned your hcloud cluster, you need to configure kubectl. Customize the following command with your cluster name and resource group. It will get the access credentials for your cluster and automatically configure kubectl.

You are now ready to deploy a MAYANode.

Last updated

Was this helpful?