Skip to content
This repository has been archived by the owner on May 20, 2024. It is now read-only.

Latest commit

 

History

History
57 lines (39 loc) · 3.05 KB

README.md

File metadata and controls

57 lines (39 loc) · 3.05 KB

Terraform config to launch Rancher 2

Note: requires Terraform v0.13

Summary

This Terraform setup will:

  • Start a droplet running rancher/rancher version specified in rancher_version
  • Create a custom RKE1 cluster called cluster_name
  • Start count_agent_all_nodes amount of droplets and add them to the custom cluster with all roles
  • Create a custom RKE2 cluster called cluster_rke2_name
  • Start count_rke2_agent_all_nodes amount of droplets and add them to the custom cluster with all roles
  • Create an ssh_config file in the terraform module directory for connecting to the droplets

Optional adding nodes per role

  • Start count_agent_etcd_nodes amount of droplets and add them to the custom cluster with etcd role
  • Start count_agent_controlplane_nodes amount of droplets and add them to the custom cluster with controlplane role
  • Start count_agent_worker_nodes amount of droplets and add them to the custom cluster with worker role
  • Start count_rke2_agent_etcd_nodes amount of droplets and add them to the custom cluster with etcd role
  • Start count_rke2_agent_controlplane_nodes amount of droplets and add them to the custom cluster with controlplane role
  • Start count_rke2_agent_worker_nodes amount of droplets and add them to the custom cluster with worker role

Other options

All available options/variables are described in terraform.tfvars.example.

Tools

You can add a tools node, which consists of some software that can be used for Rancher tooling like notifiers and logging. See below for more information on the current software included:

Note: replace PRIVATE_IP or PUBLIC_IP with tools-private-ip or tools-public-ip

Software Endpoint View command
ElasticSearch http://PRIVATE_IP:9200 docker logs elasticsearch
Kibana http://PUBLIC_IP:5601 docker logs kibana
SMTP (Mailhog) http://PRIVATE_IP:1025 docker logs mailhog
Echo server for HTTP requests http://PRIVATE_IP:8080 docker logs echo
Syslog (Syslog-NG) http://PRIVATE_IP:514 docker logs syslog
Fluentd http://PRIVATE_IP:24224 docker logs fluentd

SSH Config

Note: set the appropriate users for the images in the terraform variables, default is root

You can use the use the auto-generated ssh_config file to connect to the droplets by droplet name, e.g. ssh <prefix>-rancheragent-all-0 or ssh <prefix>-rancherserver etc. To do so, you have two options:

  1. Add an Include directive at the top of the SSH config file in your home directory (~/.ssh/config) to include the ssh_config file at the location you have checked out the this repository, e.g. Include ~/git/tf-do-rancher2/ssh_config.

  2. Specify the ssh_config file when invoking ssh via the -F option, e.g. ssh -F ~/git/tf-do-rancher2/ssh_config <host>.

How to use

  • Clone this repository
  • Move the file terraform.tfvars.example to terraform.tfvars and edit (see inline explanation)
  • Run terraform apply