skip to navigation
skip to content

Not Logged In

dynamic-dynamodb 1.6.0

Automatic provisioning for AWS DynamoDB tables

Latest Version: 1.20.4

# Dynamic DynamoDB

AWS DynamoDB is a great service, but it falls short when it comes to automated throughput scaling. This is where Dynamic DynamoDB enters the stage. It provides automatic read and write provisioning for DynamoDB.

All you need to do is to tell Dynamic DynamoDB at which point and how much you want to scale up or down your DynamoDB. An example is in place. Let’s say you have way more traffic on your database during sales hours 4pm - 10pm. DynamicDB can monitor the increased throughput on your DynamoDB instance (via CloudWatch) and provision more throughput as needed. When the load is reducing Dynamic DynamoDB will sence that and automatically reduce your provisioning.

See an example of how to configure Dynamic DynamoDB under Basic usage or checkout dynamic-dynamodb –help.

Features in short

  • Scale up and down DynamoDB automatically
  • Restrict scaling to certain time slots
  • Monitor multiple DynamoDB tables at the same time
  • Gives you control over how much reads and writes you want to scale up and down with
  • Dynamic DynamoDB has support for max and min limits so that you always knows how much money you spend at most and how much capacity you can be guaranteed
  • Support for circuit breaker API call. If your service is experiencing disturbances, Dynamic DynamoDB will not scale down your DynamoDB tables


Project documentation is hosted at [](

Basic usage

This example will configure Dynamic DynamoDB to:

  • Scale up your DynamoDB table when the consumed reads 90% of the total provisioned reads
  • Scale up your DynamoDB table when the consumed writes 90% of the total provisioned writes
  • Scale up your reads with 50%
  • Scale up your writes with 40%
  • Scale down your DynamoDB table when the consumed reads 30% of the total provisioned reads
  • Scale down your DynamoDB table when the consumed writes 40% of the total provisioned writes
  • Scale down your reads with 40%
  • Scale down your writes with 70%
  • Check for changes every 5 minutes


dynamic-dynamodb –table-name my-table
–reads-upper-threshold 90 –reads-lower-threshold 30 –increase-reads-with 50 –decrease-reads-with 40 –writes-upper-threshold 90 –writes-lower-threshold 40 –increase-writes-with 40 –decrease-writes-with 70 –check-interval 300

Please note that using configuration files instead of command line options will give you even more control over the service.

Installation instructions

The easiest way to install Dynamic DynamoDB is through PyPI:

pip install dynamic-dynamodb

Reporting bugs

Please help me by providing feedback and bug reports. You can file bugs in the project’s [GitHub Issues page](

Provide as much details as possible to make bug fixing as swift as possible.

Git strategy

This project uses [git-flow]( for handling branching and releasing in Git. See the following [blog post]( for more details on how it works.

Release information

1.6.0 (2013-11-21)

1.5.8 (2013-10-18)

1.5.7 (2013-10-17)

1.5.6 (2013-10-06)

1.5.5 (2013-08-31)

1.5.4 (2013-08-29)

1.5.3 (2013-08-27)

1.5.2 (2013-08-27)

The AWS ListTables permission is no longer a hard requirement. It’s only needed if you’re using regular expressions to configure your DynamoDB tables.

1.5.1 (2013-08-22)

Fixed bug in the 1.5.0 release.

1.5.0 (2013-08-22)

Thanks [@pragnesh]( for adding this feature!

1.4.0 (2013-08-14)

1.3.6 (2013-07-21)

1.3.5 (2013-06-17)

1.3.4 (2013-06-13)

1.3.3 (2013-06-08)

1.3.2 (2013-05-14)

1.3.1 (2013-05-10)

1.3.0 (2013-05-01)

This Dynamic DynamoDB release makes it possible to use multiple Dynamic DynamoDB instances in parallel in daemon mode. Simply use the –instance flag to separate the difference instances with a unique name. Then control them as usual with the –daemon flag.

1.2.5 (2013-04-29)

1.2.4 (2013-04-26)

1.2.0 (2013-04-20)

1.1.0 (2013-04-17)

1.0.1 (2013-04-17)

  • Minor fix: Ugly output removed

1.0.0 (2013-04-16)

The 1.0.0 release is a leap forward when it comes to module structure and extendability. Please remember that this is still released in beta in PyPI, so all bug reports are very welcome. File any odd behavior or bugs in [GitHub Issues](

0.5.0 (2013-04-12)

0.4.2 (2013-04-11)

0.4.1 (2013-04-10)

0.4.0 (2013-04-06)

0.3.5 (2013-04-05)

0.3.4 (2013-04-05)

0.3.3 (2013-04-05)

0.3.2 (2013-04-05)

0.3.1 (2013-04-04)

0.3.0 (2013-03-27)

This release contains support for configuration files, custom AWS access keys and configurable maintenance windows. The maintenance feature will restrict Dynamic DynamoDB to change your provisioning only during specific time slots.

0.2.0 (2013-03-24) - First public release

0.1.1 (2013-03-24) - Initial release

Releasing to PyPI

make release


This project is maintained by [Sebastian Dahlgren]( ([GitHub]( | [Twitter]( | [LinkedIn](


APACHE LICENSE 2.0 Copyright 2013 Sebastian Dahlgren

Licensed under the Apache License, Version 2.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

File Type Py Version Uploaded on Size
dynamic-dynamodb-1.6.0.tar.gz (md5) Source 2013-11-21 34KB
  • Downloads (All Versions):
  • 191 downloads in the last day
  • 2101 downloads in the last week
  • 7463 downloads in the last month