openclaw-memory-alibaba-mysql 0.2.0 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +37 -51
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -1,33 +1,36 @@
|
|
|
1
|
-
#
|
|
1
|
+
# openclaw-memory-alibaba-mysql
|
|
2
2
|
|
|
3
|
-
OpenClaw 记忆插件,使用阿里云 RDS MySQL
|
|
3
|
+
OpenClaw 记忆插件,使用阿里云 RDS MySQL 做向量存储。支持用户记忆、全文对话记录、自进化记忆;可与 OpenClaw 的 before_agent_start / agent_end 配合,自动召回与自动落库。
|
|
4
4
|
|
|
5
|
-
##
|
|
5
|
+
## 功能概览
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
- **用户记忆**:从对话中自动抽取事实、偏好、决策(如「喜欢寿司」「打算用 Python」),支持按向量检索并注入到每轮上下文。
|
|
8
|
+
- **全文记忆**:按消息来源分为用户、助手、系统、工具等 6 类,每类按会话保留一份,每轮更新;只存真实对话内容,不存系统注入的上下文块。
|
|
9
|
+
- **自进化记忆**:从对话中抽取学习要点、错误、需求等,可选参与召回。
|
|
10
|
+
- **冲突与去重**:可选用 LLM 判断新记忆与已有记忆是否矛盾或重复,避免重复、矛盾条目堆积。
|
|
11
|
+
- **时间衰减**:召回时可对旧记忆降权,让近期信息更突出。
|
|
12
|
+
- **工具**:提供 `memory_recall`(按查询搜记忆)、`memory_store`(显式写入)、`memory_forget`(删除);若只依赖自动召回与自动抓取,可不给 agent 开放 recall/store,仅保留 forget 用于删除。
|
|
12
13
|
|
|
13
|
-
|
|
14
|
-
- **memory_store 工具**:可显式指定 `category`,默认 `user_memory_fact`。
|
|
15
|
-
- **召回**:`before_agent_start` 与 `memory_recall` 统一按向量检索用户记忆(及可选 self_improving),注入上下文。
|
|
14
|
+
## 记忆分类
|
|
16
15
|
|
|
17
|
-
|
|
16
|
+
| 类型 | 说明 |
|
|
17
|
+
|------|------|
|
|
18
|
+
| 用户事实 / 偏好 / 决策 | 从用户话里抽取的事实、喜好、决定,用于后续对话的上下文 |
|
|
19
|
+
| 全文·用户 / 助手 / 系统 / 工具 / 工具结果 / 其它 | 按消息角色分的完整对话记录,按会话维护、每轮更新 |
|
|
20
|
+
| 自进化(学习 / 错误 / 需求) | 从对话中抽取的可复用经验,可选参与召回 |
|
|
18
21
|
|
|
19
22
|
## 配置示例
|
|
20
23
|
|
|
21
|
-
###
|
|
24
|
+
### 最简配置
|
|
22
25
|
|
|
23
|
-
|
|
26
|
+
只接 MySQL 和向量服务,其余用默认(自动召回 + 自动抓取用户记忆,不开启全文与自进化):
|
|
24
27
|
|
|
25
28
|
```json
|
|
26
29
|
{
|
|
27
30
|
"plugins": {
|
|
28
|
-
"slots": { "memory": "
|
|
31
|
+
"slots": { "memory": "openclaw-memory-alibaba-mysql" },
|
|
29
32
|
"entries": {
|
|
30
|
-
"
|
|
33
|
+
"openclaw-memory-alibaba-mysql": {
|
|
31
34
|
"enabled": true,
|
|
32
35
|
"config": {
|
|
33
36
|
"mysql": {
|
|
@@ -50,16 +53,16 @@ OpenClaw 记忆插件,使用阿里云 RDS MySQL 向量存储。用户记忆细
|
|
|
50
53
|
}
|
|
51
54
|
```
|
|
52
55
|
|
|
53
|
-
###
|
|
56
|
+
### 功能全开
|
|
54
57
|
|
|
55
|
-
|
|
58
|
+
开启全文记忆、自进化、LLM 抽取与冲突处理、时间衰减等:
|
|
56
59
|
|
|
57
60
|
```json
|
|
58
61
|
{
|
|
59
62
|
"plugins": {
|
|
60
|
-
"slots": { "memory": "
|
|
63
|
+
"slots": { "memory": "openclaw-memory-alibaba-mysql" },
|
|
61
64
|
"entries": {
|
|
62
|
-
"
|
|
65
|
+
"openclaw-memory-alibaba-mysql": {
|
|
63
66
|
"enabled": true,
|
|
64
67
|
"config": {
|
|
65
68
|
"mysql": {
|
|
@@ -89,7 +92,7 @@ OpenClaw 记忆插件,使用阿里云 RDS MySQL 向量存储。用户记忆细
|
|
|
89
92
|
"memoryExtractionMethod": "llm",
|
|
90
93
|
"autoRecall": true,
|
|
91
94
|
"autoCapture": true,
|
|
92
|
-
"captureMaxChars":
|
|
95
|
+
"captureMaxChars": 5000,
|
|
93
96
|
"enableMemoryDecay": true,
|
|
94
97
|
"tableName": "openclaw_memories"
|
|
95
98
|
}
|
|
@@ -99,38 +102,21 @@ OpenClaw 记忆插件,使用阿里云 RDS MySQL 向量存储。用户记忆细
|
|
|
99
102
|
}
|
|
100
103
|
```
|
|
101
104
|
|
|
102
|
-
|
|
105
|
+
**常用配置说明**
|
|
103
106
|
|
|
104
|
-
-
|
|
105
|
-
- **
|
|
106
|
-
- **
|
|
107
|
-
- **
|
|
108
|
-
- **
|
|
109
|
-
|
|
110
|
-
|
|
107
|
+
- **mysql** / **embedding**:必填,用于连接数据库与生成向量。
|
|
108
|
+
- **llm**:使用「LLM 抽取」或「冲突/去重」时必填。
|
|
109
|
+
- **memoryExtractionMethod**:`"llm"`(默认)或 `"regex"`,控制如何从对话里抽取用户记忆与自改进记忆。
|
|
110
|
+
- **enableFullContextMemory**:是否按角色保存全文对话(每会话每类一份,每轮更新)。
|
|
111
|
+
- **enableSelfImprovingMemory**:是否启用自进化记忆的写入与召回。
|
|
112
|
+
- **memory_duplication_conflict_process**:是否用 LLM 做写入前的去重与矛盾判断。
|
|
113
|
+
- **captureMaxChars**:单条记忆与全文截断的最大字符数,建议 5000 以保留完整当轮对话。
|
|
114
|
+
- **enableMemoryDecay**:召回时是否对旧记忆做时间衰减(近期记忆权重更高)。
|
|
115
|
+
- **tableName**:存储表名,默认 `openclaw_memories`。
|
|
111
116
|
|
|
112
117
|
## 环境变量
|
|
113
118
|
|
|
114
|
-
|
|
115
|
-
- `DASHSCOPE_API_KEY`:DashScope 用于 embedding(若 apiKey 使用 `${DASHSCOPE_API_KEY}`)。
|
|
116
|
-
|
|
117
|
-
---
|
|
118
|
-
|
|
119
|
-
## 测试
|
|
120
|
-
|
|
121
|
-
```bash
|
|
122
|
-
export MYSQL_HOST=your-host MYSQL_PASSWORD=xxx DASHSCOPE_API_KEY=xxx
|
|
123
|
-
npx tsx test-agent-isolation.ts
|
|
124
|
-
npx tsx test-three-memory-types.ts
|
|
125
|
-
npx tsx test-full-context-memory.ts
|
|
126
|
-
```
|
|
127
|
-
|
|
128
|
-
---
|
|
129
|
-
|
|
130
|
-
## 文件说明
|
|
119
|
+
配置中可使用占位符引用环境变量,例如 `${MYSQL_PASSWORD}`、`${DASHSCOPE_API_KEY}`。常见需要准备的有:
|
|
131
120
|
|
|
132
|
-
-
|
|
133
|
-
-
|
|
134
|
-
- `db.ts`:MemoryDB 建表、store、search、softDelete(向量 COSINE)。
|
|
135
|
-
- `index.ts`:插件注册、memory_recall / memory_store / memory_forget、before_agent_start / agent_end。
|
|
136
|
-
- `prompts.ts`:用户记忆与 self_improving 的 LLM 抽取 Prompt。
|
|
121
|
+
- **MYSQL_HOST**, **MYSQL_USER**, **MYSQL_PASSWORD**:MySQL 连接信息。
|
|
122
|
+
- **DASHSCOPE_API_KEY**:DashScope API Key,用于 embedding(以及 LLM 若使用 DashScope)。
|