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.
memory-lancedb là một Plugin bộ nhớ đi kèm, lưu trữ bộ nhớ dài hạn trong
LanceDB và dùng embeddings để truy hồi. Nó có thể tự động truy hồi các bộ nhớ
liên quan trước một lượt mô hình và ghi lại các sự kiện quan trọng sau một phản hồi.
Dùng Plugin này khi bạn muốn có một cơ sở dữ liệu vector cục bộ cho bộ nhớ, cần một
điểm cuối embedding tương thích OpenAI, hoặc muốn giữ cơ sở dữ liệu bộ nhớ bên ngoài
kho bộ nhớ tích hợp mặc định.
memory-lancedb là một Plugin Active Memory. Bật nó bằng cách chọn slot bộ nhớ
với plugins.slots.memory = "memory-lancedb". Các Plugin đồng hành như
memory-wiki có thể chạy cùng nó, nhưng chỉ một Plugin sở hữu slot bộ nhớ đang hoạt động.Bắt đầu nhanh
Embeddings dựa trên nhà cung cấp
memory-lancedb có thể dùng cùng các adapter nhà cung cấp embedding bộ nhớ như
memory-core. Đặt embedding.provider và bỏ qua embedding.apiKey để dùng
hồ sơ xác thực đã cấu hình của nhà cung cấp, biến môi trường, hoặc
models.providers.<provider>.apiKey.
openai-codex) không phải là thông tin xác thực
embeddings của OpenAI Platform. Với embeddings OpenAI, hãy dùng hồ sơ xác thực khóa OpenAI API,
OPENAI_API_KEY, hoặc models.providers.openai.apiKey. Người dùng chỉ có OAuth có thể dùng
một nhà cung cấp có khả năng embedding khác như GitHub Copilot hoặc Ollama.
Embeddings Ollama
Với embeddings Ollama, nên dùng nhà cung cấp embedding Ollama đi kèm. Nó dùng điểm cuối Ollama/api/embed gốc và tuân theo cùng các quy tắc xác thực/base URL như
nhà cung cấp Ollama được ghi trong Ollama.
dimensions cho các mô hình embedding không chuẩn. OpenClaw biết
số chiều của text-embedding-3-small và text-embedding-3-large; các mô hình tùy chỉnh
cần giá trị này trong cấu hình để LanceDB có thể tạo cột vector.
Với các mô hình embedding cục bộ nhỏ, hãy giảm recallMaxChars nếu bạn thấy lỗi
độ dài ngữ cảnh từ máy chủ cục bộ.
Nhà cung cấp tương thích OpenAI
Một số nhà cung cấp embedding tương thích OpenAI từ chối tham sốencoding_format,
trong khi các nhà cung cấp khác bỏ qua tham số này và luôn trả về vector number[].
Do đó memory-lancedb bỏ qua encoding_format trong các yêu cầu embedding và
chấp nhận phản hồi dạng mảng số thực hoặc phản hồi float32 được mã hóa base64.
Nếu bạn có một điểm cuối embeddings tương thích OpenAI thô không có
adapter nhà cung cấp đi kèm, hãy bỏ qua embedding.provider (hoặc để là openai) và
đặt embedding.apiKey cùng embedding.baseUrl. Cách này giữ đường dẫn client
tương thích OpenAI trực tiếp.
Đặt embedding.dimensions cho các nhà cung cấp có số chiều mô hình không được tích hợp sẵn.
Ví dụ, ZhiPu embedding-3 dùng 2048 chiều:
Giới hạn truy hồi và ghi lại
memory-lancedb có hai giới hạn văn bản riêng biệt:
| Cài đặt | Mặc định | Phạm vi | Áp dụng cho |
|---|---|---|---|
recallMaxChars | 1000 | 100-10000 | văn bản gửi đến API embedding để truy hồi |
captureMaxChars | 500 | 100-10000 | độ dài tin nhắn assistant đủ điều kiện để ghi lại |
recallMaxChars kiểm soát tự động truy hồi, công cụ memory_recall, đường dẫn truy vấn
memory_forget, và openclaw ltm search. Tự động truy hồi ưu tiên
tin nhắn người dùng mới nhất trong lượt và chỉ dùng toàn bộ prompt làm dự phòng khi không có
tin nhắn người dùng. Cách này giữ metadata kênh và các khối prompt lớn
khỏi yêu cầu embedding.
captureMaxChars kiểm soát liệu phản hồi có đủ ngắn để được xem xét
ghi lại tự động hay không. Nó không giới hạn embeddings truy vấn truy hồi.
Lệnh
Khimemory-lancedb là Plugin bộ nhớ đang hoạt động, nó đăng ký namespace CLI ltm:
openclaw memory bằng tiểu lệnh query không dùng vector
chạy trực tiếp trên bảng LanceDB:
--cols <columns>: danh sách cho phép các cột, phân tách bằng dấu phẩy (mặc định làid,text,importance,category,createdAt).--filter <condition>: mệnh đề WHERE kiểu SQL; giới hạn ở 200 ký tự và chỉ cho phép chữ số/chữ cái, toán tử so sánh, dấu ngoặc kép/đơn, ngoặc đơn, và một tập nhỏ dấu câu an toàn.--limit <n>: số nguyên dương; mặc định là10.--order-by <column>:<asc|desc>: sắp xếp trong bộ nhớ được áp dụng sau bộ lọc; cột sắp xếp tự động được đưa vào phép chiếu.
memory_recallđể truy hồi dựa trên LanceDBmemory_stoređể lưu các sự kiện quan trọng, tùy chọn, quyết định, và thực thểmemory_forgetđể xóa các bộ nhớ khớp
Lưu trữ
Theo mặc định, dữ liệu LanceDB nằm trong~/.openclaw/memory/lancedb. Ghi đè
đường dẫn bằng dbPath:
storageOptions chấp nhận các cặp khóa/giá trị dạng chuỗi cho backend lưu trữ LanceDB và
hỗ trợ mở rộng ${ENV_VAR}:
Phụ thuộc runtime
memory-lancedb phụ thuộc vào gói gốc @lancedb/lancedb. Các bản cài đặt
OpenClaw đóng gói trước tiên thử phụ thuộc runtime đi kèm và có thể sửa
phụ thuộc runtime của Plugin trong trạng thái OpenClaw khi import đi kèm không
khả dụng.
Nếu một bản cài đặt cũ ghi log lỗi thiếu dist/package.json hoặc thiếu
@lancedb/lancedb trong lúc tải Plugin, hãy nâng cấp OpenClaw và khởi động lại
Gateway.
Nếu Plugin ghi log rằng LanceDB không khả dụng trên darwin-x64, hãy dùng backend
bộ nhớ mặc định trên máy đó, chuyển Gateway sang nền tảng được hỗ trợ, hoặc
tắt memory-lancedb.
Khắc phục sự cố
Độ dài đầu vào vượt quá độ dài ngữ cảnh
Điều này thường có nghĩa là mô hình embedding đã từ chối truy vấn truy hồi:recallMaxChars thấp hơn, sau đó khởi động lại Gateway:
Mô hình embedding không được hỗ trợ
Nếu không códimensions, chỉ các số chiều embedding OpenAI tích hợp sẵn mới được biết.
Với các mô hình embedding cục bộ hoặc tùy chỉnh, hãy đặt embedding.dimensions thành kích thước vector
do mô hình đó báo cáo.
Plugin tải nhưng không có bộ nhớ nào xuất hiện
Kiểm tra rằngplugins.slots.memory trỏ đến memory-lancedb, sau đó chạy:
autoCapture bị tắt, Plugin sẽ truy hồi các bộ nhớ hiện có nhưng sẽ
không tự động lưu các bộ nhớ mới. Dùng công cụ memory_store hoặc bật
autoCapture nếu bạn muốn ghi lại tự động.