Awesome
<p align="center"> <a href="https://spacetimedb.com#gh-dark-mode-only" target="_blank"> <img width="320" src="./images/dark/logo.svg" alt="SpacetimeDB Logo"> </a> <a href="https://spacetimedb.com#gh-light-mode-only" target="_blank"> <img width="320" src="./images/light/logo.svg" alt="SpacetimeDB Logo"> </a> </p> <p align="center"> <a href="https://spacetimedb.com#gh-dark-mode-only" target="_blank"> <img width="250" src="./images/dark/logo-text.svg" alt="SpacetimeDB"> </a> <a href="https://spacetimedb.com#gh-light-mode-only" target="_blank"> <img width="250" src="./images/light/logo-text.svg" alt="SpacetimeDB"> </a> <h3 align="center"> Multiplayer at the speed of light. </h3> </p> <p align="center"> <a href="https://github.com/clockworklabs/spacetimedb"><img src="https://img.shields.io/github/v/release/clockworklabs/spacetimedb?color=%23ff00a0&include_prereleases&label=version&sort=semver&style=flat-square"></a> <a href="https://github.com/clockworklabs/spacetimedb"><img src="https://img.shields.io/badge/built_with-Rust-dca282.svg?style=flat-square"></a> <a href="https://github.com/clockworklabs/spacetimedb/actions"><img src="https://img.shields.io/github/actions/workflow/status/clockworklabs/spacetimedb/ci.yml?style=flat-square&branch=master"></a> <a href="https://status.spacetimedb.com"><img src="https://img.shields.io/uptimerobot/ratio/7/m784409192-e472ca350bb615372ededed7?label=cloud%20uptime&style=flat-square"></a> <a href="https://hub.docker.com/r/clockworklabs/spacetimedb"><img src="https://img.shields.io/docker/pulls/clockworklabs/spacetimedb?style=flat-square"></a> <a href="https://github.com/clockworklabs/spacetimedb/blob/master/LICENSE.txt"><img src="https://img.shields.io/badge/license-BSL_1.1-00bfff.svg?style=flat-square"></a> </p> <p align="center"> <a href="https://crates.io/crates/spacetimedb"><img src="https://img.shields.io/crates/d/spacetimedb?color=e45928&label=Rust%20Crate&style=flat-square"></a> <a href="https://www.nuget.org/packages/SpacetimeDB.Runtime"><img src="https://img.shields.io/nuget/dt/spacetimedb.runtime?color=0b6cff&label=NuGet%20Package&style=flat-square"></a> </p> <p align="center"> <a href="https://discord.gg/spacetimedb"><img src="https://img.shields.io/discord/1037340874172014652?label=discord&style=flat-square&color=5a66f6"></a> <a href="https://twitter.com/spacetime_db"><img src="https://img.shields.io/badge/twitter-Follow_us-1d9bf0.svg?style=flat-square"></a> <a href="https://clockworklabs.io/join"><img src="https://img.shields.io/badge/careers-Join_us-86f7b7.svg?style=flat-square"></a> <a href="https://www.linkedin.com/company/clockworklabs/"><img src="https://img.shields.io/badge/linkedin-Connect_with_us-0a66c2.svg?style=flat-square"></a> </p> <p align="center"> <a href="https://discord.gg/spacetimedb"><img height="25" src="./images/social/discord.svg" alt="Discord"></a> <a href="https://twitter.com/spacetime_db"><img height="25" src="./images/social/twitter.svg" alt="Twitter"></a> <a href="https://github.com/clockworklabs/spacetimedb"><img height="25" src="./images/social/github.svg" alt="Github"></a> <a href="https://twitch.tv/SpacetimeDB"><img height="25" src="./images/social/twitch.svg" alt="Twitch"></a> <a href="https://youtube.com/@SpacetimeDB"><img height="25" src="./images/social/youtube.svg" alt="YouTube"></a> <a href="https://www.linkedin.com/company/clockwork-labs/"><img height="25" src="./images/social/linkedin.svg" alt="LinkedIn"></a> <a href="https://stackoverflow.com/questions/tagged/spacetimedb"><img height="25" src="./images/social/stackoverflow.svg" alt="StackOverflow"></a> </p> <br>What is SpacetimeDB?
You can think of SpacetimeDB as both a database and server combined into one.
It is a relational database system that lets you upload your application logic directly into the database by way of fancy stored procedures called "modules."
Instead of deploying a web or game server that sits in between your clients and your database, your clients connect directly to the database and execute your application logic inside the database itself. You can write all of your permission and authorization logic right inside your module just as you would in a normal server.
This means that you can write your entire application in a single language, Rust, and deploy it as a single binary. No more microservices, no more containers, no more Kubernetes, no more Docker, no more VMs, no more DevOps, no more infrastructure, no more ops, no more servers.
<figure> <img src="./images/basic-architecture-diagram.png" alt="SpacetimeDB Architecture" style="width:100%"> <figcaption align="center"> <p align="center"><b>SpacetimeDB application architecture</b><br /><sup><sub>(elements in white are provided by SpacetimeDB)</sub></sup></p> </figcaption> </figure>It's actually similar to the idea of smart contracts, except that SpacetimeDB is a database, has nothing to do with blockchain, and is orders of magnitude faster than any smart contract system.
So fast, in fact, that the entire backend of our MMORPG BitCraft Online is just a SpacetimeDB module. We don't have any other servers or services running, which means that everything in the game, all of the chat messages, items, resources, terrain, and even the locations of the players are stored and processed by the database before being synchronized out to all of the clients in real-time.
SpacetimeDB is optimized for maximum speed and minimum latency rather than batch processing or OLAP workloads. It is designed to be used for real-time applications like games, chat, and collaboration tools.
This speed and latency is achieved by holding all of application state in memory, while persisting the data in a write-ahead-log (WAL) which is used to recover application state.
Installation
SpacetimeDB is an embedded database library that you can use to extend your own applications. You can also run SpacetimeDB as a standalone database server via the spacetime
CLI tool.
You can install and run the spacetime
CLI tool via Cargo, Homebrew, Docker, or by downloading the binary directly from our website.
Install on macOS
You can install SpacetimeDB on macOS using Homebrew. This will install the spacetime
CLI tool and the SpacetimeDB standalone server as a single executable. You can also install on macOS using the Linux instructions below.
brew install clockworklabs/tap/spacetime
Install on Linux
Installing SpacetimeDB on Linux (or other Unix operating systems) is as easy as downloading the binary and running it. You can also install on Linux using the Docker instructions below.
curl --proto '=https' --tlsv1.2 -sSf https://install.spacetimedb.com | sh
Install on Windows
Run the following command in your terminal and follow the on-screen instructions to install the spacetime
CLI tool and the SpacetimeDB standalone server as a single executable.
iwr https://windows.spacetimedb.com -useb | iex
Install with Cargo
If you'd like to build the spacetime
CLI tool from source, you can install it using Cargo.
cargo install spacetimedb-cli
Installing from Source
For MacOS and Linux this is straightforward. Just run the following commands in a terminal:
# Install rustup, you can skip this step if you have cargo and the wasm32-unknown-unknown target already installed.
curl https://sh.rustup.rs -sSf | sh
# Clone SpacetimeDB
git clone https://github.com/clockworklabs/SpacetimeDB
# Build and install the CLI
cd SpacetimeDB
cargo install --path ./crates/cli --locked
Windows may require some extra dependencies be installed, including openssl and a specific version of perl. A guide for this will be available soon.
Running with Docker
You can execute the spacetime
CLI tool using Docker to run the SpacetimeDB standalone server without needing to install any command-line tools or other dependencies.
docker run --rm --pull always --name spacetimedb -p 3000:80 clockworklabs/spacetimedb:latest start
Documentation
For more information about SpacetimeDB, getting started guides, game development guides, and reference material please see our documentation.
Getting Started
We've prepared several getting started guides in each of our supported languages to help you get up and running with SpacetimeDB as quickly as possible. You can find them on our docs page.
In summary there are only 4 steps to getting started with SpacetimeDB.
- Install the
spacetime
CLI tool. - Start a SpacetimeDB standalone node with
spacetime start
. - Write and upload a module in one of our supported module languages.
- Connect to the database with one of our client libraries.
You can see a summary of the supported languages below with a link to the getting started guide for each.
Language Support
You can write SpacetimeDB modules in a bunch of popular languages, with many more to come in the future!
Serverside Libraries
- Rust
- C# (experimental)
- Typescript (planned)
- Python (planned)
- C++ (planned)
- Lua (planned)
Client Libraries
- Rust
- C#
- Typescript
- Python (planned)
- C++ (planned)
- Lua (planned)
License
SpacetimeDB is licensed under the BSL 1.1 license. This is not an open source or free software license, however, it converts to the AGPL v3.0 license with a linking exception after a few years.
Note that the AGPL v3.0 does not typically include a linking exception. We have added a custom linking exception to the AGPL license for SpacetimeDB. Our motivation for choosing a free software license is to ensure that contributions made to SpacetimeDB are propagated back to the community. We are expressly not interested in forcing users of SpacetimeDB to open source their own code if they link with SpacetimeDB, so we needed to include a linking exception.