Open the server Apps tab
Select the tutorial-vps VPS, open the Apps tab, and start a new app deployment. Keep sensitive server details hidden before capturing or sharing screenshots.


Multi-model database for real-time apps with SQL-style queries and graph relations
Add your server credentials to Server Compass
Choose from our template library
Fill in settings and click Deploy
Use the SurrealDB template in Server Compass to deploy a multi-model database for real-time apps on your VPS, then verify the deployed database with SurrealDB HTTP health.
Select the tutorial-vps VPS, open the Apps tab, and start a new app deployment. Keep sensitive server details hidden before capturing or sharing screenshots.

Click New App and choose the template deployment path so Server Compass can load the built-in catalog.

Use the template picker search to find SurrealDB in the Server Compass template catalog.

Choose the SurrealDB template. Server Compass fills the SurrealDB container, persistent data volume, host port, root username, and generated root password.

Confirm the app name and compose service. In this run, the app was named surrealdb-demo and used host port 8000.

Review the generated environment values, keep the database password masked, confirm the web port is available, and click Deploy Now.

Keep the deployment modal open while Server Compass uploads the compose file, pulls the SurrealDB image, starts the container, and verifies the stack.

After deployment finishes, return to the Apps tab and confirm the SurrealDB app is marked Running with the database port available.

Open the app detail view and verify the running SurrealDB container. In this tutorial run, the SurrealDB HTTP health endpoint confirmed the database service was accepting connections without exposing the generated root password.

The SurrealDB service returned HTTP 200 from its health endpoint on the deployed VPS.
It deploys the official SurrealDB container with persistent SurrealKV storage, a root username, a generated root password, and the HTTP database port exposed on the selected host port.
The tutorial used host port 8000, which maps to SurrealDB container port 8000.
SurrealDB is a database service, not a conventional web application. The tutorial verifies it with the SurrealDB HTTP health endpoint instead of opening a browser page.
No. The deployment guide should live on the SurrealDB template detail page and be linked from the reusable template deployment docs page.
Deploy SurrealDB the traditional way with SSH and Docker Compose.
Open a terminal session and log into your VPS. Replace the placeholder with your actual IP.
# Connect via SSH
ssh root@your-vps-ip
# Alternative with key file
ssh -i /path/to/key root@your-vps-ipFirst time? Make sure Docker is installed on your VPS. Run: curl -fsSL https://get.docker.com | sh
Create a workspace for your deployment files.
# Create and navigate to project directory
mkdir -p ~/apps/surrealdb
cd ~/apps/surrealdbConfigure your containers with this Docker Compose setup:
services:
surrealdb:
image: surrealdb/surrealdb:latest
user: root
ports:
- "8000:8000"
volumes:
- surrealdb_data:/data
command: start --username root --password <your-surreal-pass> surrealkv:/data/database.db
restart: unless-stopped
healthcheck:
test: ["CMD", "surreal", "isready", "--endpoint", "http://localhost:8000"]
interval: 10s
timeout: 5s
retries: 5
volumes:
surrealdb_data:
PORTHost port to expose(default: 8000)SURREAL_USERRoot username(default: root)SURREAL_PASSRoot passwordSpin up the containers and verify the deployment.
# Start all services
docker compose up -d
# List running containers
docker compose ps
# Watch the logs
docker compose logs -fAllow incoming traffic on the application port.
# Allow the application port through firewall
sudo ufw allow 8000/tcp
sudo ufw reload
# Access your app at:
# http://your-server-ip:8000Server Compass makes deploying SurrealDB effortless. Visual setup, one-click deploy, done.
After deploying SurrealDB with Server Compass, complete these steps to finish setup
Test database connection using surreal sql CLI
Create namespaces and databases for your applications
Define schemas with DEFINE TABLE and DEFINE FIELD
Create scoped users with limited permissions
Set up monitoring and alerts
Configure backup schedules for the data volume
Need help? Check out our documentation for detailed guides.
Common questions about self-hosting SurrealDB
Simply download Server Compass, connect to your VPS, and select SurrealDB from the templates list. Fill in the required configuration and click Deploy. The entire process takes under 3 minutes.
SurrealDB requires a minimum of 256MB RAM. We recommend a VPS with at least 1024MB RAM for optimal performance. Any modern Linux server with Docker support will work.
Yes! Server Compass provides volume mapping that allows you to import existing data. You can also use standard SurrealDB backup and restore procedures.
Server Compass makes updates easy. Simply click the Update button in your deployment dashboard, and the latest SurrealDB image will be pulled and deployed with zero downtime.
SurrealDB is open-source software. You only pay for your VPS hosting (typically $5-20/month) and optionally Server Compass ($29 one-time). No subscription fees or per-seat pricing.
Download Server Compass and deploy SurrealDB to your VPS in under 3 minutes. No Docker expertise required.
Download Server Compass