2021-01-15 12:41:06 -06:00
# Terraform Consul Load Testing
## How to use
1. Build an image with the desired Consul version and a load test image in the Packer folder [here ](../packer ).
2020-10-05 20:16:09 -05:00
2. Create your own `vars.tfvars` file in this directory.
2021-01-15 12:41:06 -06:00
3. Place the appropriate AMI IDs in the `consul_ami_id` and `test_server_ami` variables. If no AMI ID is specified it will default
to pulling from latest.
4. Set either `consul_version` or `consul_download_url` . If neither is set it will default to utilizing Consul 1.9.0
5. AWS Variables are set off of environment variables. Make sure to export necessary variables [shown here ](https://registry.terraform.io/providers/hashicorp/aws/latest/docs#environment-variables ).
2022-06-15 09:29:38 -04:00
6. Run `terraform init` once to setup the working directory.
7. Run `terraform plan -var-file=vars.tfvars` , and then `terraform apply -var-file=vars.tfvars` when ready.
8. Upon completion k6 should run and push metrics to the desired Datadog dashboard.
2021-01-15 12:41:06 -06:00
An example of a `vars.tfvars` :
2020-10-05 20:16:09 -05:00
```
vpc_name = "consul-test-vpc"
vpc_cidr = "11.0.0.0/16"
2022-06-15 09:29:38 -04:00
vpc_allwed_ssh_cidr = "0.0.0.0/0"
2020-10-05 20:16:09 -05:00
public_subnet_cidrs = ["11.0.1.0/24", "11.0.3.0/24"]
private_subnet_cidrs = ["11.0.2.0/24"]
vpc_az = ["us-east-2a", "us-east-2b"]
test_instance_type = "t2.micro"
test_server_ami = "ami-0ad7711e837ebe166"
cluster_name = "ctest"
test_public_ip = "true"
instance_type = "t2.micro"
ami_owners = ["******"]
consul_ami_id = "ami-016d80ff5472346f0"
2021-01-15 12:41:06 -06:00
````
2022-06-15 09:29:38 -04:00
Note that `vpc_allwed_ssh_cidr` must be set to allowed the test server to be accessible from the
machine running the load test, e.g., "0.0.0.0/0" (It is disabled by default).
2021-01-15 12:41:06 -06:00
## Customization
2020-12-15 17:03:44 -06:00
All customization for infrastructure that is available can be found by looking through the `variables.tf` file.
2021-01-15 12:41:06 -06:00
## How to SSH
After `terraform apply` is run Terraform should create a `keys/` directory which will give access to all instances created.
For example, `ssh -i "keys/[cluster-name]-spicy-banana.pem" ubuntu@[IPADDRESS]`
2020-10-05 20:16:09 -05:00