• 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 CloudStart (single-node) to Scale (SurrealDS cluster)Vertical and horizontal (by plan)Fully managed HA on ScaleWhere 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-nodeSurrealDSHorizontal; distributed storageHigh (replication and consensus)Where enabled on the storage tierLarge-scale production workloadsScale on Cloud; self-hosted Enterprise
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.

Cloud plans range from Start (single-node, vertically scalable instances) to Scale (multi-node clusters on SurrealDS, minimum three compute units). Start is enough for many workloads; Scale is aimed at business-critical production where a single-node outage would stop the application and where operating HA yourself (Kubernetes, replication, patching, and backups) would otherwise consume platform team time. See Cloud architecture and Pricing.

For more detail, see What is SurrealDB Cloud?.

  • Managed SurrealDB infrastructure

  • Automatic scaling

  • High availability

  • Managed backups

  • Secure connectivity

  • Multi-node distributed architecture on the Scale plan

  • 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.

For high availability and horizontal scalability, SurrealDB supports distributed deployments using SurrealDS — SurrealDB's distributed transactional storage layer for large-scale clusters.

In distributed deployments:

  • Multiple query nodes scale horizontally against shared storage

  • SurrealDS manages replication, consensus, fault tolerance, and distributed transactions

  • Object-storage backing (rolling out on Scale) places transactional data in commodity object storage while frequently accessed data stays on local disk

This architecture enables zero-downtime scaling, resilient clusters, high-throughput workloads, geographically distributed applications, and (as Scale features roll out) database branching, instant replication and recovery, and lower storage costs at scale.

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

For a deeper overview of the storage engine, see SurrealDS.

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 instead of operating clusters yourself

  • You need production-ready HA quickly — especially on the Scale plan for multi-node fault tolerance

  • Your team prefers building applications over provisioning servers, Kubernetes, replication, and upgrade runbooks

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 with SurrealDS when

  • High availability is required

  • Workloads need horizontal scaling

  • Infrastructure spans multiple nodes or availability zones

For managed clusters, use SurrealDB Cloud Scale. For self-hosted Kubernetes with Enterprise, 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, scale horizontally with SurrealDS, or use SurrealDB Cloud Start or Scale, you can match operational and scalability requirements without rewriting queries.

Was this page helpful?