Integrating AWS Lambda into IaC Strategy | West Loop Strategy
We love using AWSÂ Lambda. The simplicity, the scale, the speed - we find ourselves using it all the time (we are an AWSÂ Lambda Service Delivery Partner, after all). We've also written about why you should use Infrastructure as Code (IaC) if you're working with the cloud. We find ourselves using Terraform more than any other IaCÂ tool, and the intersection between Terraform and Lambdas can be confusing. This post will layout some thoughts on best practices for the lines of demarcation.
First- a Caveat
Like most things, this strategy will not always work. Imagine, if you will, needing to integrate a Lambda function with the Cognito Authentication flow. You need the Lambda ZIP in Terraform during execution, but you can't compile the Lambda without knowing details of the User Pool.... but we digress. This strategy works for the majority of cases!
Where to use Terraform
To keep this brief- for everything except the APIÂ Gateway and the Lambda functions themselves. All other resources should be created via Terraform, and any required information can be passed to the Lambas as Parameters.
Now what about the Lambdas?
AWSÂ provides the 'AWSÂ Serverless Application Model' (AWSÂ SAM) for just this case. AWSÂ SAM is really just a wrapper for AWSÂ Cloud Formation, but it provides additional functionality to aid in the development of Lambda functions. This blog won't dive into too much detail here, but a quick summary is that the SAMÂ template can be used to run the functions locally (on Docker) for testing, as well as for deploying the lambda functions to the cloud. This template allows a simple configuration for the APIÂ Gateway and all Lambda functions in an understandable, repeatable manner.
Tying them together
Now that we know which technology to use for which task, how do we tie them together? I'll show a simplified example using AWSÂ Code Pipeline.
- First, we run our command to apply Terraform. This creates the infrastructure, and outputs a block of variables into JSON. These variables will typically consist of a variety of ARNs, Ids, and other values needed to point to specific pieces of infrastructure
- We deploy React. Moving along, not relevant here.
- We deploy the Lambdas using an AWSÂ Cloud Formation step (remember- SAMÂ Templates are really a wrapper for Cloud Formation!). This step utilizes the JSONÂ output from Terraform as an input, and maps the values to SAMÂ Template parameters. The SAMÂ Template then deploys the Lambdas to a stack, and our deployment is complete.
In Summary
We believe that this approach utilizes the strength of both technologies to provide the simplest solution. We could (and have)Â used Terraform or Cloud Formation independently to achieve the same final state, but have found that those solutions end up being inelegant and hard to maintain. Â Technology is supposed to make our jobs easier- and we believe that this approach is the easier solution.
‍