Skip to content

記憶搜尋

memory_search 會從您的記憶檔案中找出相關筆記,即使措辭與原文不同。其運作方式是將記憶索引成小區塊,並使用嵌入、關鍵字或兩者結合來進行搜尋。

如果您已設定 GitHub Copilot 訂閱、OpenAI、Gemini、Voyage 或 Mistral API 金鑰,記憶搜尋會自動運作。若要明確設定提供者:

{
agents: {
defaults: {
memorySearch: {
provider: "openai", // or "gemini", "local", "ollama", etc.
},
},
},
}

對於多端點設定,provider 也可以是自訂的 models.providers.<id> 項目,例如 ollama-5080,當該供應商設定 了 api: "ollama" 或其他嵌入配接器擁有者時。

對於沒有 API 金鑰的本機嵌入,請設定 provider: "local"。來源檢出 可能仍需要原生建置核准:pnpm approve-builds 然後 pnpm rebuild node-llama-cpp

部分相容 OpenAI 的嵌入端點需要非對稱標籤,例如搜尋使用 input_type: "query",而索引區塊使用 input_type: "document""passage"。 請使用 memorySearch.queryInputTypememorySearch.documentInputType 來設定這些項目;請參閱 記憶體設定參考

供應商ID需要 API 金鑰備註
Bedrockbedrock當 AWS 憑證鏈解析時自動偵測
Geminigemini支援影像/音訊索引
GitHub Copilotgithub-copilot自動偵測,使用 Copilot 訂閱
LocallocalGGUF 模型,約需下載 0.6 GB
Mistralmistral自動偵測
Ollamaollama本機,必須明確設定
OpenAIopenai自動偵測,快速
Voyagevoyage自動偵測

OpenClaw 會並行執行兩個檢索路徑並合併結果:

flowchart LR
Q["Query"] --> E["Embedding"]
Q --> T["Tokenize"]
E --> VS["Vector Search"]
T --> BM["BM25 Search"]
VS --> M["Weighted Merge"]
BM --> M
M --> R["Top Results"]
  • 向量搜尋 尋找含義相似的筆記(「gateway host」會符合 「the machine running OpenClaw」)。
  • BM25 關鍵字搜尋 尋找完全相符的項目(ID、錯誤字串、設定 鍵)。

如果只有一條路徑可用(沒有嵌入或沒有 FTS),另一條路徑會單獨執行。

當嵌入無法使用時,OpenClaw 仍會對 FTS 結果使用詞彙排序,而不是僅回退到原始的完全相符順序。這種降級模式會提升具有較強查詢詞涵蓋率和相關檔案路徑的區塊,即使沒有 sqlite-vec 或嵌入供應商,也能保持召回率的實用性。

當您有大量的筆記歷史記錄時,有兩個可選功能可以提供幫助:

舊筆記會逐漸降低排名權重,因此近期資訊會優先顯示。使用預設的 30 天半衰期,上個月的筆記分數為其原始權重的 50%。像 MEMORY.md 這樣的常青檔案永遠不會衰減。

減少重複結果。如果五則筆記都提及相同的路由器設定,MMR 會確保頂部結果涵蓋不同主題,而不是重複出現。

{
agents: {
defaults: {
memorySearch: {
query: {
hybrid: {
mmr: { enabled: true },
temporalDecay: { enabled: true },
},
},
},
},
},
}

使用 Gemini Embedding 2,您可以將圖片和音訊檔案與 Markdown 一起建立索引。搜尋查詢保持為文字,但它們會與視覺和音訊內容進行比對。請參閱 記憶體設定參考 了解設定方式。

您可以選擇性地將會話逐字稿建立索引,以便 memory_search 能夠回憶先前的對話。這是透過 memorySearch.experimental.sessionMemory 啟用的。詳情請參閱 設定參考

沒有結果? 執行 openclaw memory status 以檢查索引。如果是空的,請執行 openclaw memory index --force

只有關鍵字相符? 您的嵌入供應商可能尚未設定。請檢查 openclaw memory status --deep

本機嵌入逾時? ollamalmstudiolocal 預設使用較長的內聯批次逾時時間。如果主機只是速度較慢,請設定 agents.defaults.memorySearch.sync.embeddingBatchTimeoutSeconds 並重新執行 openclaw memory index --force

找不到 CJK 文字? 使用 openclaw memory index --force 重建 FTS 索引。