feat: 添加 Dashboard 完整日志监控系统 v1.1.0

 新增功能
- 完整的日志记录系统(6 种日志级别)
- 日志配置功能(可通过 config.json 控制)
- 性能监控装饰器和请求日志中间件
- 7 个管理工具脚本
- 完整的文档和使用指南

🛠️ 管理工具
- start-with-log.sh: 启动脚本(带日志)
- stop-dashboard.sh: 停止脚本
- view-logs.sh: 日志查看器
- monitor-logs.sh: 实时监控工具(支持多种过滤器)
- analyze-logs.sh: 日志分析工具(自动生成报告)
- demo-logging.sh: 功能演示脚本
- test-logging-config.sh: 配置测试工具

📊 日志特性
- 支持 INFO/SUCCESS/WARN/ERROR/DEBUG/PERF 6 种级别
- 自动记录启动过程、API 请求、性能统计
- 缓存命中情况追踪
- 分步性能监控
- 智能过滤器

⚙️ 配置功能
- 可控制是否启用日志(默认:true)
- 可设置日志级别(默认:INFO)
- 可控制文件/控制台输出
- 支持动态配置(重启生效)

📚 文档
- LOGGING_GUIDE.md: 完整使用指南
- LOGGING_CONFIG.md: 配置说明文档
- LOGGING_CONFIG_QUICK.md: 快速配置指南
- 多个中文说明文档

🔒 安全
- 添加 .gitignore 排除敏感信息
- config.json(含 Token)不提交
- 日志文件不提交
- 示例配置使用占位符

 测试
- 语法检查通过
- 功能完整性验证
- 配置控制测试通过
- 文档完整性检查

详见 CHANGELOG_v1.1.0.md

Made-with: Cursor
This commit is contained in:
fang
2026-03-11 11:37:35 +08:00
commit 5f14174bb9
65 changed files with 12754 additions and 0 deletions

53
dashboard/stop-dashboard.sh Executable file
View File

@@ -0,0 +1,53 @@
#!/bin/bash
# AI Team Dashboard 停止脚本
# 使用方法:./stop-dashboard.sh
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
PID_FILE="$SCRIPT_DIR/logs/dashboard.pid"
if [ ! -f "$PID_FILE" ]; then
echo "⚠️ 未找到 PID 文件Dashboard 可能没有运行"
echo ""
echo "尝试查找 Dashboard 进程..."
DASHBOARD_PID=$(ps aux | grep "node server.js" | grep -v grep | awk '{print $2}')
if [ -n "$DASHBOARD_PID" ]; then
echo "找到 Dashboard 进程: $DASHBOARD_PID"
kill "$DASHBOARD_PID" 2>/dev/null
echo "✅ Dashboard 已停止"
else
echo "未找到运行中的 Dashboard 进程"
fi
exit 0
fi
DASHBOARD_PID=$(cat "$PID_FILE")
if ps -p "$DASHBOARD_PID" > /dev/null 2>&1; then
echo "🛑 正在停止 Dashboard (PID: $DASHBOARD_PID)..."
kill "$DASHBOARD_PID"
# 等待进程结束
for i in {1..5}; do
if ! ps -p "$DASHBOARD_PID" > /dev/null 2>&1; then
echo "✅ Dashboard 已停止"
rm -f "$PID_FILE"
exit 0
fi
sleep 1
done
# 如果还没停止,强制结束
if ps -p "$DASHBOARD_PID" > /dev/null 2>&1; then
echo "⚠️ 正在强制停止..."
kill -9 "$DASHBOARD_PID"
sleep 1
fi
echo "✅ Dashboard 已停止"
rm -f "$PID_FILE"
else
echo "⚠️ 进程 $DASHBOARD_PID 不存在"
rm -f "$PID_FILE"
echo "✅ 已清理 PID 文件"
fi