Quickly stand up an HA-style Rancher management server in your infrastructure provider of choice.
Intended for experimentation/evaluation ONLY.
You will be responsible for any and all infrastructure costs incurred by these resources. As a result, this repository minimizes costs by standing up the minimum required resources for a given provider. Use Vagrant to run Rancher locally and avoid cloud costs.
A local quickstart is provided in the form of Vagrant configuration.
The Vagrant quickstart does not currently follow Rancher best practices for installing a Rancher manangement server. Use this configuration only to evaluate the features of Rancher. See cloud provider quickstarts for an HA foundation according to Rancher installtion best practices.
- Vagrant
- VirtualBox
- 6GB unused RAM
See /vagrant for details on usage and settings.
Quickstarts are provided for Amazon Web Services (aws
), Microsoft Azure Cloud (azure
), Microsoft Azure Cloud with Windows nodes (azure-windows
), DigitalOcean (do
), and Google Cloud Platform (gcp
).
You will be responsible for any and all infrastructure costs incurred by these resources.
Each quickstart will install Rancher on a single-node RKE cluster, then will provision another single-node workload cluster using a Custom cluster in Rancher. This setup provides easy access to the core Rancher functionality while establishing a foundation that can be easily expanded to a full HA Rancher server.
- Terraform >=0.12.0
- RKE terraform provider version 1.0.1 installed locally - full install instructions below
- Credentials for the cloud provider used for the quickstart
Download the v1.0.1 release archive for Linux,
extract the archive, and move the binary to
~/.terraform.d/plugins/linux_amd64/terraform-provider-rke_v1.0.1
.
If curl and unzip are installed, you can use the following script:
curl -LO https://github.com/rancher/terraform-provider-rke/releases/download/v1.0.1/terraform-provider-rke_1.0.1_linux_amd64.zip && \
unzip terraform-provider-rke_1.0.1_linux_amd64.zip && \
chmod +x ./terraform-provider-rke_v1.0.1 && \
mkdir -p ~/.terraform.d/plugins/linux_amd64/ && \
mv ./terraform-provider-rke_v1.0.1 ~/.terraform.d/plugins/linux_amd64/terraform-provider-rke_v1.0.1
rm -rf ./terraform-provider-rke_*
Download the v1.0.1 release archive for MacOS,
extract the archive, and move the binary to
~/.terraform.d/plugins/darwin_amd64/terraform-provider-rke_v1.0.1
.
If curl and unzip are installed, you can use the following script:
curl -LO https://github.com/rancher/terraform-provider-rke/releases/download/v1.0.1/terraform-provider-rke_1.0.1_darwin_amd64.zip && \
unzip terraform-provider-rke_1.0.1_darwin_amd64.zip && \
chmod +x ./terraform-provider-rke_v1.0.1 && \
mkdir -p ~/.terraform.d/plugins/darwin_amd64/ && \
mv ./terraform-provider-rke_v1.0.1 ~/.terraform.d/plugins/darwin_amd64/terraform-provider-rke_v1.0.1
rm -rf ./terraform-provider-rke_*
Download the v1.0.1 release archive for Windows (64-bit),
extract the archive, and move the executable to
%APPDATA%\terraform.d\plugins\windows_amd64\terraform-provider-rke_v1.0.1.exe
.
You can use the following PowerShell script to perform the same steps (tested with PS version 5.1):
New-Item -Path $Env:APPDATA\terraform.d\plugins\windows_amd64 -ItemType Directory -Force
Invoke-WebRequest -Uri https://github.com/rancher/terraform-provider-rke/releases/download/v1.0.1/terraform-provider-rke_1.0.1_windows_amd64.zip -OutFile terraform-provider-rke_1.0.1_windows_amd64.zip -UseBasicParsing
Expand-Archive terraform-provider-rke_1.0.1_windows_amd64.zip
Move-Item -Path terraform-provider-rke_1.0.1_windows_amd64\terraform-provider-rke_v1.0.1.exe -Destination $Env:APPDATA\terraform.d\plugins\windows_amd64\terraform-provider-rke_v1.0.1.exe
Remove-Item -Path terraform-provider-rke_1.0.1_windows_amd64* -Recurse
Download the v1.0.1 release archive for Windows (32-bit),
extract the archive, and move the executable to
%APPDATA%\terraform.d\plugins\windows_386\terraform-provider-rke_v1.0.1.exe
.
You can use the following PowerShell script to perform the same steps (tested with PS version 5.1):
Invoke-WebRequest -Uri https://github.com/rancher/terraform-provider-rke/releases/download/v1.0.1/terraform-provider-rke_1.0.1_windows_386.zip -OutFile terraform-provider-rke_1.0.1_windows_386.zip -UseBasicParsing
New-Item -Path $Env:APPDATA\terraform.d\plugins\windows_386 -ItemType Directory -Force
Expand-Archive terraform-provider-rke_1.0.1_windows_386.zip
Move-Item -Path terraform-provider-rke_1.0.1_windows_386\terraform-provider-rke_v1.0.1.exe -Destination $Env:APPDATA\terraform.d\plugins\windows_386\terraform-provider-rke_v1.0.1.exe
Remove-Item -Path terraform-provider-rke_1.0.1_windows_386* -Recurse
To begin with any quickstart, perform the following steps:
- Clone or download this repository to a local folder
- Choose a cloud provider and navigate into the provider's folder
- Copy or rename
terraform.tfvars.example
toterraform.tfvars
and fill in all required variables - Run
terraform init
- Run
terraform apply
When provisioning has finished, terraform will output the URL to connect to the Rancher server. Two sets of Kubernetes configurations will also be generated:
kube_config_server.yaml
contains credentials to access the RKE cluster supporting the Rancher serverkube_config_workload.yaml
contains credentials to access the provisioned workload cluster
For more details on each cloud provider, refer to the documentation in their respective folders.
When you're finished exploring the Rancher server, use terraform to tear down all resources in the quickstart.
NOTE: Any resources not provisioned by the quickstart are not guaranteed to be destroyed when tearing down the quickstart. Make sure you tear down any resources you provisioned manually before running the destroy command.
Run terraform destroy -auto-approve
to remove all resources without prompting for confirmation.