novel-doomsday-resurgence/inkos_monitor.sh
唐天洛 5dc8c00de0 feat(sync): 固化小说内容到Git仓库
📚 小说内容:
- 《末日重生-开局囤货十亿物资》33章
- 完整的状态文件、记忆索引、钩子系统

🛠️ 系统配置:
- 版本控制管理系统
- 自动化脚本系统
- 质量监控系统

🧠 固化记忆:
- 长期记忆文件
- 系统配置文档
- 恢复流程指南

💾 数据安全:
- 本地备份系统
- Git版本控制
- 远程同步机制

同步时间: 2026-03-30 16:25:35
系统状态: inkos正常运行中 (PID: 1433309)
创作进度: 第33章《油粮》创作中
2026-03-30 16:25:35 +08:00

200 lines
5.5 KiB
Bash
Executable File

#!/bin/bash
# inkos 监控脚本
# 功能:监控 inkos 守护进程状态,每小时检查工作进度
# 如果进程停止,根据问题修复后重启
LOG_FILE="/tmp/inkos-monitor-$(date +%Y%m%d).log"
PROJECT_DIR="/root/.openclaw/workspace/tomato-novel"
DAEMON_PID_FILE="/tmp/inkos-daemon.pid"
# 记录日志
log() {
echo "[$(date '+%Y-%m-%d %H:%M:%S')] $1" | tee -a "$LOG_FILE"
}
# 检查 inkos 守护进程是否运行
check_daemon() {
if pgrep -f "inkos up" > /dev/null; then
DAEMON_PID=$(pgrep -f "inkos up")
log "✅ inkos 守护进程运行中 (PID: $DAEMON_PID)"
echo "$DAEMON_PID" > "$DAEMON_PID_FILE"
return 0
else
log "❌ inkos 守护进程已停止"
return 1
fi
}
# 检查工作进度
check_progress() {
log "📊 检查 inkos 工作进度..."
cd "$PROJECT_DIR" 2>/dev/null || {
log "错误:无法进入项目目录"
return 1
}
# 检查书籍状态
BOOK_STATUS=$(inkos book list 2>/dev/null)
if [ $? -eq 0 ]; then
log "📚 书籍状态:$BOOK_STATUS"
else
log "⚠️ 无法获取书籍列表"
fi
# 统计章节数量
CHAPTER_COUNT=0
if [ -d "books" ]; then
for book_dir in books/*/; do
if [ -d "${book_dir}chapters" ]; then
COUNT=$(find "${book_dir}chapters" -name "*.md" -o -name "*.json" 2>/dev/null | wc -l)
BOOK_NAME=$(basename "$book_dir")
CHAPTER_COUNT=$((CHAPTER_COUNT + COUNT))
log " 📖 书籍 '$BOOK_NAME': $COUNT 个章节"
# 显示最新章节
LATEST_CHAPTER=$(find "${book_dir}chapters" -name "*.md" 2>/dev/null | sort | tail -1)
if [ -n "$LATEST_CHAPTER" ]; then
CHAPTER_NAME=$(basename "$LATEST_CHAPTER" .md)
log " 最新章节: $CHAPTER_NAME"
# 显示章节字数
if [ -f "$LATEST_CHAPTER" ]; then
WORD_COUNT=$(wc -w < "$LATEST_CHAPTER" 2>/dev/null)
CHAR_COUNT=$(wc -m < "$LATEST_CHAPTER" 2>/dev/null)
log " 字数: ${WORD_COUNT}字 (${CHAR_COUNT}字符)"
fi
fi
fi
done
fi
log "📈 总计章节: $CHAPTER_COUNT"
# 检查守护进程日志
if [ -f "/tmp/inkos-daemon.log" ]; then
LOG_LINES=$(tail -5 "/tmp/inkos-daemon.log" 2>/dev/null)
if [ -n "$LOG_LINES" ]; then
log "📝 最近日志:"
echo "$LOG_LINES" | while IFS= read -r line; do
log " $line"
done
fi
fi
return 0
}
# 修复常见问题
fix_issues() {
log "🔧 诊断并修复问题..."
cd "$PROJECT_DIR" 2>/dev/null || {
log "错误:无法进入项目目录"
return 1
}
# 1. 检查 API 配置
if [ ! -f ".env" ]; then
log "⚠️ 缺少 .env 配置文件,正在创建..."
cat > .env << 'EOF'
# LLM Configuration
INKOS_LLM_PROVIDER=custom
INKOS_LLM_BASE_URL=https://ark.cn-beijing.volces.com/api/coding/v3
INKOS_LLM_API_KEY=63589785-b399-47dd-8423-d2433938f169
INKOS_LLM_MODEL=deepseek-v3.2
EOF
log "✅ .env 文件已创建"
else
log "✅ .env 配置文件存在"
fi
# 2. 检查书籍目录
if [ ! -d "books" ]; then
log "⚠️ 缺少 books 目录,正在创建..."
mkdir -p books
fi
# 3. 检查 inkos 配置
if ! inkos status > /dev/null 2>&1; then
log "⚠️ inkos 配置有问题,尝试修复..."
# 重新初始化项目
if [ -f "inkos.json" ]; then
log "✅ inkos.json 存在,项目结构正常"
else
log "❌ inkos.json 不存在,可能需要重新初始化"
fi
fi
# 4. 检查章节文件完整性
for book_dir in books/*/; do
if [ -d "$book_dir" ]; then
CHAPTER_DIR="${book_dir}chapters"
if [ ! -d "$CHAPTER_DIR" ]; then
log "⚠️ 书籍 $(basename "$book_dir") 缺少 chapters 目录,正在创建..."
mkdir -p "$CHAPTER_DIR"
fi
fi
done
log "🔧 修复完成"
}
# 重启守护进程
restart_daemon() {
log "🔄 重启 inkos 守护进程..."
# 停止现有进程
if pgrep -f "inkos up" > /dev/null; then
log "停止现有 inkos 进程..."
pkill -f "inkos up"
sleep 2
fi
# 修复问题
fix_issues
# 启动新进程
log "启动 inkos 守护进程..."
cd "$PROJECT_DIR" && nohup inkos up > /tmp/inkos-daemon.log 2>&1 &
# 等待启动
sleep 5
# 验证启动
if check_daemon; then
log "✅ inkos 守护进程重启成功"
return 0
else
log "❌ inkos 守护进程启动失败"
return 1
fi
}
# 主监控函数
main_monitor() {
log "="*60
log "🦠 inkos 监控开始运行"
# 检查守护进程
if ! check_daemon; then
log "⚠️ 检测到 inkos 守护进程停止,正在尝试修复并重启..."
if restart_daemon; then
log "✅ 修复重启成功"
else
log "❌ 修复重启失败,可能需要人工干预"
fi
else
log "✅ inkos 守护进程正常运行"
fi
# 检查工作进度
check_progress
log "🦠 inkos 监控运行完成"
log "="*60
}
# 执行监控
main_monitor