The Amazon DAX Client for Python is used to access Amazon DAX clusters from Python. It is nearly source-compatible with Boto3, with only a small change needed to the client initialization to use DAX instead of DynamoDB. Creating a connection to your DAX cluster requires using the cluster discovery endpoint URL returned in the DescribeClusters response as the endpoint.
Install Amazon DAX Client using pip:
$ pip install amazon-dax-client
Boto3 has two different interfaces, the resource interface and the botocore client interface. Both are supported by the Amazon DAX client, with slightly different client initialization.
For the resource API, change from:
ddb = boto3.resource('dynamodb')
to
dax = AmazonDaxClient.resource(
endpoint_url=<cluster_discovery_endpoint_url>)
All other boto3.resource()
arguments are accepted.
For the botocore client API, change from:
session = botocore.session.get_session()
ddb = session.create_client('dynamodb', ...)
to
session = botocore.session.get_session()
dax = AmazonDaxClient(session, ...)
For Boto3 client API, change from:
ddb = boto3.client('dynamodb')
to
dax = AmazonDaxClient(endpoint_url=<cluster_discovery_endpoint_url>)
The Boto3 and botocore client APIs are exactly the same.
Hostname Verification for TLS connections is enabled by default when making requests from the client to the cluster and has no effect for unencrypted clusters. This can be turned off using the client API, be sure you understand the implication of turning it off, which is the inability to authenticate the cluster that you are connecting to.
The Amazon DAX client does not support table operations. Any table manipulation operations must use the regular Boto3 or botocore DynamoDB client.
Paginators are not currently supported for DAX.
Once created, the interface is the same as the Boto3/botocore DynamoDB clients.
For acomplete example, follow the guide to create a sample app.
Please use these community resources for getting help.
- Ask a question on StackOverflow and tag it with amazon-dynamodb-dax
- Ask a question on the AWS DynamoDB forum
- Open a support ticket with AWS Support
v2.0.0
- Encryption in transit feature
- Drop support for python versions below 3.6
v1.1.8
- Retry logic bug fixes
v1.1.7
- Minor bug fixes
v1.1.6
- Linting fixes
- Updated logging to log on Logger objects
v1.1.5
- Add jitter and backoff for retryable exceptions
v1.1.4
- Fixes bug starting with clusters of less than 3 nodes.
v1.1.3
- Fixes and improvements to service discovery logic.
- Add support for Python 3.8.
- Fix
'RetryHandler' object has no attribute '_cluster': AttributeError
problem reported in the AWS Forums. - Fix problems found by static analysis.
v1.1.2
- Fixes a bug that can result in a failure to update the roster when it
changes, which can later result in a
NoRouteException
.
v1.1.1
- Fixes a bug that can result in an infinite loop on node failure.
- Update TransactWriteItem test item limit to 25.
v1.1.0
- Adds support for transact-get-items and transact-write-items APIs for DyanamoDB transactions.
- Improved efficiency of connection pooling.
v1.0.7
- Fix scheduling of background tasks.
v1.0.6
- Properly de-anonymize UnprocessedItems results from BatchWrite.
- Raise a proper error if no backends are available.
v1.0.5
- Fix UpdateItem result parsing with a subset of attributes changed
v1.0.4
- Use user-specified timeouts
- Fix issue with update response if the item is not changed
- Fix error decoding BatchWrite UnprocessedItems.
v1.0.3
- Fix AmazonDaxClient.resource() when using batch_get_items or batch_write_items.
v1.0.2
- Fix Python 2 encoding issues
- Fix decoding of ConsumedCapacity, ItemCollectionMetrics in batch operations
v1.0.1
- Initial release