The cluster is provisioned in separate stages as follows:
- Terraform to provision the cluster instances, security groups, firewalls, cloud infrastructure and security (SSL) certificates.
- Ansible to configure the cluster, including installing Kubernetes, addons and platform level configuration (files, directories etc...)
- You need a Digitalocean account. Visit https://cloud.digitalocean.com/registrations/new to get started
- You need to have installed and configured Terraform (>= 0.6.16 recommended). Visit https://www.terraform.io/intro/getting-started/install.html to get started.
- You need to have Python >= 2.7.5 installed along with pip.
- Kubectl installed in and your PATH:
curl -O https://storage.googleapis.com/kubernetes-release/release/v1.2.3/bin/linux/amd64/kubectl
On an OS X workstation, replace linux in the URL above with darwin:
curl -O https://storage.googleapis.com/kubernetes-release/release/v1.2.3/bin/darwin/amd64/kubectl
After downloading the binary, ensure it is executable and move it into your PATH:
chmod +x kubectl
mv kubectl /usr/local/bin/kubectl
## Cluster Turnup
### Download Kubeform (install from source at head)
git clone https://github.com/Capgemini/kubeform.git /tmp/kubeform
cd /tmp/kubeform
pip install -r requirements.txt
### Set config
Configuration can be set via environment variables. As a minimum you will need to set these environment variables:
export TF_VAR_do_token=$DO_API_TOKEN
export TF_VAR_STATE_ROOT=/tmp/kubeform/terraform/digitalocean
### Get terraform dependencies
cd /tmp/kubeform/terraform/digitalocean
terraform get
terraform apply
### Configure the cluster
To install the role dependencies for Ansible execute:
cd /tmp/kubeform
ansible-galaxy install -r requirements.yml
To run the Ansible playbook (to configure the cluster):
ansible-playbook -u core --ssh-common-args="-i /tmp/kubeform/terraform/digitalocean/id_rsa -q" --inventory-file=inventory site.yml
This will run the playbook (using the credentials output by terraform and the terraform state as a dynamic inventory).
## Cluster Destroy
cd /tmp/kubeform/terraform/digitalocean
terraform destroy