Linux Server
Run the OpenClaw Gateway on any Linux server or cloud VPS. This page helps you pick a provider, explains how cloud deployments work, and covers generic Linux tuning that applies everywhere.Pick a provider
Railway
One-click, browser setup
Northflank
One-click, browser setup
DigitalOcean
Simple paid VPS
Oracle Cloud
Always Free ARM tier
Fly.io
Fly Machines
Hetzner
Docker on Hetzner VPS
Hostinger
VPS with one-click setup
GCP
Compute Engine
Azure
Linux VM
exe.dev
VM with HTTPS proxy
Raspberry Pi
ARM self-hosted
How cloud setups work
- The Gateway runs on the VPS and owns state + workspace.
- You connect from your laptop or phone via the Control UI or Tailscale/SSH.
- Treat the VPS as the source of truth and back up the state + workspace regularly.
- Secure default: keep the Gateway on loopback and access it via SSH tunnel or Tailscale Serve.
If you bind to
lanortailnet, requiregateway.auth.tokenorgateway.auth.password.
Shared company agent on a VPS
Running a single agent for a team is a valid setup when every user is in the same trust boundary and the agent is business-only.- Keep it on a dedicated runtime (VPS/VM/container + dedicated OS user/accounts).
- Do not sign that runtime into personal Apple/Google accounts or personal browser/password-manager profiles.
- If users are adversarial to each other, split by gateway/host/OS user.
Using nodes with a VPS
You can keep the Gateway in the cloud and pair nodes on your local devices (Mac/iOS/Android/headless). Nodes provide local screen/camera/canvas andsystem.run
capabilities while the Gateway stays in the cloud.
Docs: Nodes, Nodes CLI.
Startup tuning for small VMs and ARM hosts
If CLI commands feel slow on low-power VMs (or ARM hosts), enable Node’s module compile cache:NODE_COMPILE_CACHEimproves repeated command startup times.OPENCLAW_NO_RESPAWN=1avoids extra startup overhead from a self-respawn path.- First command run warms the cache; subsequent runs are faster.
- For Raspberry Pi specifics, see Raspberry Pi.
systemd tuning checklist (optional)
For VM hosts usingsystemd, consider:
- Add service env for a stable startup path:
OPENCLAW_NO_RESPAWN=1NODE_COMPILE_CACHE=/var/tmp/openclaw-compile-cache
- Keep restart behavior explicit:
Restart=alwaysRestartSec=2TimeoutStartSec=90
- Prefer SSD-backed disks for state/cache paths to reduce random-I/O cold-start penalties.
openclaw onboard --install-daemon path, edit the user unit:
openclaw-gateway.service via sudo systemctl edit openclaw-gateway.service.
How Restart= policies help automated recovery:
systemd can automate service recovery.