エージェントのワークスペース
ワークスペースはエージェントのホームです。これは、ファイルツールとワークスペースコンテキストで使用される唯一の作業ディレクトリです。 これを非公開に保ち、メモリとして扱ってください。 これは、設定、認証情報、セッションを保存する~/.openclaw/ とは別です。
重要: ワークスペースはデフォルトの cwdであり、厳格なサンドボックスではありません。ツールはワークスペースを基準に相対パスを解決しますが、サンドボックス化が有効でない限り、絶対パスは引き続きホスト上の別の場所へ到達できます。分離が必要な場合は、agents.defaults.sandbox(および/またはエージェントごとのサンドボックス設定)を使用してください。サンドボックス化が有効で、workspaceAccess が "rw" ではない場合、ツールはホストのワークスペースではなく、~/.openclaw/sandboxes 配下のサンドボックスワークスペース内で動作します。
デフォルトの保存場所
- デフォルト:
~/.openclaw/workspace OPENCLAW_PROFILEが設定されていて"default"ではない場合、デフォルトは~/.openclaw/workspace-<profile>になります。~/.openclaw/openclaw.jsonで上書きします:
openclaw onboard、openclaw configure、または openclaw setup は、ワークスペースが存在しない場合にそれを作成し、ブートストラップファイルを初期投入します。
サンドボックスのシードコピーは、ワークスペース内の通常ファイルのみを受け入れます。ソースワークスペースの外部を指す symlink/hardlink のエイリアスは無視されます。
すでにワークスペースファイルを自分で管理している場合は、ブートストラップファイルの作成を無効にできます:
追加のワークスペースフォルダー
古いインストールでは~/openclaw が作成されていることがあります。複数のワークスペースディレクトリを残しておくと、同時に有効なのは1つのワークスペースだけなので、認証や状態の食い違いによって混乱を招くことがあります。
推奨: 有効なワークスペースは1つだけにしてください。追加フォルダーをもう使わない場合は、アーカイブするかゴミ箱へ移動してください(例: trash ~/openclaw)。意図的に複数のワークスペースを保持する場合は、agents.defaults.workspace が有効なものを指していることを確認してください。
openclaw doctor は、追加のワークスペースディレクトリを検出すると警告します。
ワークスペースのファイルマップ(各ファイルの意味)
これらは、OpenClaw がワークスペース内にあることを想定している標準ファイルです:-
AGENTS.md- エージェント向けの運用指示と、メモリの使い方。
- 毎セッションの開始時に読み込まれます。
- ルール、優先順位、「どう振る舞うか」の詳細を書くのに適しています。
-
SOUL.md- ペルソナ、トーン、境界。
- 毎セッションで読み込まれます。
- ガイド: SOUL.md Personality Guide
-
USER.md- ユーザーが誰か、どう呼びかけるか。
- 毎セッションで読み込まれます。
-
IDENTITY.md- エージェントの名前、雰囲気、絵文字。
- ブートストラップ儀式の間に作成または更新されます。
-
TOOLS.md- ローカルツールと慣習に関するメモ。
- ツールの利用可否を制御するものではなく、あくまでガイダンスです。
-
HEARTBEAT.md- Heartbeat 実行用の任意の小さなチェックリスト。
- トークン消費を避けるため、短く保ってください。
-
BOOT.md- 内部フックが有効なとき、Gateway 再起動時に実行される任意の起動チェックリスト。
- 短く保ち、外向き送信には message ツールを使用してください。
-
BOOTSTRAP.md- 初回実行時だけの儀式。
- 新規ワークスペースに対してのみ作成されます。
- 儀式が完了したら削除してください。
-
memory/YYYY-MM-DD.md- 日次メモリログ(1日1ファイル)。
- セッション開始時に今日と昨日のファイルを読むことを推奨します。
-
MEMORY.md(任意)- キュレーションされた長期メモリ。
- メインの非公開セッションでのみ読み込んでください(共有/グループコンテキストではありません)。
-
skills/(任意)- ワークスペース固有の Skills。
- そのワークスペースにおける最優先の Skills 保存場所です。
- 名前が衝突した場合、プロジェクトのエージェント Skills、個人用エージェント Skills、管理された Skills、同梱 Skills、および
skills.load.extraDirsより優先されます。
-
canvas/(任意)- Node 表示用の Canvas UI ファイル(例:
canvas/index.html)。
- Node 表示用の Canvas UI ファイル(例:
agents.defaults.bootstrapMaxChars(デフォルト: 12000)と agents.defaults.bootstrapTotalMaxChars(デフォルト: 60000)で調整してください。
openclaw setup は、既存ファイルを上書きせずに不足しているデフォルトを再作成できます。
ワークスペースに含まれないもの
以下は~/.openclaw/ 配下にあり、ワークスペースのリポジトリにコミットすべきではありません:
~/.openclaw/openclaw.json(設定)~/.openclaw/agents/<agentId>/agent/auth-profiles.json(モデル認証プロファイル: OAuth + API keys)~/.openclaw/credentials/(チャネル/プロバイダーの状態と旧OAuthインポートデータ)~/.openclaw/agents/<agentId>/sessions/(セッショントランスクリプト + メタデータ)~/.openclaw/skills/(管理された Skills)
Git バックアップ(推奨、非公開)
ワークスペースは非公開のメモリとして扱ってください。バックアップと復旧ができるよう、非公開の git リポジトリに置いてください。 これらの手順は Gateway が動作しているマシン上で実行してください(ワークスペースはそこにあります)。1) リポジトリを初期化する
git がインストールされている場合、まったく新しいワークスペースは自動的に初期化されます。このワークスペースがまだリポジトリでない場合は、次を実行してください:2) 非公開リモートを追加する(初心者向けオプション)
オプションA: GitHub web UI- GitHub で新しい非公開リポジトリを作成します。
- README で初期化しないでください(マージ競合を避けるため)。
- HTTPS リモートURLをコピーします。
- リモートを追加して push します:
gh)
- GitLab で新しい非公開リポジトリを作成します。
- README で初期化しないでください(マージ競合を避けるため)。
- HTTPS リモートURLをコピーします。
- リモートを追加して push します:
3) 継続的な更新
シークレットをコミットしないでください
非公開リポジトリであっても、ワークスペースにシークレットを保存するのは避けてください:- API keys、OAuth tokens、passwords、または private credentials。
~/.openclaw/配下のものすべて。- チャットや機密添付ファイルの生ダンプ。
~/.openclaw/)。
推奨される .gitignore の初期例:
ワークスペースを新しいマシンへ移す
- 希望するパス(デフォルトは
~/.openclaw/workspace)にリポジトリを clone します。 ~/.openclaw/openclaw.jsonでagents.defaults.workspaceをそのパスに設定します。openclaw setup --workspace <path>を実行して、不足しているファイルを初期投入します。- セッションが必要な場合は、古いマシンから
~/.openclaw/agents/<agentId>/sessions/を別途コピーしてください。
補足
- マルチエージェントのルーティングでは、エージェントごとに異なるワークスペースを使えます。ルーティング設定については Channel routing を参照してください。
agents.defaults.sandboxが有効な場合、非メインセッションではagents.defaults.sandbox.workspaceRoot配下のセッションごとのサンドボックスワークスペースを使用できます。
関連
- Standing Orders — ワークスペースファイル内の永続的な指示
- Heartbeat — HEARTBEAT.md ワークスペースファイル
- Session — セッション保存パス
- Sandboxing — サンドボックス環境におけるワークスペースアクセス