When you use different kinds of databases, you need to migrate data between them frequently. A specific use case that often comes up is the transfer of data from your transactional database to your data warehouse, such as transferring/copying data from DynamoDB to Redshift. This article introduces you to AWS DynamoDB and Redshift. It also provides 4 methods (with detailed instructions) that you can use to migrate data from AWS DynamoDB to Redshift.

Amazon DynamoDB Overview

Dynamodb Logo

Amazon DynamoDB is a serverless NoSQL database service that works on the key-value and document data models. It allows developers to build modern, serverless applications that start small but eventually scale globally. Amazon DynamoDB applies automated horizontal scaling, guaranteeing unlimited scaling capability to support virtually any table size.

Key Features: 

  • Performance at scale
  • Designed for 99.9999% SLA
  • Serverless performance with limitless scalability
  • On-demand backup and restore
  • Private network connectivity

Amazon Redshift Overview

Redshift Logo

Amazon Redshift is a fully managed cloud data warehouse service for large-scale data analysis. It provides fast query performance and cost-effectiveness, making it perfect for business intelligence and data warehousing.

Key Features:

  • Highly Scalable with less downtime.
  • Optimized Query Performance because columnar storage and data compression are enabled.
  • Flexible pricing options for what you use.
  • Automated backups, patching, and updates.
  • Encryption at rest and in transit, VPC isolation, and IAM integration.

Methods to Copy Data from DynamoDB to Redshift

Loading Data from DynamoDB to Redshift

Method 1: DynamoDB to Redshift Using Hevo Data

Hevo Data helps you to connect Dynamo DB to Redshift in just two simple steps. It is a simple, fast and no-code method for all your migration processes. It safeguards your data with its fault-tolerant architecture.

Method 2: DynamoDB to Redshift Using Redshift’s COPY Command

This method operates on Amazon Redshift’s COPY command, which accepts a DynamoDB URL as one of the inputs. This method can overload the database in case of large datasets.

Method 3: DynamoDB to Redshift Using AWS Data Pipeline

This method uses AWS Data Pipeline, which first migrates data from DynamoDB to S3. Afterward, data is transferred from S3 to Redshift using Redshift’s COPY command. However, it can not transfer the data directly from DynamoDb to Redshift, so it can be time-consuming.

Method 4: DynamoDB to Redshift Using Dynamo DB Streams

This method leverages the DynamoDB Streams which provide a time-ordered sequence of records that contains data modified inside a DynamoDB table. This method is better suited for regular real-time data transfer.

Move your Data to Redshift for Free

Method 1: DynamoDB to Redshift Using Hevo Data

DynamoDb to Redshift: Hevo Logo

Here are the 2 simple steps you need to use to move data from DynamoDB to Redshift using Hevo: 

  • Step 1) Authenticate Source: Connect your DynamoDB account as a source for Hevo by entering a unique name for Hevo Pipeline, AWS Access Key, AWS Secret Key, and AWS Region. This is shown in the below image.
DynamoDB to Redshift: Configure source
  • Step 2) Configure Destination: Configure the Redshift data warehouse as the destination for your Hevo Pipeline. You have to provide, warehouse name, database password, database schema, database port, and database username. This is shown in the below image.
DynamoDB to Redshift: Configure Destination

Method 2: DynamoDB to Redshift Using Redshift’s COPY Command

This is by far the simplest way to copy a table from DynamoDB stream to Redshift. Redshift’s COPY command can accept a DynamoDB URL as one of the inputs and manage the copying process on its own. The syntax for the COPY command is as below. 

copy <target_tablename> from 'dynamodb://<source_table_name>'
authorization
read ratio '<integer>';

For now, let’s assume you need to move product_details_v1 table from DynamoDB to Redshift (to a particular target table) named product_details_tgt. The command to move data will be as follows.

COPY product_details_v1_tgt from dynamodb://product_details_v1
credentials ‘aws_access_key_id = <access_key_id>;aws_secret_access_key=<secret_access_key>  
readratio 40;

The “readratio” parameter in the above command specifies the amount of provisioned capacity in the DynamoDB instance that can be used for this operation. This operation is usually a performance-intensive one and it is recommended to keep this value below 50% to avoid the source database getting busy.

Load data from DynamoDB to Redshift
Load data from DynamoDB to Snowflake
Load data from DynamoDB to BigQuery

Limitations of Using Redshift’s Copy Command to Load Data from DynamoDB to Redshift

The above command may look easy, but in real life, there are multiple problems that a user needs to be careful about while doing this. A list of such critical factors that should be considered is given below.

  • DynamoDB and Redshift follow different sets of rules for their table names. While DynamoDB allows for the use of up to 255 characters to form the table name, Redshift limits it to 127 characters and prohibits the use of many special characters, including dots and dashs. In addition to that, Redshift table names are case-insensitive.
  • While copying data from DynamoDB to Redshift, Redshift tries to map between DynamoDB attribute names and Redshift column names. If there is no match for a Redshift column name, it is populated as empty or NULL depending on the value of EMPTYASNULL parameter configuration parameter in the COPY command.
  • All the attribute names in DynamoDB that cannot be matched to column names in Redshift are discarded.
  • At the moment, the COPY command only supports STRING and NUMBER data types in DynamoDB.
  • The above method works well when the copying operation is a one-time operation.

Method 3: DynamoDB to Redshift Using AWS Data Pipeline

AWS Data Pipeline is Amazon’s own service to execute the migration of data from one point to another point in the AWS Ecosystem. Unfortunately, it does not directly provide us with an option to copy data from DynamoDB to Redshift but gives us an option to export DynamoDB data to S3. From S3, we will need to used a COPY command to recreate the table in S3. Follow the steps below to copy data from DynamoDB to Redshift using AWS Data Pipeline:

  • Create an AWS Data pipeline from the AWS Management Console and select the option “Export DynamoDB table to S3” in the source option as shown in the image below. A detailed account of how to use the AWS Data Pipeline can be found in the blog post.
DynamoDB to Redshift
  • Once the Data Pipeline completes the export, use the COPY command with the source path as the JSON file location. The COPY command is intelligent enough to autoload the table using JSON attributes. The following command can be used to accomplish the same.
COPY product_details_v1_tgt from s3://my_bucket/product_details_v1.json  credentials ‘aws_access_key_id =          <access_key_id>;aws_secret_access_key=<secret_access_key>   Json = ‘auto’

In the avove command, product_details_v1.json is the output of AWS Data Pipeline execution. Alternately instead of the “auto” argument, a JSON file can be specified to map the JSON attribute names to Redshift columns, in case those two are not matching.

Method 4: DynamoDB to Redshift Using DynamoDB Streams

The following are the steps to migrate Amazon Dynamo to Amazon Redshift using DynamoDB Stream:

  1. Go to the DynamoDB console dashboard and turn on DynamoDB Streams for the source table; real-time changes will be captured.
DynamoDB Streams step 1
  1. Create an AWS Lambda function and configure it using the AWS Lambda Service. AWS Lambda can execute code triggered by events and triggers from various AWS services or custom-defined events. It will look something like this:
DynamoDB Streams step 2
  1. In the Lambda function, process the stream records and transform data into a form usable in Redshift. This may comprise formatting, enriching data, and other changes.
  2. Configure an Amazon S3 bucket to store the Lambda function’s results temporarily. 
DynamoDB Streams step 4- S3 Bucket
  1. If you don’t have an Amazon Redshift cluster, create one. Design the table schema to match the transformed data from DynamoDB.
DynamoDB Streams step 5- Redshift cluster
  1. Create the delivery stream by giving the relevant details.
DynamoDB Streams step 6- Delivery stream
  1. After you configure the details of the source and destination and provide relevant details, click on ‘Create Delivery Stream’. 
DynamoDB Streams step 7- Create Delivery stream
  1. The data stream is successfully created after the status shows ‘Active’.
DynamoDB Streams step 8- Active Kinesis Stream

Limitations of Using DynamoDB Streams

  1. The development includes setting up a Lambda function, processing DynamoDB Streams, and transforming data, which could be time-consuming.
  2. It requires knowledge of coding, error handling, and concepts of event-driven architecture. The development and maintenance of these functions are tricky.
  3. There can be complexity in the NoSQL data of DynamoDB mapping to the relational database of Redshift. 
  4. Some data types will require additional processing to transform and map; it won’t have a straightforward one-to-one mapping.

Conclusion

The article provided 4 different methods for copying data from DynamoDB to Redshift. Since DynamoDB is usually used as a transactional database and Redshift as a data warehouse, the need to copy data from DynamoDB is very common.

If you’re interested in learning about the differences between the two, take a look at the article: Amazon Redshift vs. DynamoDB.

Frequently Asked Questions

1. How to transfer data from DynamoDB to Redshift?

You can transfer data from DynamoDB to Redshift using the following methods:
– Using automated platforms like Hevo
– Using Copy command
– Using AWS Data Pipeline
– Using DynamoDB streams

2. What is the difference between Redshift and DynamoDB?

Redshift: A managed data warehouse for complex queries and large datasets, optimized for analytics.
DynamoDB: Managed NoSQL database for fast, scalable key-value and document data storage, optimized for high-velocity applications.

3. How do I transfer data to Redshift?

You can transfer data to Redshift using the following methods:
– Using automated platforms like Hevo
– Using Copy command
– Using AWS Data Pipeline
– Using AWS Glue

Want to take Hevo for a spin? Sign up for a 14-day free trial and experience the feature-rich Hevo suite firsthand. Checkout the Hevo pricing to choose the best plan for you.

Share your experience of copying data from DynamoDB to Redshift in the comment section below!

mm
Principal Frontend Engineer, Hevo Data

With over a decade of experience, Suraj has played a crucial role in architecting and developing core frontend modules for Hevo. His expertise lies in building scalable UI solutions, collaborating across teams, and contributing to the open-source community, showcasing a deep commitment to innovation in the tech industry.

No-code Data Pipeline for Redshift