Skip to content

Pipeline to ingest S3 files to Postgres with a Lambda, deployed with an AWS SAM template

License

Notifications You must be signed in to change notification settings

jamessewell/timescale-s3-pipeline

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

timescale-s3-pipeline

This repo defines an AWS SAM template for a pipeline to ingest S3 files to Postgres with a Lambda. It can be deployed with a single command.

The pipeline happy path operates as follows:

sequenceDiagram
    participant S3 as S3 Bucket
    participant SQS as SQS Queue
    participant Lambda as Lambda Function
    participant SecretsManager as Secrets Manager
    participant Timescale as Timescale Database
    participant CloudWatch as CloudWatch Logs

    S3->>SQS: 1. File uploaded event
    SQS->>Lambda: 2. Trigger Lambda function
    Lambda->>SecretsManager: 3. Request database credentials
    SecretsManager->>Lambda: 4. Return credentials
    Lambda->>S3: 5. Get file metadata and content
    S3->>Lambda: 6. Return file data
    Lambda->>Timescale: 7. Check if file already processed
    Timescale->>Lambda: 8. Confirm file not processed
    Lambda->>Timescale: 9. Create target table if not exists
    Lambda->>Timescale: 10. Stream COPY data from S3 file
    Lambda->>Timescale: 11. Mark file as processed
    Lambda->>SQS: 12. Delete processed message
    Lambda->>CloudWatch: 13. Log operation details
Loading

Features

  • CSV files are imported to a table name that matches the top level S3 directory
  • The imported_files table is created on first run if it doesn't exist
  • Any error will result in the SQS message not being removed, which will trigger a retry after 5mins
  • Files which have already been imported will not be re-imported (unless they are removed from imported_files)
  • Full logging to CloudWatch
  • Persistent failures will be routed to the SQS Dead Letter Queue for manual processing

Non-goals

  • Parallel import / multi-threading. If files take too long to import then reduce CSV size.

Schema

The lambda will create the processed_files table on first run with the following schema. All files listed in this table have been ingested exactly once.

erDiagram
    PROCESSED_FILES {
        int id PK
        text bucket
        text key
        timestamptz processed_at
        interval processing_time
        int rows_copied
        bigint file_size_bytes
        text target_table
    }
Loading

Usage

Pre-requisites

  • Install the AWS sam (Serverless Application Model) client and configure it as described here
  • Ensure that the API key you have configured has S3, SecretManager, Lambda and SQS permissions.

Installation

  • Run sam deploy --guided --stack-name timescale-s3-pipeline. The guided option will prompt you for all variable values, and then write the results to a file to re-use next time.
  • ✅ Done

Check it out!

Testing

  • Create a subfolder in your ingest S3 bucket which matches the name of a table you want to ingest data into
  • Drop a CSV file with the same format at the table into the new subfolder
  • You should see the rows appear in your table, and import details show up in the new processed_files table.
  • 🚀🚀🚀

Check it out!

Uninstallation

  • Remove all folders and files from your ingest S3 bucket manually (these will cause sam delete to fail, protecting your data)
  • Run sam delete
  • ❌ All components should be removed.

About

Pipeline to ingest S3 files to Postgres with a Lambda, deployed with an AWS SAM template

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages