Install overview

Node.js

OpenClaw には Node 22.16 以降が必要です。インストール、CI、リリースワークフローでは、Node 24 がデフォルトかつ推奨ランタイムです。Node 22 はアクティブな LTS 系列を通じて引き続きサポートされます。インストーラースクリプトは Node を自動的に検出してインストールします。このページは、Node を自分でセットアップし、すべてが正しく接続されていること(バージョン、PATH、グローバルインストール)を確認したい場合のためのものです。

バージョンを確認する

bash
node -v

これが v24.x.x 以上を出力する場合、推奨デフォルトを使用しています。v22.16.x 以上を出力する場合、サポート対象の Node 22 LTS パスを使用していますが、都合のよいタイミングで Node 24 へアップグレードすることを引き続き推奨します。Node がインストールされていない、またはバージョンが古すぎる場合は、以下からインストール方法を選んでください。

Node をインストールする

macOS

Homebrew(推奨):

bash
brew install node

または nodejs.org から macOS インストーラーをダウンロードします。

Linux

Ubuntu / Debian:

bash
curl -fsSL https://deb.nodesource.com/setup_24.x | sudo -E bash -sudo apt-get install -y nodejs

Fedora / RHEL:

bash
sudo dnf install nodejs

またはバージョンマネージャーを使用します(下記参照)。

Windows

winget(推奨):

powershell
winget install OpenJS.NodeJS.LTS

Chocolatey:

powershell
choco install nodejs-lts

または nodejs.org から Windows インストーラーをダウンロードします。

バージョンマネージャー(nvm、fnm、mise、asdf)を使用する

バージョンマネージャーを使うと、Node のバージョンを簡単に切り替えられます。よく使われる選択肢:

  • fnm - 高速でクロスプラットフォーム
  • nvm - macOS/Linux で広く使用されている
  • mise - ポリグロット(Node、Python、Ruby など)

fnm の例:

bash
fnm install 24fnm use 24

トラブルシューティング

openclaw: command not found

これはほとんどの場合、npm のグローバル bin ディレクトリが PATH に含まれていないことを意味します。

  • グローバル npm prefix を見つける

    bash
    npm prefix -g
  • PATH に含まれているか確認する

    bash
    echo "$PATH"

    出力に <npm-prefix>/bin(macOS/Linux)または <npm-prefix>(Windows)があるか確認します。

  • シェルの起動ファイルに追加する

    macOS / Linux

    ~/.zshrc または ~/.bashrc に追加します:

    bash
    export PATH="$(npm prefix -g)/bin:$PATH"

    その後、新しいターミナルを開きます(または zsh では rehash、bash では hash -r を実行します)。

    Windows

    設定 → システム → 環境変数から、npm prefix -g の出力をシステム PATH に追加します。

  • npm install -g での権限エラー(Linux)

    EACCES エラーが表示される場合は、npm のグローバル prefix をユーザーが書き込み可能なディレクトリに切り替えます:

    bash
    mkdir -p "$HOME/.npm-global"npm config set prefix "$HOME/.npm-global"export PATH="$HOME/.npm-global/bin:$PATH"

    永続化するには、export PATH=... 行を ~/.bashrc または ~/.zshrc に追加します。

    関連

    Was this useful?