mem0: add alembic migration Job, PVC, update APP_DB_NAME to mem0

This commit is contained in:
hermes-bot
2026-05-31 03:35:49 +00:00
parent 7f2a609914
commit 2ea8964b7c

View File

@@ -32,6 +32,7 @@ ccr.ccs.tencentyun.com/tei_agent/mem0:latest
| AUTH_DISABLED | false | 启用认证 | | AUTH_DISABLED | false | 启用认证 |
| MEM0_TELEMETRY | false | 关闭遥测 | | MEM0_TELEMETRY | false | 关闭遥测 |
| REQUEST_LOG_RETENTION_DAYS | 30 | 日志保留天数 | | REQUEST_LOG_RETENTION_DAYS | 30 | 日志保留天数 |
| HISTORY_DB_PATH | /app/data/mem0_history.db | SQLite 历史数据库路径 |
### Secret (mem0-secrets) ### Secret (mem0-secrets)
@@ -41,103 +42,67 @@ ccr.ccs.tencentyun.com/tei_agent/mem0:latest
| ADMIN_API_KEY | 管理后台 API key | | ADMIN_API_KEY | 管理后台 API key |
| POSTGRES_PASSWORD | PostgreSQL 密码 | | POSTGRES_PASSWORD | PostgreSQL 密码 |
## 部署清单 ## 数据库迁移 (Alembic)
mem0 server 使用 Alembic 管理 PostgreSQL schema。**首次部署前必须先执行迁移**,创建 `request_logs` 等表。
### 迁移 Job
```yaml ```yaml
apiVersion: v1 apiVersion: batch/v1
kind: ConfigMap kind: Job
metadata: metadata:
name: mem0-env name: mem0-migrate
namespace: tei
data:
| APP_DB_NAME | mem0 | 数据库名 |
QDRANT_HOST: "qdrant"
QDRANT_PORT: "6333"
QDRANT_COLLECTION_NAME: "mem0"
EMBEDDER_PROVIDER: "tei"
TEI_ENDPOINT: "http://tei:8080"
LLM_PROVIDER: "openai"
OPENAI_API_KEY: "YOUR_MINIMAX_KEY"
OPENAI_BASE_URL: "https://api.minimax.chat/v1"
AUTH_DISABLED: "false"
MEM0_TELEMETRY: "false"
REQUEST_LOG_RETENTION_DAYS: "30"
---
apiVersion: v1
kind: Secret
metadata:
name: mem0-secrets
namespace: tei
type: Opaque
stringData:
JWT_SECRET: "your-jwt-secret-change-me"
ADMIN_API_KEY: "your-admin-key-change-me"
POSTGRES_PASSWORD: "gitlab"
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: mem0
namespace: tei namespace: tei
spec: spec:
replicas: 1 ttlSecondsAfterFinished: 300 # 完成后5分钟自动清理
selector:
matchLabels:
app: mem0
template: template:
metadata:
labels:
app: mem0
spec: spec:
restartPolicy: OnFailure
containers: containers:
- name: mem0 - name: alembic
image: ccr.ccs.tencentyun.com/tei_agent/mem0:latest image: ccr.ccs.tencentyun.com/tei_agent/mem0:latest
ports: command: ["alembic", "upgrade", "head"]
- containerPort: 8000
name: http
envFrom: envFrom:
- configMapRef: - configMapRef:
name: mem0-env name: mem0-env
- secretRef: - secretRef:
name: mem0-secrets name: mem0-secrets
livenessProbe:
httpGet:
path: /health
port: 8000
initialDelaySeconds: 30
periodSeconds: 10
readinessProbe:
httpGet:
path: /health
port: 8000
initialDelaySeconds: 10
periodSeconds: 5
resources: resources:
limits: limits:
cpu: "2" memory: "512Mi"
memory: "4Gi"
requests:
cpu: "500m" cpu: "500m"
memory: "1Gi"
---
apiVersion: v1
kind: Service
metadata:
name: mem0
namespace: tei
spec:
ports:
- port: 8000
name: http
selector:
app: mem0
``` ```
## History PVCSQLite 持久化) ### 迁移部署步骤
mem0 的对话历史history默认存在 SQLite**必须用 PVC 持久化**emptyDir 重启丢失)。 ```bash
# 1. 先跑迁移(只执行一次)
kubectl apply -f mem0-migrate-job.yaml
### 前置:创建 PVC # 2. 确认迁移完成
kubectl get job mem0-migrate -n tei -w
# 3. 确认成功后再部署 mem0
kubectl apply -f mem0-deployment.yaml
# 4. 如果迁移失败,查看原因
kubectl logs job/mem0-migrate -n tei
```
**重要**:迁移 Job 只跑一次。Pod 重启时不需要重新迁移PostgreSQL schema 不会天天变。
## 前置要求
1. **pgvector 扩展** — PostgreSQL 需要安装 pgvector
2. **mem0 数据库** — 需要提前创建
3. **mem0-migrate Job** — 首次部署前必须先执行迁移
4. **mem0-history PVC** — 必须提前创建
5. **Qdrant collection** — mem0 启动时自动创建(首次调用时)
## 部署清单
### PVC + ConfigMap + Secret + Deployment + Service
```yaml ```yaml
apiVersion: v1 apiVersion: v1
@@ -152,29 +117,6 @@ spec:
requests: requests:
storage: 1Gi storage: 1Gi
storageClassName: standard # 根据你的 StorageClass 调整 storageClassName: standard # 根据你的 StorageClass 调整
```
### 环境变量追加
| 变量 | 值 | 说明 |
|---|---|---|
| HISTORY_DB_PATH | /app/data/mem0_history.db | SQLite 数据库路径 |
### PVC + 完整 Deployment
```yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: mem0-history
namespace: tei
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1Gi
storageClassName: standard
--- ---
apiVersion: v1 apiVersion: v1
kind: ConfigMap kind: ConfigMap
@@ -182,7 +124,7 @@ metadata:
name: mem0-env name: mem0-env
namespace: tei namespace: tei
data: data:
| APP_DB_NAME | mem0 | 数据库名 | APP_DB_NAME: "mem0"
QDRANT_HOST: "qdrant" QDRANT_HOST: "qdrant"
QDRANT_PORT: "6333" QDRANT_PORT: "6333"
QDRANT_COLLECTION_NAME: "mem0" QDRANT_COLLECTION_NAME: "mem0"
@@ -273,20 +215,31 @@ spec:
app: mem0 app: mem0
``` ```
## 前置要求
1. **pgvector 扩展** — PostgreSQL 需要安装 pgvector
2. **mem0 数据库** — 需要提前创建
3. **Qdrant collection** — mem0 启动时自动创建(首次调用时)
4. **mem0-history PVC** — 必须提前创建
## 验证 ## 验证
```bash ```bash
# 检查 PVC
kubectl get pvc -n tei mem0-history kubectl get pvc -n tei mem0-history
# 检查 Pod
kubectl get pods -n tei -l app=mem0 kubectl get pods -n tei -l app=mem0
# 查看日志
kubectl logs -n tei -l app=mem0 --tail=50 kubectl logs -n tei -l app=mem0 --tail=50
# 健康检查 # 健康检查
curl http://mem0:8000/health curl http://mem0:8000/health
``` ```
## History SQLite 说明
mem0 的对话历史存储在 SQLite位于 `/app/data/mem0_history.db`。**必须用 PVC 持久化**emptyDir 挂载重启后数据丢失。
如果 PVC 空间不足或不需要历史功能,可以改用空目录(数据丢失但不影响核心记忆功能):
```yaml
# 测试/轻量级环境用 emptyDir
volumes:
- name: mem0-history
emptyDir: {}
```