Skip to content

AWS Athena

Athena is an interactive query service that allows users to analyze data directly in Amazon S3 using standard SQL.

The Athena destination stores data as Parquet files in S3 buckets and creates external tables in AWS Glue Catalog.

ingestr supports Athena as a destination.

URI format

The URI format for Athena is as follows:

plaintext
athena://?bucket=<your-destination-bucket> \
    query_results_path=<your-query-results-location> \
    access_key_id=<your-aws-access-key-id> \
    secret_access_key=<your-aws-secret-access-key> \
    region_name=<your-aws-region>

URI parameters:

  • bucket (required): The name of the bucket where the data will be stored, containing the Parquet files that Athena will work with, e.g. your_bucket_name or s3://your_bucket_name.
  • access_key_id and secret_access_key (required): These are AWS credentials that will be used to authenticate with AWS services like S3 and Athena.
  • region_name (required): The AWS region of the Athena service and S3 buckets, e.g. eu-central-1
  • query_results_path (optional): The query location path where the results of Athena queries will be saved, e.g. dest_path or s3://dest_path. If not provided, it will default to the bucket specified in the bucket parameter.
  • workgroup (optional): The name of the Athena workgroup, e.g. my_group

Setting up an Athena Integration

Athena requires a bucket, access_key_id, secret_access_key and region_name to access the S3 bucket. Please follow the guide on dltHub to obtain credentials. Once you've completed the guide, you should have all the above-mentioned credentials.

ingestr ingest \
  --source-uri "stripe://?api_key=key123" \
  --source-table 'event' \
  --dest-uri "athena://?bucket=bucket_123&access_key_id=access_123&secret_access_key=secret_123&region_name=eu-central-1" \
  --dest-table 'stripe.event'

This is a sample command that will copy the data from the Stripe source into Athena.

athena_img