Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Error Analyzer MCP Serveranalyze error.log and create a fix plan for my project"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Error Analyzer MCP Server š§
A specialized Model Context Protocol (MCP) server that analyzes errors in your projects, identifies root causes, and generates detailed fix plans with a built-in approval workflow before applying any changes.
š Overview
When your project encounters errors, this MCP server helps you:
Read and analyze log files to understand what went wrong
Identify the affected files and their dependencies
Diagnose the root cause of errors
Create detailed fix plans with step-by-step solutions
Request your approval before making ANY file modifications
Apply approved fixes safely to your project
This server emphasizes safety and transparency: it never modifies your files without your explicit approval and clear understanding of what will change.
šļø Architecture
Reads log files from a configurable
loggerdirectoryAnalyzes error messages and stack traces
Identifies related files and dependencies
Generates fix plans with risk assessment
Implements a two-phase workflow:
Analysis & Planning Phase: Creates fix plans
Approval Phase: Waits for your explicit approval
Application Phase: Applies approved changes
š ļø Available Tools
1. list_available_logs
List all log files in your logger directory.
Returns all
.logfiles available for analysis
2. analyze_error
Analyze errors in a specific log file.
Input: project directory path, log file name
Returns: error location, root cause, affected files, severity level
Creates an analysis ID for further processing
3. create_fix_plan
Create a detailed work plan to fix identified errors.
Input: analysis ID from previous step
Returns: fix plan with proposed fixes, impact assessment, risk level
Status: Awaiting your approval
Creates a plan ID for tracking
4. approve_fix_plan
Approve a fix plan after reviewing the proposed changes.
Input: plan ID
Effect: Marks the plan as approved
Next step: Call
apply_fix_planto make the changes
5. reject_fix_plan
Reject a fix plan if you disagree with proposed solutions.
Input: plan ID, optional feedback
Effect: Cancels the plan
Next step: Can request new analysis with different parameters
6. apply_fix_plan
Apply the approved fixes to your project files.
Input: plan ID (must be approved first)
Effect: MODIFIES YOUR PROJECT FILES
Returns: List of changes applied
Safety: Only works if plan was explicitly approved
7. get_fix_plan_details
Retrieve detailed information about a specific fix plan.
Useful for reviewing plans before approval
8. list_pending_plans
See all fix plans created in this session with their statuses.
Helps track pending approvals and applied fixes
š Workflow Example
1. Error occurs in your project
ā
2. Error is written to logger/error.log
ā
3. Call analyze_error(project_dir="/path/to/project", log_file_name="error.log")
ā Returns: analysis_id = "abc123"
ā
4. Call create_fix_plan(analysis_id="abc123")
ā Returns: plan_id = "xyz789"
ā Status: "AWAITING USER APPROVAL"
ā
5. Review the proposed fixes in the plan
ā
6. Either:
a) Call approve_fix_plan(plan_id="xyz789") ā then apply_fix_plan(plan_id="xyz789")
b) Call reject_fix_plan(plan_id="xyz789", feedback="...")š Setup
Installation
Clone or extract the project to your workspace:
cd m:\mcp\mcp-read-logInstall dependencies:
pip install -r requirements.txtConfigure environment (optional):
# Copy the example file
cp .env.example .env
# Edit .env to customize:
# - LOG_DIR: Path to your logger directory (default: ./logger)
# - PROJECT_DIR: Default project to analyze
# - BACKUP_BEFORE_APPLY: Create backups before applying fixesCreate logger directory if it doesn't exist:
mkdir loggerš Usage with Claude or Other AI Agents
In Claude or Cline:
You have access to the error-analyzer-mcp MCP server. When a user's project has errors:
1. First call: list_available_logs() to see what log files are available
2. Then call: analyze_error() with the project path and log file name
3. Review the analysis results
4. Call: create_fix_plan() with the analysis ID
5. Show the user the proposed fixes and ask for approval
6. Only after explicit approval, call: apply_fix_plan()Example Session:
User: "My Python project is broken with errors"
AI: Calling list_available_logs()... Found: error.log, debug.log
AI: Which log should I analyze? Let me check error.log.
AI: Calling analyze_error(project_dir=".", log_file_name="error.log")
AI: Analysis complete! Found SyntaxError on line 42, affects 3 files.
AI: Calling create_fix_plan()...
AI: Created fix plan. Here are the proposed changes:
- Fix syntax error in main.py line 42
- Update import in handler.py line 15
AI: This has LOW risk. Do you approve these changes?
User: "Yes, apply them"
AI: Calling approve_fix_plan()... then apply_fix_plan()
AI: Done! Applied 2 fixes to your project.š Safety Features
ā No file modifications without approval
Every fix plan requires explicit user approval before changes
ā Clear risk assessment
Each plan shows risk level, severity, and dependencies
ā Transparent change tracking
See exactly which files and lines will be modified
ā Reversible operations
Backup support (configurable in .env)
Can review changes before committing
š Log File Format
Place log files in the logger directory. Supported formats:
Standard error logs with file:line:column notation
Stack traces with file paths
IDE error output
Custom formatted logs with error messages
Example:
Error in /path/to/file.py on line 42:
SyntaxError: invalid syntax
x = y +
^
File "helper.py", line 15, in process()
undefined_variable = 5š§ Configuration Files
pyproject.toml
Project metadata and Python dependencies. Uses PyPI packages for MCP, Pydantic, and python-dotenv.
requirements.txt
Direct pip requirements for easy installation.
settings.py
Configuration dataclass for runtime settings.
.env
Environment variables:
LOG_DIR: Custom logger directory pathPROJECT_DIR: Default project to analyzeBACKUP_BEFORE_APPLY: Whether to create backups (true/false)
š Project Structure
mcp-read-log/
āāā main.py # MCP server with all tools
āāā settings.py # Configuration management
āāā pyproject.toml # Project metadata
āāā requirements.txt # Python dependencies
āāā .env.example # Example configuration
āāā README.md # This file
ā
āāā models/
ā āāā result.py # ToolResult, ErrorInfo, ErrorAnalysis models
ā āāā error_analysis_models.py # Input models for MCP tools
ā
āāā services/
ā āāā log_reader.py # Log file reading utilities
ā āāā error_analysis_service.py # Core error analysis logic
ā
āāā utils/
ā āāā (utilities for path, validation, errors)
ā
āāā tests/
ā āāā (unit tests for services)
ā
āāā logger/ # Log files (created on first use)
āāā error.log
āāā debug.logš Debugging
If the MCP server doesn't start:
Check Python version: Requires Python 3.12+
python --versionVerify dependencies:
pip list | grep mcp
pip list | grep pydanticTest log reading:
python -c "from services.log_reader import list_log_files; print(list_log_files())"Check environment:
echo %LOG_DIR% # Windows
echo $LOG_DIR # Linux/Macš License
Based on the git-mcp-server framework by the course instructor.
š¤ Contributing
To extend this MCP server:
Add new error detection patterns in
error_analysis_service.pyAdd new analysis types by extending
ErrorAnalysismodelAdd new tool methods in
main.pyfollowing the@mcp.tool()pattern
Remember: This server helps you understand and fix errors safely. Always review proposed changes before approval!
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.