跳轉到主要內容

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

工作區是代理的家。它是檔案工具和工作區內容脈絡唯一使用的工作目錄。請保持私密,並將其視為記憶。 這與 ~/.openclaw/ 不同,後者用來儲存設定、憑證和工作階段。
工作區是預設 cwd,不是嚴格的沙箱。工具會以工作區解析相對路徑,但除非啟用沙箱,否則絕對路徑仍可存取主機上的其他位置。如果你需要隔離,請使用 agents.defaults.sandbox(以及/或個別代理沙箱設定)。啟用沙箱且 workspaceAccess 不是 "rw" 時,工具會在 ~/.openclaw/sandboxes 底下的沙箱工作區內運作,而不是你的主機工作區。

預設位置

  • 預設:~/.openclaw/workspace
  • 如果已設定 OPENCLAW_PROFILE 且不是 "default",預設會變成 ~/.openclaw/workspace-<profile>
  • ~/.openclaw/openclaw.json 中覆寫:
{
  agents: {
    defaults: {
      workspace: "~/.openclaw/workspace",
    },
  },
}
如果工作區和啟動檔案不存在,openclaw onboardopenclaw configureopenclaw setup 會建立工作區並植入啟動檔案。
沙箱種子複製只接受工作區內的一般檔案;解析到來源工作區外部的符號連結/硬連結別名會被忽略。
如果你已經自行管理工作區檔案,可以停用啟動檔案建立:
{ agents: { defaults: { skipBootstrap: true } } }

額外工作區資料夾

較舊的安裝可能建立過 ~/openclaw。保留多個工作區目錄可能造成令人困惑的驗證或狀態漂移,因為一次只有一個工作區是作用中的。
建議: 保留單一作用中工作區。如果你不再使用額外資料夾,請封存或移到垃圾桶(例如 trash ~/openclaw)。如果你刻意保留多個工作區,請確保 agents.defaults.workspace 指向作用中的那一個。openclaw doctor 偵測到額外工作區目錄時會發出警告。

工作區檔案對照表

以下是 OpenClaw 預期工作區內具備的標準檔案:
代理的操作指示,以及它應如何使用記憶。每個工作階段開始時載入。適合放置規則、優先順序和「行為方式」細節。
人格、語氣和界線。每個工作階段載入。指南:SOUL.md 人格指南
使用者是誰,以及應如何稱呼他們。每個工作階段載入。
代理的名稱、氛圍和 emoji。在啟動儀式期間建立/更新。
關於你的本機工具和慣例的註記。不控制工具可用性;它只是指引。
Heartbeat 執行用的選用小型檢查清單。保持簡短以避免消耗 token。
Gateway 重新啟動時自動執行的選用啟動檢查清單(啟用內部 hooks 時)。保持簡短;對外傳送請使用訊息工具。
一次性的首次執行儀式。只會為全新工作區建立。儀式完成後請刪除。
每日記憶記錄(每天一個檔案)。建議在工作階段開始時讀取今天與昨天。
經整理的長期記憶。只在主要的私人工作階段載入(不要在共用/群組內容脈絡中載入)。請參閱記憶了解工作流程和自動記憶清理。
工作區專屬 Skills。這是該工作區中優先順序最高的 skill 位置。名稱衝突時,會覆寫專案代理 Skills、個人代理 Skills、受管理 Skills、內建 Skills,以及 skills.load.extraDirs
節點顯示用的 Canvas UI 檔案(例如 canvas/index.html)。
如果缺少任何啟動檔案,OpenClaw 會將「缺少檔案」標記注入工作階段並繼續。大型啟動檔案在注入時會被截斷;可用 agents.defaults.bootstrapMaxChars(預設:12000)和 agents.defaults.bootstrapTotalMaxChars(預設:60000)調整限制。openclaw setup 可以重新建立缺少的預設檔案,而不覆寫既有檔案。

工作區內不包含什麼

這些位於 ~/.openclaw/ 底下,不應提交到工作區 repo:
  • ~/.openclaw/openclaw.json(設定)
  • ~/.openclaw/agents/<agentId>/agent/auth-profiles.json(模型驗證設定檔:OAuth + API 金鑰)
  • ~/.openclaw/credentials/(channel/provider 狀態,加上舊版 OAuth 匯入資料)
  • ~/.openclaw/agents/<agentId>/sessions/(工作階段逐字稿 + 中繼資料)
  • ~/.openclaw/skills/(受管理的 Skills)
如果你需要遷移工作階段或設定,請分開複製,並讓它們留在版本控制之外。

Git 備份(建議,私人)

將工作區視為私人記憶。把它放在私人 git repo 中,讓它可備份且可復原。 在 Gateway 執行所在的機器上執行以下步驟(工作區也位於該處)。
1

Initialize the repo

如果已安裝 git,全新的工作區會自動初始化。如果此工作區還不是 repo,請執行:
cd ~/.openclaw/workspace
git init
git add AGENTS.md SOUL.md TOOLS.md IDENTITY.md USER.md HEARTBEAT.md memory/
git commit -m "Add agent workspace"
2

Add a private remote

  1. 在 GitHub 上建立新的私人儲存庫。
  2. 不要用 README 初始化(避免合併衝突)。
  3. 複製 HTTPS 遠端 URL。
  4. 加入遠端並推送:
git branch -M main
git remote add origin <https-url>
git push -u origin main
3

Ongoing updates

git status
git add .
git commit -m "Update memory"
git push

不要提交秘密

即使在私人 repo 中,也請避免將秘密儲存在工作區:
  • API 金鑰、OAuth token、密碼或私人憑證。
  • ~/.openclaw/ 底下的任何內容。
  • 聊天或敏感附件的原始傾印。
如果你必須儲存敏感參照,請使用佔位符,並將真正的秘密保存在其他地方(密碼管理器、環境變數,或 ~/.openclaw/)。
建議的 .gitignore 起始內容:
.DS_Store
.env
**/*.key
**/*.pem
**/secrets*

將工作區移到新機器

1

Clone the repo

將 repo 複製到所需路徑(預設 ~/.openclaw/workspace)。
2

Update config

~/.openclaw/openclaw.json 中將 agents.defaults.workspace 設為該路徑。
3

Seed missing files

執行 openclaw setup --workspace <path> 以植入任何缺少的檔案。
4

Copy sessions (optional)

如果你需要工作階段,請從舊機器分開複製 ~/.openclaw/agents/<agentId>/sessions/

進階註記

  • 多代理路由可以為每個代理使用不同工作區。請參閱Channel 路由了解路由設定。
  • 如果啟用 agents.defaults.sandbox,非主要工作階段可使用 agents.defaults.sandbox.workspaceRoot 底下的個別工作階段沙箱工作區。

相關