clockwork-mcp

clockwork-mcp

A Claude Code MCP server that connects to Laravel Clockwork to provide insights into application performance, database queries, errors, and request flow.

Category
访问服务器

README

clockwork-mcp

CI npm version Node.js License: MIT

MCP server for Laravel Clockwork - debug Laravel apps with Claude Code.

What it does

This MCP server gives Claude Code access to your Laravel application's Clockwork debugging data, enabling:

  • Debugging - Find slow queries, N+1 problems, cache issues, errors
  • Performance analysis - Track response times, query counts, memory usage
  • Development insight - Understand request flow, see runtime behavior

Installation

Option 1: Claude Code Plugin (Recommended)

/marketplace add github:fridzema/clockwork-mcp
/plugin install clockwork

This installs the MCP server and adds convenience commands:

  • /clockwork:status - Check storage status
  • /clockwork:latest - Show latest request summary
  • /clockwork:slow - Find slow queries
  • /clockwork:n+1 - Detect N+1 patterns

Option 2: Manual MCP Configuration

Add to your Claude Code MCP settings:

{
  "mcpServers": {
    "clockwork": {
      "command": "npx",
      "args": ["-y", "clockwork-mcp"]
    }
  }
}

Quick Start

1. Install Clockwork in your Laravel app

composer require itsgoingd/clockwork

2. Start debugging

Ask Claude to analyze your requests:

  • "Show me the latest request"
  • "Find slow queries in the last request"
  • "Check for N+1 query problems"
  • "Compare this request with the previous one"

Or use the slash commands:

  • /clockwork:status
  • /clockwork:latest
  • /clockwork:slow
  • /clockwork:n+1

Usage Examples

Debugging a Slow Endpoint

You: "The /api/orders endpoint is slow, can you analyze it?"

Claude will use the MCP tools to:

  1. Find the latest request to /api/orders
  2. Analyze query performance
  3. Detect N+1 patterns
  4. Suggest fixes like eager loading or caching

Investigating a 500 Error

You: "I just got a 500 error on the checkout page, what happened?"

Claude will:

  1. Find the latest failed request
  2. Show error logs and exception details
  3. Identify the problematic code path

Optimizing Database Queries

You: "Check if there are N+1 issues on the products page"

Claude will:

  1. Analyze recent requests to the products route
  2. Detect repeated query patterns
  3. Suggest eager loading with ->with('relation')

More Natural Language Examples

Performance:

  • "Compare the last two requests to /api/users"
  • "Which queries are taking the longest?"
  • "Show me the cache hit ratio"

Debugging:

  • "What middleware ran on the last request?"
  • "Show me all log entries with errors"
  • "List the events that were dispatched"

Analysis:

  • "Give me a performance summary of the latest request"
  • "Show the full request timeline"
  • "What views were rendered?"

Exception & Error Analysis:

  • "Show me exception patterns from the last hour"
  • "What errors have been occurring?"
  • "Group recent exceptions by type"

Route Performance:

  • "Which routes are slowest? Show p95 response times"
  • "Analyze route performance for the past day"
  • "Compare response times across endpoints"

Memory Issues:

  • "Are there any memory issues?"
  • "Detect memory leaks or growth patterns"
  • "Which requests are using the most memory?"

Queue Jobs:

  • "List failed queue jobs"
  • "Show me recent job executions"
  • "What jobs are pending?"

Test Execution:

  • "List recent test runs"
  • "Show failed tests"
  • "What tests are being skipped?"

Tools

Request Discovery

Tool Description
list_requests List recent requests with filtering
get_request Get full request details by ID
get_latest_request Get the most recent request
search_requests Search by controller, URI, status, duration

Database Analysis

Tool Description
get_queries Get all database queries for a request
analyze_slow_queries Find queries above threshold
detect_n_plus_one Detect N+1 query patterns
get_query_stats Get aggregate query statistics

Performance

Tool Description
get_performance_summary Response time, memory, query overview
get_timeline Execution timeline events
compare_requests Compare two requests side by side

Cache & Redis

Tool Description
get_cache_operations Cache hits, misses, writes
get_cache_stats Hit ratio and totals
get_redis_commands Redis commands executed

Application Context

Tool Description
get_logs Log entries with level filtering
get_events Dispatched events and listeners
get_views Rendered views
get_http_requests Outgoing HTTP requests

Artisan Commands

Tool Description
list_commands List profiled command executions
get_command Full command execution details

Traces & Execution Flow

Tool Description
get_call_graph Hierarchical execution tree from timeline events
get_query_stack_trace Source location for a database query
get_log_stack_trace Source location for a log entry

Profiling (Xdebug)

Tool Description
get_xdebug_profile Xdebug profiling data (stub)
get_xdebug_hotspots Xdebug hotspots (stub)

Queue Jobs

Tool Description
list_queue_jobs List queue jobs with filtering
get_queue_job Full queue job details

Test Execution

Tool Description
list_tests List test executions with filtering
get_test Full test execution details

Request Context

Tool Description
get_auth_user Authenticated user for a request
get_session_data Session data for a request
get_middleware_chain Middleware chain for a request
get_route_details Route details for a request

Multi-Request Analysis

Tool Description
analyze_exceptions Group exceptions by message pattern
analyze_route_performance Route performance with percentiles (p50/p95/p99)
detect_memory_issues Detect high memory usage and growth patterns

Utility

Tool Description
get_clockwork_status Storage status and statistics
explain_request_flow High-level request summary

Configuration

Storage Backends

By default, Clockwork MCP auto-detects your Laravel project and uses php artisan tinker to read Clockwork data. This works with all Clockwork storage backends:

  • File (default)
  • SQLite
  • MySQL
  • PostgreSQL
  • Redis

When you configure Clockwork to use SQL or Redis storage in your Laravel app (config/clockwork.php), the MCP server automatically uses the same storage by running PHP commands through artisan tinker. No additional configuration required.

Environment Variables

Variable Default Description
CLOCKWORK_PROJECT_PATH Auto-detect Path to Laravel project root
CLOCKWORK_STORAGE_DRIVER Auto-detect Force storage driver (artisan or file)
CLOCKWORK_PHP_PATH php Custom PHP binary path
CLOCKWORK_STORAGE_PATH Auto-detect Direct path to storage (file driver only)

Auto-detection

The MCP server automatically finds Clockwork storage by:

  1. Checking CLOCKWORK_PROJECT_PATH environment variable
  2. Looking for Laravel project (has artisan file) in current directory
  3. Traversing up to find a Laravel project

When a Laravel project is found, the artisan driver is used by default, which supports all Clockwork storage backends. The file driver is used as a fallback when only a direct storage path is available.

Requirements

  • Node.js 18+
  • Laravel project with Clockwork installed
  • Claude Code with MCP support

License

MIT

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选