Skip to content

Terraform-AWS Serverless Producer-Consumer Module

Notifications You must be signed in to change notification settings

AlphaGit/tas-pc

Repository files navigation

TAS PC

Terraform-AWS Serverless Producer-Consumer Module.

This repository uses Terraform to automatically create a Lambda infrastructure that produces events through an API Gateway powered lambda function, stores them in an AWS SQS queue and through event sources automatically fires consumer functions.

The lambdas also have optional access to a S3 bucket that can be used to store results.

But one picture is worth a thousand words:

How to use

  1. Clone this repository
  2. Adapt the variables in vars.tf, or create your own tfvars file.
  3. Adapt your code from the base of consumer_function/ and producer_function/ python modules. (You don't need to use python.)
  4. terraform init
  5. terraform apply
  6. ./test.sh to shoot a message and see it queued.

Demo

./test.sh
{
  "MD5OfMessageBody": "c7bb08ef48366081a55037f8e0deef97",
  "MessageId": "d48b8dc1-5e30-4681-9d48-1505f12a3740",
  "ResponseMetadata": {
    "RequestId": "82ec27b7-a468-5605-81e6-7da1ee2c2c40",
    "HTTPStatusCode": 200,
    "HTTPHeaders": {
      "x-amzn-requestid": "82ec27b7-a468-5605-81e6-7da1ee2c2c40",
      "date": "Tue, 23 Nov 2021 01:46:44 GMT",
      "content-type": "text/xml",
      "content-length": "378"
    },
    "RetryAttempts": 0
  }
}

About

Terraform-AWS Serverless Producer-Consumer Module

Resources

Stars

Watchers

Forks

Packages

No packages published