CLI commands

Node

openclaw node

Gateway WebSocket に接続し、このマシン上で system.run / system.which を公開する ヘッドレスノードホスト を実行します。

なぜノードホストを使うのか?

完全な macOS コンパニオンアプリをインストールせずに、ネットワーク内の 他のマシンでコマンドを実行 したい場合にノードホストを使用します。

一般的なユースケース:

  • リモートの Linux/Windows マシン(ビルドサーバー、ラボマシン、NAS)でコマンドを実行する。
  • exec を Gateway 上で サンドボックス化 したまま、承認済みの実行を他のホストに委任する。
  • 自動化や CI ノード向けに、軽量なヘッドレス実行ターゲットを提供する。

実行は引き続き、ノードホスト上の exec 承認 とエージェントごとの許可リストで保護されるため、コマンドアクセスをスコープ化し、明示的に保てます。

ブラウザプロキシ(ゼロ設定)

ノード上で browser.enabled が無効化されていない場合、ノードホストはブラウザプロキシを自動的に通知します。これにより、エージェントは追加設定なしで、そのノード上のブラウザ自動化を使用できます。

デフォルトでは、プロキシはノードの通常のブラウザプロファイル面を公開します。nodeHost.browserProxy.allowProfiles を設定すると、プロキシは制限的になります。許可リストにないプロファイル指定は拒否され、永続プロファイルの作成/削除ルートはプロキシ経由ではブロックされます。

必要に応じてノード上で無効化します:

json5
{  nodeHost: {    browserProxy: {      enabled: false,    },  },}

実行(フォアグラウンド)

bash
openclaw node run --host <gateway-host> --port 18789

オプション:

  • --host <host>: Gateway WebSocket ホスト(デフォルト: 127.0.0.1
  • --port <port>: Gateway WebSocket ポート(デフォルト: 18789
  • --context-path <path>: Gateway WebSocket コンテキストパス(例: /openclaw-gw)。WebSocket URL に追加されます。
  • --tls: Gateway 接続に TLS を使用する
  • --tls-fingerprint <sha256>: 期待される TLS 証明書フィンガープリント(sha256)
  • --node-id <id>: ノード ID を上書きする(ペアリングトークンをクリア)
  • --display-name <name>: ノードの表示名を上書きする

ノードホストの Gateway 認証

openclaw node runopenclaw node install は config/env から Gateway 認証を解決します(ノードコマンドに --token/--password フラグはありません):

  • OPENCLAW_GATEWAY_TOKEN / OPENCLAW_GATEWAY_PASSWORD が最初にチェックされます。
  • 次にローカル設定へのフォールバック: gateway.auth.token / gateway.auth.password
  • ローカルモードでは、ノードホストは意図的に gateway.remote.token / gateway.remote.password を継承しません。
  • gateway.auth.token / gateway.auth.password が SecretRef 経由で明示的に設定され、未解決の場合、ノード認証解決はフェイルクローズします(リモートフォールバックによるマスキングはありません)。
  • gateway.mode=remote では、リモートクライアントフィールド(gateway.remote.token / gateway.remote.password)もリモート優先順位ルールに従って対象になります。
  • ノードホストの認証解決は OPENCLAW_GATEWAY_* 環境変数のみを尊重します。

プレーンテキストの ws:// Gateway に接続するノードでは、ループバック、プライベート IP リテラル、.local、Tailnet *.ts.net ホストが受け入れられます。その他の信頼済み private-DNS 名では、OPENCLAW_ALLOW_INSECURE_PRIVATE_WS=1 を設定します。これがない場合、ノード起動はフェイルクローズし、wss://、SSH トンネル、または Tailscale の使用を求めます。これはプロセス環境によるオプトインであり、openclaw.json 設定キーではありません。 openclaw node install は、インストールコマンド環境に存在する場合、監視対象のノードサービスへこれを永続化します。

サービス(バックグラウンド)

ヘッドレスノードホストをユーザーサービスとしてインストールします。

bash
openclaw node install --host <gateway-host> --port 18789

オプション:

  • --host <host>: Gateway WebSocket ホスト(デフォルト: 127.0.0.1
  • --port <port>: Gateway WebSocket ポート(デフォルト: 18789
  • --context-path <path>: Gateway WebSocket コンテキストパス(例: /openclaw-gw)。WebSocket URL に追加されます。
  • --tls: Gateway 接続に TLS を使用する
  • --tls-fingerprint <sha256>: 期待される TLS 証明書フィンガープリント(sha256)
  • --node-id <id>: ノード ID を上書きする(ペアリングトークンをクリア)
  • --display-name <name>: ノードの表示名を上書きする
  • --runtime <runtime>: サービスランタイム(node または bun
  • --force: すでにインストール済みの場合に再インストール/上書きする

サービスを管理します:

bash
openclaw node statusopenclaw node startopenclaw node stopopenclaw node restartopenclaw node uninstall

フォアグラウンドのノードホストには openclaw node run を使用します(サービスなし)。

サービスコマンドは、機械可読出力のために --json を受け付けます。

ノードホストは Gateway の再起動とネットワーク切断をプロセス内で再試行します。Gateway が終端的なトークン/パスワード/bootstrap 認証一時停止を報告した場合、ノードホストはクローズ詳細をログに記録し、非ゼロで終了するため、launchd/systemd は新しい設定と認証情報で再起動できます。ペアリング必須の一時停止はフォアグラウンドフローに留まり、保留中のリクエストを承認できるようにします。

ペアリング

最初の接続では、Gateway 上に保留中のデバイスペアリングリクエスト(role: node)が作成されます。 次で承認します:

bash
openclaw devices listopenclaw devices approve <requestId>

厳格に制御されたノードネットワークでは、Gateway オペレーターが信頼済み CIDR からの初回ノードペアリングの自動承認を明示的にオプトインできます:

json5
{  gateway: {    nodes: {      pairing: {        autoApproveCidrs: ["192.168.1.0/24"],      },    },  },}

これはデフォルトで無効です。リクエストされたスコープがない新規の role: node ペアリングにのみ適用されます。オペレーター/ブラウザクライアント、Control UI、WebChat、およびロール、スコープ、メタデータ、公開鍵のアップグレードには、引き続き手動承認が必要です。

ノードが変更された認証詳細(ロール/スコープ/公開鍵)でペアリングを再試行すると、以前の保留中リクエストは置き換えられ、新しい requestId が作成されます。 承認前に openclaw devices list を再度実行してください。

ノードホストは、ノード ID、トークン、表示名、Gateway 接続情報を ~/.openclaw/node.json に保存します。

exec 承認

system.run はローカル exec 承認でゲートされます:

  • $OPENCLAW_STATE_DIR/exec-approvals.json、または 変数が未設定の場合は ~/.openclaw/exec-approvals.json
  • exec 承認
  • openclaw approvals --node <id|name|ip>(Gateway から編集)

承認済みの非同期ノード exec では、OpenClaw はプロンプトを出す前に正規の systemRunPlan を準備します。後で承認済みの system.run 転送は、その保存済みプランを再利用するため、承認リクエスト作成後に command/cwd/session フィールドを編集しても、ノードが実行する内容を変更する代わりに拒否されます。

関連

Was this useful?
On this page

On this page