Installer internals
OpenClaw ships three installer scripts, served from openclaw.ai.
Script Platform What it does install.shmacOS / Linux / WSL Installs Node if needed, installs OpenClaw via npm (default) or git, and can run onboarding. install-cli.shmacOS / Linux / WSL Installs Node + OpenClaw into a local prefix (~/.openclaw). No root required. install.ps1Windows (PowerShell) Installs Node if needed, installs OpenClaw via npm (default) or git, and can run onboarding.
Quick commands
install.sh
install-cli.sh
install.ps1
curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install.sh | bash
curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install.sh | bash -s -- --help
curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install-cli.sh | bash
curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install-cli.sh | bash -s -- --help
iwr - useb https: // openclaw.ai / install.ps1 | iex
& ([ scriptblock ]::Create((iwr - useb https: // openclaw.ai / install.ps1))) - Tag beta - NoOnboard - DryRun
install.sh
Recommended for most interactive installs on macOS/Linux/WSL.
Flow (install.sh)
Detect OS
Supports macOS and Linux (including WSL). If macOS is detected, installs Homebrew if missing.
Ensure Node.js 24 by default
Checks Node version and installs Node 24 if needed (Homebrew on macOS, NodeSource setup scripts
on Linux apt/dnf/yum). OpenClaw still supports Node 22 LTS, currently 22.14+, for
compatibility.
Ensure Git
Installs Git if missing.
Install OpenClaw
npm method (default): global npm install - git method: clone/update repo, install deps
with pnpm, build, then install wrapper at ~/.local/bin/openclaw
Post-install tasks
Runs openclaw doctor --non-interactive on upgrades and git installs (best effort) - Attempts
onboarding when appropriate (TTY available, onboarding not disabled, and bootstrap/config checks
pass) - Defaults SHARP_IGNORE_GLOBAL_LIBVIPS=1
Source checkout detection
If run inside an OpenClaw checkout (package.json + pnpm-workspace.yaml), the script offers:
use checkout (git), or
use global install (npm)
If no TTY is available and no install method is set, it defaults to npm and warns.
The script exits with code 2 for invalid method selection or invalid --install-method values.
Examples (install.sh)
Default
Skip onboarding
Custom git directory
bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install.sh | bash
curl -fsSL --proto --tlsv1.2 https://openclaw.ai/install.sh | bash -s --
--no-onboard ```
< /Tab >
< Tab title = "Git install" >
``` bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install.sh | bash -s --
--install-method git ```
< /Tab >
< Tab title = "GitHub main via npm" >
``` bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install.sh | bash -s --
--version main ```
< /Tab >
< Tab title = "Dry run" >
``` bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install.sh | bash -s --
--dry-run ```
< /Tab >
< /Tabs >
< AccordionGroup >
< Accordion title = "Flags reference" >
| Flag | Description |
| ------------------------------------- | ---------------------------------------------------------- |
| ` --install-method npm \| git ` | Choose install method (default: ` npm `). Alias: `--method` |
| ` --npm ` | Shortcut for npm method |
| ` --git ` | Shortcut for git method. Alias: ` --github ` |
| ` --version < version \| dist-tag \| spe c > ` | npm version, dist-tag, or package spec (default: ` latest `) |
| ` --beta ` | Use beta dist-tag if available, else fallback to ` latest ` |
| ` --git-dir < pat h > ` | Checkout directory (default: ` ~/openclaw `). Alias: `--dir` |
| ` --no-git-update ` | Skip ` git pull ` for existing checkout |
| ` --no-prompt ` | Disable prompts |
| ` --no-onboard ` | Skip onboarding |
| ` --onboard ` | Enable onboarding |
| ` --dry-run ` | Print actions without applying changes |
| ` --verbose ` | Enable debug output (` set -x ` , npm notice-level logs ) |
| ` --help ` | Show usage (` -h `) |
< /Accordion >
< Accordion title = "Environment variables reference" >
| Variable | Description |
| ------------------------------------------------------- | --------------------------------------------- |
| ` OPENCLAW_INSTALL_METHOD = git \| npm ` | Install method |
| ` OPENCLAW_VERSION = latest \| next \| main \| < semver > \| < spec > ` | npm version, dist-tag, or package spec |
| ` OPENCLAW_BETA = 0 \| 1 ` | Use beta if available |
| ` OPENCLAW_GIT_DIR =< path > ` | Checkout directory |
| ` OPENCLAW_GIT_UPDATE = 0 \| 1 ` | Toggle git updates |
| ` OPENCLAW_NO_PROMPT = 1 ` | Disable prompts |
| ` OPENCLAW_NO_ONBOARD = 1 ` | Skip onboarding |
| ` OPENCLAW_DRY_RUN = 1 ` | Dry run mode |
| ` OPENCLAW_VERBOSE = 1 ` | Debug mode |
| ` OPENCLAW_NPM_LOGLEVEL = error \| warn \| notice ` | npm log level |
| ` SHARP_IGNORE_GLOBAL_LIBVIPS = 0 \| 1 ` | Control sharp/libvips behavior (default: ` 1 `) |
< /Accordion >
< /AccordionGroup >
---
## install-cli.sh
< Info >
Designed for environments where you want everything under a local prefix (default ` ~/.openclaw `)
and no system Node dependency.
< /Info >
### Flow (install-cli.sh)
< Steps >
< Step title = "Install local Node runtime" >
Downloads a pinned supported Node LTS tarball (the version is embedded in the script and updated independently ) to ` < prefix > /tools/node-v < version > ` and verifies SHA-256.
< /Step >
< Step title = "Ensure Git" >
If Git is missing, attempts install via apt/dnf/yum on Linux or Homebrew on macOS.
< /Step >
< Step title = "Install OpenClaw under prefix" >
Installs with npm using ` --prefix < prefi x > ` , then writes wrapper to ` < prefix > /bin/openclaw ` .
< /Step >
< /Steps >
### Examples (install-cli.sh)
< Tabs >
< Tab title = "Default" >
``` bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install-cli.sh | bash ```
< /Tab >
< Tab title = "Custom prefix + version" >
``` bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install-cli.sh | bash -s --
--prefix /opt/openclaw --version latest ```
< /Tab >
< Tab title = "Automation JSON output" >
``` bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install-cli.sh | bash -s --
--json --prefix /opt/openclaw ```
< /Tab >
< Tab title = "Run onboarding" >
``` bash curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install-cli.sh | bash -s --
--onboard ```
< /Tab >
< /Tabs >
< AccordionGroup >
< Accordion title = "Flags reference" >
| Flag | Description |
| ---------------------- | ------------------------------------------------------------------------------- |
| ` --prefix < pat h > ` | Install prefix (default: ` ~/.openclaw `) |
| ` --version < ve r > ` | OpenClaw version or dist-tag (default: ` latest `) |
| ` --node-version < ve r > ` | Node version (default: ` 22.22.0 `) |
| ` --json ` | Emit NDJSON events |
| ` --onboard ` | Run ` openclaw onboard ` after install |
| ` --no-onboard ` | Skip onboarding (default) |
| ` --set-npm-prefix ` | On Linux, force npm prefix to ` ~/.npm-global ` if current prefix is not writable |
| ` --help ` | Show usage (` -h `) |
< /Accordion >
< Accordion title = "Environment variables reference" >
| Variable | Description |
| ------------------------------------------- | --------------------------------------------------------------------------------- |
| `OPENCLAW_PREFIX =< path > ` | Install prefix |
| `OPENCLAW_VERSION =< ver > ` | OpenClaw version or dist-tag |
| `OPENCLAW_NODE_VERSION =< ver > ` | Node version |
| `OPENCLAW_NO_ONBOARD = 1 ` | Skip onboarding |
| `OPENCLAW_NPM_LOGLEVEL = error \| warn \| notice ` | npm log level |
| `OPENCLAW_GIT_DIR =< path > ` | Legacy cleanup lookup path (used when removing old ` Peekaboo ` submodule checkout ) |
| `SHARP_IGNORE_GLOBAL_LIBVIPS = 0 \| 1 ` | Control sharp/libvips behavior (default: ` 1 `) |
< /Accordion >
< /AccordionGroup >
---
## install.ps1
### Flow (install.ps1)
< Steps >
< Step title = "Ensure PowerShell + Windows environment" > Requires PowerShell 5+. < /Ste p >
< Step title = "Ensure Node.js 24 by default" >
If missing, attempts install via winget, then Chocolatey, then Scoop. Node 22 LTS, currently
` 22.14+ ` , remains supported for compatibility.
< /Step >
< Step title = "Install OpenClaw" >
- ` npm ` method (default): global npm install using selected ` -Tag ` - ` git ` method: clone/update
repo, install/build with pnpm, and install wrapper at ` %USERPROFILE%\.local\bin\openclaw.cmd `
< /Step >
< Step title = "Post-install tasks" >
Adds needed bin directory to user PATH when possible, then runs ` openclaw doctor
--non-interactive ` on upgrades and git installs (best effort ).
< /Step >
< /Steps >
### Examples (install.ps1)
< Tabs >
< Tab title = "Default" > ``` powershell iwr -useb https://openclaw.ai/install.ps1 | iex ``` < /Tab >
< Tab title = "Git install" >
``` powershell & ([scriptblock]::Create((iwr - useb https :// openclaw.ai / install.ps1)))
-InstallMethod git ```
< /Tab >
< Tab title = "GitHub main via npm" >
``` powershell & ([scriptblock]::Create((iwr - useb https :// openclaw.ai / install.ps1))) -Tag main
& ([scriptblock]::Create((iwr -useb https://openclaw.ai/install.ps1)))
- InstallMethod git - GitDir "C:\openclaw" `` `
</ Tab >
< Tab title = "Dry run" >
`` ` powershell & ([ scriptblock ]::Create((iwr - useb https: // openclaw.ai / install.ps1))) - DryRun `` `
</ Tab >
< Tab title = "Debug trace" >
`` ` powershell # install.ps1 has no dedicated -Verbose flag yet. Set-PSDebug -Trace 1 &
([ scriptblock ]::Create((iwr - useb https: // openclaw.ai / install.ps1))) - NoOnboard Set-PSDebug
- Trace 0 `` `
</ Tab >
</ Tabs >
< AccordionGroup >
< Accordion title = "Flags reference" >
| Flag | Description |
| --------------------------- | ---------------------------------------------------------- |
| `- InstallMethod npm\ | git ` | Install method ( default : `npm ` ) |
| `- Tag < tag\ | version\ | spec >` | npm dist - tag , version , or package spec ( default : ` latest ` ) |
| `- GitDir < path >` | Checkout directory ( default : `% USERPROFILE % \openclaw ` ) |
| `- NoOnboard ` | Skip onboarding |
| `- NoGitUpdate ` | Skip ` git pull ` |
| `- DryRun ` | Print actions only |
</ Accordion >
< Accordion title = "Environment variables reference" >
| Variable | Description |
| ---------------------------------- | ------------------ |
| ` OPENCLAW_INSTALL_METHOD = git\ | npm ` | Install method |
| ` OPENCLAW_GIT_DIR =< path >` | Checkout directory |
| ` OPENCLAW_NO_ONBOARD = 1 ` | Skip onboarding |
| ` OPENCLAW_GIT_UPDATE = 0 ` | Disable git pull |
| ` OPENCLAW_DRY_RUN = 1 ` | Dry run mode |
</ Accordion >
</ AccordionGroup >
< Note >
If `- InstallMethod git ` is used and Git is missing , the script exits and prints the Git for
Windows link.
</ Note >
---
## CI and automation
Use non - interactive flags / env vars for predictable runs.
< Tabs >
< Tab title = "install.sh (non-interactive npm)" >
```bash curl - fsSL -- proto '=https' -- tlsv1. 2 https: // openclaw.ai / install.sh | bash - s --
-- no - prompt -- no - onboard `` `
</ Tab >
< Tab title = "install.sh (non-interactive git)" >
```bash OPENCLAW_INSTALL_METHOD = git OPENCLAW_NO_PROMPT = 1 \ curl - fsSL -- proto '=https' -- tlsv1. 2
https: // openclaw.ai / install.sh | bash `` `
</ Tab >
< Tab title = "install-cli.sh (JSON)" >
```bash curl - fsSL -- proto '=https' -- tlsv1. 2 https: // openclaw.ai / install-cli .sh | bash - s --
-- json -- prefix / opt / openclaw `` `
</ Tab >
< Tab title = "install.ps1 (skip onboarding)" >
`` ` powershell & ([ scriptblock ]::Create((iwr - useb https: // openclaw.ai / install.ps1))) - NoOnboard
Troubleshooting
Git is required for git install method. For npm installs, Git is still checked/installed to avoid spawn git ENOENT failures when dependencies use git URLs.
Why does npm hit EACCES on Linux?
Some Linux setups point npm global prefix to root-owned paths. install.sh can switch prefix to
~/.npm-global and append PATH exports to shell rc files (when those files exist).
The scripts default SHARP_IGNORE_GLOBAL_LIBVIPS=1 to avoid sharp building against system libvips. To override: SHARP_IGNORE_GLOBAL_LIBVIPS = 0 curl -fsSL --proto '=https' --tlsv1.2 https://openclaw.ai/install.sh | bash
Windows: "npm error spawn git / ENOENT"
Install Git for Windows, reopen PowerShell, rerun installer.
Windows: "openclaw is not recognized"
Run npm config get prefix and add that directory to your user PATH (no \bin suffix needed on
Windows), then reopen PowerShell.
Windows: how to get verbose installer output
install.ps1 does not currently expose a -Verbose switch.
Use PowerShell tracing for script-level diagnostics:Set-PSDebug - Trace 1
& ([ scriptblock ]::Create((iwr - useb https: // openclaw.ai / install.ps1))) - NoOnboard
Set-PSDebug - Trace 0
openclaw not found after install
This page is sourced from openclaw/openclaw .