Skip to content

Latest commit

 

History

History
160 lines (106 loc) · 6.05 KB

README.md

File metadata and controls

160 lines (106 loc) · 6.05 KB

dev-lab-aws

This repository contains terraform resources to spin up an environment in AWS. It provisions a VPC, EKS and required resources to make the kubernetes cluster functional.

local tools

install openvpn

Install openvpn to connect to VPN and accept the GDPR terms and condition so that it opens and ready to be used. TF script will add configuration to it so its necessary that it is ready to be used.

brew install --cask openvpn-connect

install flux cli

Solution uses flux to sync resources to EKS cluster, so please install flux cli. Refer brew install fluxcd/tap/flux

brew install fluxcd/tap/flux

vault cli for local (optional)

It would be a good idea to have vault cli locally, though it is not must to run the project.

brew tap hashicorp/tap       
brew install hashicorp/tap/vault

apply terraform (up)

Fork this repo and change variables to run to create resources for you. It's recommended to create a branch from main and use the branch instead of using main as all the commits done by the the terraform would remain in a branch and you can discard the branch once you destroy the environment.

Update the terraform.tfvars as per you.

OWNER_EMAIL           = "[email protected]"
GITHUB_OWNER          = "<your-github-account>"
GITHUB_TOKEN          = "<your-github--token>"
REPOSITORY_NAME       = "dev-lab-aws"
REPOSITORY_VISIBILITY = "public"
BRANCH                = "a-branch" # change the branch


AWS_REGION      = "<your-desired-region>"
RESOURCE_PREFIX = "<your-name-or-any-prefix-you-prefer>"

AWS_EKS_ACCESS_ENTRIES = {
  access_role = {
    type          = "STANDARD"
    principal_arn = "<principal_arn>"

    policy_associations = {
      admin = {
        policy_arn = "arn:aws:eks::aws:cluster-access-policy/AmazonEKSClusterAdminPolicy"
        access_scope = {
          type = "cluster"
        }
      }
    }
  }
}

# If you want to use an existing vpc, set the vpc id. Also make sure the region is set same as vpc region. 
VPC_ID = "vpc-xxx"

# only set when you are using existing vpc, default is set to use ["*private*", "*Private*", "*PRIVATE*"] and ["*public*", "*Public*", "*PUBLIC*"], in case you have different name then set them here. 

PRIVATE_SUBNETS_NAME_FILTER = ["*my-private-filter*"]
PUBLIC_SUBNETS_NAME_FILTER = ["*my-public-filter*"]

run

To run, make use of a small script located in ./script/up.sh

./script/up.sh

RETRY: If it fails, try one more time. There is an unknown issue where sometimes it fails for the first time.

DNS resolution

Solution creates a private hosted zone to work with and use from the kubernetes cluster. You can resolve this from your machine once you are connected to VPN.

One caveat is if you have any software which manages your DNS server then you may have to either disable it or use a VPN client which allows you to change the DNS configuration while connecting to VPN. e.g. If you have Cloudflare WARP installed then you can disable it while you are working with the VPN and enable it once you don't need it. After disabling you may need to reset the WIFI or Ethernet connection to reestablish the internet connection and then connect to VPN. To test you can run nslookup vault.<resource_prefix>.local it should resolve to a private IP address in 10.0.0.0/16 range.

force sync git (optional)

Flux is scheduled to sync Git Repository evert minute, if you would like to force sync then run ./scripts/sync_git.sh to sync immediately.

set local variables

After successful run, you may run source ./scripts/post_run.sh to set local env variables to connect to vault and eks. Alternatively, you may run these as below.

(alternatively) setup kubeconfig

If you didn't run post_run.sh then you can manually setup.

export EKS_NAME=$(terraform output -json | jq -r '.eks_cluster_name.value | values')
export AWS_REGION=$(terraform output -json | jq -r '.aws_region.value | values')
aws eks update-kubeconfig --region $AWS_REGION --name $EKS_NAME --alias $EKS_NAME

(alternatively) get vault token

Export vault token

export S3_BUCKET_VAULT_OBJECT=$(terraform output -json | jq -r '.vault_s3_bucket.value | values')

export VAULT_ADDR=https://$(terraform output -json | jq -r '.vault_url.value | values')

aws s3 cp $S3_BUCKET_VAULT_OBJECT vault-secret.json 
export VAULT_TOKEN=$(jq -r '.root_token | values' vault-secret.json)

(Optional) add custom certs to trust store

(Optional) For ease you can run below commands to add the root ca to trusted root on your mac

sudo security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain ./generated_certs/root_ca.crt
sudo security remove-trusted-cert -d  ./generated_certs/root_ca.crt   

Tear down

A clean tear down is very important for all the resources to be deleted without leaving dangling resources.

  • Make sure all resources which you deployed are deleted, mainly check the persistent volumes, services which are of type load-balancer. Primarily check for any resource which would have created any corresponding AWS resource such as EBS, load balancers.
  • to remove all CR for confluent for kubernetes across all namespaces can be deleted by ./script/cleanup-kafka.sh.

A multi step process to tear down the cluster and other resources is in small script at ./script/down.sh. Its important to cleanup the k8s cluster before deleting the cluster.

./script/down.sh

If destroy stuck deleting flux-system ns then edit a few resources and remove the fluxcd finalizers

k edit gitrepositories flux-system -nflux-system
k edit kustomizations flux-system -nflux-system
k edit kustomizations resources-operator-level-0 -nflux-system

If for some reason, teardown doesn't work or you loose the state. You can use the aws resource groups to find all resources by the tags owner_email or owner_github_repo