This repository is an examples for building a Kubernetes cluster using Terraform and Terraform RKE provider on AWS.
- terraform v0.11+
- terraform-provider-rke
- Valid AWS access_key and secret_key
- [optional]
kubectl
command
#clone this repo
$ git clone https://github.com/yamamoto-febc/terraform-provider-rke
$ cd terraform-provider-rke/examples/aws_ec2
#set API keys to environment variables
$ export AWS_ACCESS_KEY_ID="<your-access-key>"
$ export AWS_SECRET_ACCESS_KEY="<your-secret-key>"
#deploy
$ terraform init && terraform apply
###########################################################################
#When "terraform apply" is completed,
#kubeconfig file should be created in the current directory
###########################################################################
#set KUBECONFIG environment variable for kubectl
$ export KUBECONFIG=${PWD}/kube_config_cluster.yml
###########################################################################
#Then, kubectl command can be used
###########################################################################
#component statuses
$ kubectl get cs
NAME STATUS MESSAGE ERROR
controller-manager Healthy ok
scheduler Healthy ok
etcd-0 Healthy {"health": "true"}
#nodes
$ kubectl get nodes
NAME STATUS ROLES AGE VERSION
ip-xx-xx-xx-xx.ap-northeast-1.compute.internal Ready controlplane,etcd 1m v1.10.1
ip-xx-xx-xx-xx.ap-northeast-1.compute.internal Ready worker 1m v1.10.1
ip-xx-xx-xx-xx.ap-northeast-1.compute.internal Ready worker 1m v1.10.1
ip-xx-xx-xx-xx.ap-northeast-1.compute.internal Ready worker 1m v1.10.1