openclaw-home-pc/workspace/scripts/context_memory_guard.sh

79 lines
2.5 KiB
Bash
Executable File

#!/bin/bash
# ============================================
# 上下文使用量检测 & 记忆自动保存脚本
# 当任一 session 上下文使用量 >= 90% 时自动保存记忆
# ============================================
set -e
# 加载环境变量
export SILICONFLOW_API_KEY="sk-fpjdtxbxrhtekshircjhegstloxaodriekotjdyzzktyegcl"
LOG_FILE="/tmp/openclaw/context_memory_check.log"
TIMESTAMP=$(date '+%Y-%m-%d %H:%M:%S')
log() {
echo "[$TIMESTAMP] $1" | tee -a "$LOG_FILE"
}
log "========== 上下文使用量检测 =========="
# 获取 OpenClaw 状态中的 Tokens 信息
STATUS_OUTPUT=$(openclaw status 2>&1)
# 提取所有会话的上下文使用量(排除 cached 百分比)
# 格式: "109k/200k (54%)" - 括号内的数字是上下文使用量
# cached 格式: "🗄️ 42% cached" - 这不是上下文使用量
MAX_USAGE=0
# 逐行处理
while IFS= read -r line; do
# 跳过表头和分隔符
if echo "$line" | grep -q "│.*Tokens"; then
continue
fi
if echo "$line" | grep -q "├"; then
continue
fi
if echo "$line" | grep -q "│ Key"; then
continue
fi
if echo "$line" | grep -q "FAQ:\|Troubleshooting:"; then
continue
fi
# 提取 "XXXk/YYYk (NN%)" 格式中的数字
# 格式如: 109k/200k (54%)
usage=$(echo "$line" | grep -oE '[0-9]+k/[0-9]+k \([0-9]+\)%' | grep -oE '\([0-9]+\)' | tr -d '()' || true)
if [ -n "$usage" ]; then
if [ "$usage" -gt "$MAX_USAGE" ]; then
MAX_USAGE=$usage
fi
fi
done <<< "$STATUS_OUTPUT"
log "📊 当前最高上下文使用量: ${MAX_USAGE}%"
# 检查是否达到 90% 阈值
if [ "$MAX_USAGE" -ge 90 ]; then
log "⚠️ 上下文使用量达到 ${MAX_USAGE}%,开始保存记忆..."
# 1. 保存文件记忆
MEMORY_FILE="$HOME/.openclaw/workspace/memory/$(date '+%Y-%m-%d').md"
echo -e "\n## 🔄 上下文自动保存 (${TIMESTAMP})\n\n**触发原因**: 上下文使用量达到 ${MAX_USAGE}%\n" >> "$MEMORY_FILE"
log "✅ 文件记忆已更新"
# 2. 保存向量记忆
cd ~/openclaw-memory-vector && python3 memory_cli.py add \
"【自动保存】上下文使用量达到 ${MAX_USAGE}%,系统自动保存记忆。时间: ${TIMESTAMP}" \
--tag "auto-save,context-90" 2>&1 | tail -1
log "✅ 向量记忆已保存"
log "✅ 记忆保存完成"
else
log "✅ 上下文使用量正常 (${MAX_USAGE}%),无需保存"
fi
log "========== 检测完成 ==========\n"