Dynoxide

Dynoxide

A DynamoDB-compatible database engine (Rust, SQLite-backed) whose MCP server exposes 34 DynamoDB tools: tables, items, query/scan, batch, transactions, PartiQL, TTL, tags, streams and snapshots

Category
Visit Server

README

Dynoxide

crates.io docs.rs CI conformance license

A DynamoDB emulator backed by SQLite. Runs as an HTTP server, an MCP server for coding agents, or embeds directly into Rust and iOS applications as a library.

Why Dynoxide?

I built Dynoxide because DynamoDB Local is slow, heavy, and can't embed. It needs a JVM, and the typical Docker-based setups adds <!-- prose:ddb_local_cold_start -->2–3 seconds<!-- /bench --> of cold-start, <!-- prose:ddb_local_idle_memory -->~185 MB<!-- /bench --> of memory at idle, and a <!-- prose:ddb_local_image_size -->~225MB<!-- /bench --> Docker image (<!-- prose:ddb_local_image_size_disk -->~471 MB<!-- /bench --> on disk) before you've done anything useful. If you're running integration tests, that's Docker starting, the JVM warming up, and your pipeline waiting.

Dynoxide is a native binary. It starts in milliseconds, idles at <!-- prose:dynoxide_idle_memory -->~4.9 MB<!-- /bench -->, and ships as a <!-- prose:dynoxide_binary_size -->~3 MB<!-- /bench --> download. Point any DynamoDB SDK at it and your tests just work.

For Rust projects, there's also an embedded mode - direct API calls via Database::memory() with no HTTP layer at all. Each test gets an isolated in-memory database with zero startup cost. And because it compiles to a native library with no runtime dependencies, it runs on platforms where DynamoDB Local can't, including iOS.

Performance

Local Development (Apple Silicon)

Metric Dynoxide (embedded) Dynoxide (HTTP) DynamoDB Local
Cold startup <!-- bench:local_startup_embedded -->~0.2ms<!-- /bench --> <!-- bench:local_startup_http -->~15ms<!-- /bench --> <!-- bench:local_startup_ddb_local -->~2,287ms<!-- /bench -->
GetItem (p50) <!-- bench:local_getitem_embedded -->9µs<!-- /bench --> <!-- bench:local_getitem_http -->0.1ms<!-- /bench --> <!-- bench:local_getitem_ddb_local -->0.8ms<!-- /bench -->
PutItem throughput <!-- bench:local_putitem_embedded -->~51,613 ops/s<!-- /bench --> <!-- bench:local_putitem_http -->~6,703 ops/s<!-- /bench --> <!-- bench:local_putitem_ddb_local -->~945 ops/s<!-- /bench -->
50-test suite (sequential) <!-- bench:local_ci_suite_embedded_seq -->~484ms<!-- /bench --> <!-- bench:local_ci_suite_http_seq -->~569ms<!-- /bench --> <!-- bench:local_ci_suite_ddb_local_seq -->~2,407ms<!-- /bench -->
50-test suite (4x parallel) <!-- bench:local_ci_suite_embedded_par -->~203ms<!-- /bench --> <!-- bench:local_ci_suite_http_par -->~235ms<!-- /bench --> <!-- bench:local_ci_suite_ddb_local_par -->~1,189ms<!-- /bench -->

CI (GitHub Actions)

Numbers from ubuntu-latest (2-core AMD EPYC 7763, 8GB RAM). Commit <!-- bench:ci_commit_link_root -->e066fc0<!-- /bench -->.

Metric Dynoxide (embedded) Dynoxide (HTTP) DynamoDB Local LocalStack (all services)
Cold startup <!-- bench:ci_startup_embedded --><1ms<!-- /bench --> <!-- bench:ci_startup_http -->~2ms<!-- /bench --> <!-- bench:ci_startup_ddb_local -->~2,596ms<!-- /bench --> <!-- bench:ci_startup_localstack -->~11,648ms<!-- /bench -->
GetItem (p50) <!-- bench:ci_getitem_embedded -->14µs<!-- /bench --> <!-- bench:ci_getitem_http -->0.3ms<!-- /bench --> <!-- bench:ci_getitem_ddb_local -->0.8ms<!-- /bench --> -
50-test CI suite <!-- bench:ci_suite_embedded_seq -->784ms<!-- /bench --> <!-- bench:ci_suite_http_seq -->778ms<!-- /bench --> <!-- bench:ci_suite_ddb_local_seq -->2,518ms<!-- /bench --> -
Full workload (10K items) - <!-- bench:ci_workload_http -->3.0s<!-- /bench --> <!-- bench:ci_workload_ddb_local -->11.5s<!-- /bench --> -
Binary / image (download) <!-- prose:ci_binary_download -->~3 MB<!-- /bench --> <!-- prose:ci_binary_download_http -->~3 MB<!-- /bench --> <!-- prose:ci_image_ddb_local_download -->225 MB<!-- /bench --> <!-- prose:ci_image_localstack_download -->1.1 GB<!-- /bench -->
Binary / image (on disk) <!-- bench:ci_binary_size -->6 MB<!-- /bench --> <!-- bench:ci_binary_size_http -->6 MB<!-- /bench --> <!-- bench:ci_image_ddb_local -->471 MB<!-- /bench --> <!-- bench:ci_image_localstack -->1.1 GB<!-- /bench -->
Idle memory (RSS) <!-- bench:ci_memory_embedded_idle -->~4.9 MB<!-- /bench --> <!-- bench:ci_memory_http_idle -->~8 MB<!-- /bench --> <!-- bench:ci_memory_ddb_local_idle -->~185 MB<!-- /bench --> <!-- bench:ci_memory_localstack_idle -->~494 MB<!-- /bench -->

The gap is wider on Apple Silicon because the faster CPU amplifies the difference between native code and JVM overhead. Both are real measurements of the same benchmark suite. Full methodology and per-operation breakdowns →

Conformance

Dynoxide is continuously verified against real DynamoDB by the dynamodb-conformance suite, which runs one test matrix against AWS itself and every major DynamoDB emulator. Pass rates move as the suite grows and each engine changes, so rather than pin a snapshot that goes stale, see the live standings:

This covers the native build. The WebAssembly build is a preview and isn't run against the suite yet.

How It Compares

Dynoxide DynamoDB Local LocalStack (all services) dynalite
Language Rust Java Python + Java Node.js
Storage SQLite SQLite SQLite (via DDB Local) LevelDB
Runtime dependency - JVM Docker + LocalStack Node.js
Embeddable (Rust / iOS) - - -
MCP server for agents - - -

LocalStack uses DynamoDB Local internally as its DynamoDB engine, so its startup and memory overhead includes DynamoDB Local's JVM plus LocalStack's own Python routing layer.

Quick Start

Install from npm and start a local server:

npm install --save-dev dynoxide
npx dynoxide --port 8000

Or run it in Docker, a drop-in for amazon/dynamodb-local:

docker run --rm -p 8000:8000 ghcr.io/nubo-db/dynoxide

Point any AWS SDK or DynamoDB client at http://localhost:8000. For Homebrew, Cargo, pre-built binaries, and embedding as a Rust library, see the installation guide.

Documentation

Supported Operations

Dynoxide implements the DynamoDB API across tables, items, query and scan, batches, transactions, PartiQL, streams, TTL, and tags, with GSI and LSI support, the full expression syntax, and DynamoDB-compatible pagination, validation, and error codes. For the operation-by-operation breakdown and a comparison, see the compatibility summary.

Limitations

Dynoxide is built for local development, testing, and CI, not as a production DynamoDB replacement, so two classes of thing are missing on purpose.

Cloud-only operations with no local equivalent aren't implemented: backups and point-in-time restore, global tables, Kinesis streaming, resource policies, and capacity management. Call one and you get an UnknownOperationException.

A few behavioural differences are also worth knowing when you test against it:

  • ConsistentRead is accepted but changes nothing. SQLite is strongly consistent, so every read already is - you can't reproduce eventually-consistent reads.
  • Streams expose a single shard. DescribeStream returns one shard, and its ExclusiveStartShardId and Limit paging parameters are accepted but ignored.
  • Transaction-contention errors (TransactionConflictException, TransactionInProgressException) aren't emulated - there's no concurrent contention in a single process.

For the live, per-feature support matrix see paritysuite.org/capabilities, and the full operation-by-operation breakdown is in the compatibility summary.

Acknowledgements

Dynoxide's DynamoDB API semantics and validation logic were informed by dynalite, the excellent DynamoDB emulator built on LevelDB by Michael Hart and now maintained by the Architect team.

Dynoxide is a clean-room Rust implementation. No code was ported directly, but dynalite's thorough approach to matching live DynamoDB behaviour, including edge cases and error messages, was an invaluable reference.

Dynoxide uses SQLite as its storage layer. (AWS's DynamoDB Local also uses SQLite internally.)

License

Dual-licensed under MIT and Apache 2.0. See LICENSE-MIT and LICENSE-APACHE.

Trademarks

Amazon DynamoDB, DynamoDB, and AWS are trademarks of Amazon.com, Inc. or its affiliates. Dynoxide is an independent project and is not affiliated with, endorsed by, or sponsored by Amazon, and nothing here grants any right to use those names or marks.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured