• Start

Overview

Deployment

Deployment models for SurrealDB — managed cloud, single-node RocksDB, multi-node clusters, and embedded runtimes — and how to choose between them.

SurrealDB separates the query engine (compute) from the underlying storage layer. The same SurrealQL, APIs, and client SDKs work across embedded devices, single-node servers, distributed clusters, and SurrealDB Cloud — so you can change how the database runs without rewriting application code.

This page explains the available deployment options, storage engines, and how to choose the right architecture for your workload. For how the compute and storage layers interact, see Architecture.

Deployment modelStorage engine(s)ScalingHigh availabilityVersioning (VERSION)Best forManaged option
SurrealDB CloudSingle-node to distributed clusterAutomaticFully managed HAWhere enabledProduction without operating infrastructureYes
Single nodeRocksDB (recommended for server workloads); SurrealKV (beta)VerticalFilesystem backupsWhere enabled (see engine docs)Development and single-node productionSelf-hosted (Community Edition)
Multi-nodeDistributed storageHorizontalReplication and consensusWhere enabled on the storage tierLarge-scale production workloadsSurrealDB Cloud Dedicated tiers; self-hosted (EKS, GKE, AKS)
EmbeddedSurrealMX (memory), SurrealKV (beta), RocksDB, IndexedDB (browser)Application-boundApplication-boundWhere enabledOffline, edge, browser, and low-latency local appsNo

SurrealDB consists of two major layers:

Query layer

  • Parses and executes SurrealQL

  • Authenticates connections and sessions

  • Enforces table- and field-level permissions on reads and writes

  • Plans index-backed queries, maintains index entries during writes, and coordinates transactions

Storage layer

  • Handles persistence and durability

  • Determines scalability, temporal versioning, replication, and fault tolerance

Because these layers are separated in the architecture, applications can move between deployment models without changing application code or queries. Embedded and browser deployments still use both layers, but they run in-process rather than as separate services.

SurrealDB Cloud provides a fully managed deployment platform built on scalable, fault-tolerant infrastructure. It removes the operational complexity of running clusters while providing production-ready deployments.

For more detail, see What is SurrealDB Cloud? and Cloud architecture.

  • Managed SurrealDB infrastructure

  • Automatic scaling

  • High availability

  • Managed backups

  • Secure connectivity

  • Multi-node distributed architecture (Dedicated tiers)

  • Production monitoring and operations

  • Managed infrastructure

  • Rapid production deployment

  • Scaling applications

  • SaaS platforms

  • Enterprise workloads

FeatureSelf-hostedSurrealDB Cloud
Infrastructure managementRequiredManaged
BackupsManualManaged
ScalingManualAutomatic
HA setupManualBuilt-in
UpgradesManualManaged
Cluster operationsManualManaged

Single-node deployments run SurrealDB as a standalone server process using RocksDB. This is the simplest and most widely used production architecture on disk. RocksDB is a high-performance LSM-tree key-value store optimised for high write throughput, SSD storage, and predictable persistence.

Best for

  • Small to medium production workloads

  • Internal tooling

  • Development environments

  • Applications without horizontal scaling or built-in cluster fault tolerance

  • Vertical scaling only

  • No built-in distributed fault tolerance

For setup examples, see Run a single-node, on-disk server.

CLI

surreal start rocksdb://path/to/database

Docker

docker run --rm \
-p 8000:8000 \
surrealdb/surrealdb:latest \
start --user root --pass secret rocksdb://data/database.db

See also Self-hosted deployment for Docker, Kubernetes, and platform guides.

For single-node and embedded workloads, SurrealKV is SurrealDB’s own LSM-backed storage engine, developed in concert with the database rather than as a third-party dependency. That co-development shows up in day-to-day operation: SurrealKV exposes a comparatively small configuration surface and environment variable set next to RocksDB’s extensive tuning knobs, and is aimed at embedded and local-first scenarios.

SurrealKV remains beta. For conservative production on-disk server deployments today, prefer RocksDB. For embedded deployments where smaller resident memory and in-process behaviour are priorities, SurrealKV is the path to evaluate first. It is nonetheless a serious storage path inside the project: features such as temporal reads via the VERSION clause were exercised on SurrealKV first and have since been extended to SurrealMX and RocksDB where the engine supports them.

To try SurrealKV on a server, see the SurrealKV tab on Run a single-node, on-disk server and the surreal start storage parameters.

Multi-node deployments run multiple SurrealDB query nodes against shared distributed storage so reads and writes stay consistent across the cluster. This is the architecture for horizontal scaling and high availability in production.

In distributed deployments:

  • Multiple SurrealDB query nodes scale horizontally against shared storage

  • The primary dataset lives in the storage layer rather than on individual query nodes

  • The storage backend manages replication, consensus, fault tolerance, and distributed transactions

For managed multi-node clusters, use SurrealDB Cloud Dedicated tiers. For self-hosted highly available setups on Kubernetes, see Amazon EKS, Google GKE, and Azure AKS. For local development against distributed storage, see Run a multi-node cluster.

Horizontal scalability — Scale query and storage nodes independently.

Fault tolerance — Replication and consensus allow clusters to tolerate node failures.

Distributed ACID transactions — Strong transactional guarantees across distributed infrastructure.

Large-scale storage — Designed for very large datasets and high-concurrency production workloads.

  • Enterprise deployments

  • High-availability applications

  • Multi-region systems

  • Large graph workloads

  • Real-time platforms

  • AI-native distributed systems

Distributed deployments add cluster orchestration, node management, monitoring, and replication management. Teams that want distributed scalability without operating that stack should consider SurrealDB Cloud.

Embedded deployments run SurrealDB inside your application process without a separate database server. The query and storage layers share the process (and, in the browser, the same runtime), which removes network latency between your app and the database. This model suits edge computing, mobile and desktop software, offline-first apps, browser PWAs, and AI workflows that need minimal latency.

For language-specific setup, see Embedding SurrealDB and Storage engines.

SurrealDB supports embedded operation in Rust, Go, JavaScript / TypeScript, WebAssembly, Python, and .NET. Capabilities vary by SDK and storage backend — check the embedding guide for your language.

In-memory (SurrealMX) — Default in-memory backend since SurrealDB 3.0, with optional snapshots or append-only persistence and support for versioned queries. See Run a single-node, in-memory server.

RocksDB — Persistent on-disk storage with mature tuning for write-heavy, SSD-backed server workloads. See File-backed storage.

SurrealKV — Same beta engine as single-node server deployments; aimed at embedded and local-first in-process workloads where smaller resident memory and simple operational behaviour matter most.

IndexedDB (browser) — Browser-native persistence with binary serialisation for PWAs and local-first web apps. See Embedding SurrealDB and the Wasm engine.

Use SurrealDB Cloud when

  • You want managed infrastructure

  • You need production-ready HA quickly

  • Your team prefers building applications over operating databases

Use single-node deployments with RocksDB when

  • Simplicity matters most

  • Scaling requirements are moderate

  • You run small-to-medium production workloads without cluster-level fault tolerance

Use multi-node deployments when

  • High availability is required

  • Workloads need horizontal scaling

  • Infrastructure spans multiple nodes or availability zones

For managed clusters, use SurrealDB Cloud Dedicated tiers. For self-hosted Kubernetes, follow the EKS, GKE, or AKS guides.

Use embedded deployments when

  • You run on edge devices or in the browser

  • Offline operation is required

  • Minimising latency between app and database is critical

SurrealDB’s architecture lets the same engine and query language run across embedded, single-node, distributed, and managed models. Whether you embed SurrealDB in a browser, run RocksDB on one server, operate a multi-node cluster, or use SurrealDB Cloud, you can match operational and scalability requirements without rewriting queries.

Was this page helpful?