this project has the objective of implementing the following topology:
in order to deploy it, you'll need the following pre-requisites:
- terraform
- pyhton 3.6
- pip
DISCLAIMER: This not a production ready system. It is meant only to educate in terms of what can be achieved with the components aforementioned. In order to understand AWS best practices to production topologies, please refer to AWS Well Architected Framework
for deploying the solution, follow these simple steps:
- clone this repo
- edit the file variables.tf for setting the right required values
- create a python virtualenv inside the lambda folder and activate it
- execute a
terraform apply
the terraform script will deploy the basic infrastructure, including a lambda function written in python that will configure the target groups of both load balancers to the right ips, discovering the private endpoints of all Elasticsearch clusters deployed to the same account. This function will be invoked every minute.
In order to create the endpoint component on the transit VPC, use the 'service_endpoint' output value of the terraform script.