spark-profiler-mcp
OfficialClick 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., "@spark-profiler-mcpAnalyze my server's spark profile for performance issues"
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.
spark-profiler-mcp
MCP server that reads spark profiler files so an AI can give accurate Minecraft server tuning advice.
Parses spark's binary protobuf directly: no upload, no protoc. Ships a diagnose engine that knows TPS/MSPT/GC/heap thresholds and call-tree signatures (entity ticking, chunk gen, redstone, blocking I/O, plugin hogs, JVM flags), returns ranked findings with concrete fixes.
Supported files
File | spark command | Contents |
|
| Sampler / call tree |
|
| Memory (top retained types) |
|
| TPS/MSPT/CPU/entities over time |
Input = local path, https://spark.lucko.me/<key> / bytebin URL, or bare bytebin key. gzip and raw protobuf both auto-handled.
Shared
spark.lucko.melinks expire (bytebin deletes them). For permanent analysis,--save-to-file.
Most tools (diagnose, get_summary, get_platform_info, get_system_stats, get_health) work on sampler and health files. .sparkheap → get_heap_summary. Call-tree tools = sampler only.
Related MCP server: javaperf
Install (one line)
Published to npm — no clone, no build; npx fetches and runs it:
claude mcp add spark-profiler -- npx -y spark-profiler-mcpSame thing as an MCP client config block (.mcp.json / claude_desktop_config.json):
{
"mcpServers": {
"spark-profiler": { "command": "npx", "args": ["-y", "spark-profiler-mcp"] }
}
}Then ask: "Load this.sparkprofile and tell me what to tune." The assistant calls load_profile → diagnose → drills in.
From source (dev / unpublished)
npm install && npm run build
claude mcp add spark-profiler -- node /absolute/path/to/spark-profiler-mcp/dist/index.jsTools
Tool | Purpose |
| Parse file/URL/key → |
| Version, TPS, MSPT, heap, GC%, entities, hot methods, top plugins, verdict. |
| Ranked findings: evidence → diagnosis → action. |
| Brand/version, plugins, config highlights (view/sim-distance, spawn limits). |
| Host CPU/RAM/disk/OS, Java, JVM args (secrets redacted), GC, Aikar check. |
| TPS 1/5/15m, MSPT percentiles, ping, heap, per-minute time-series ( |
| Entities, top types, per-world totals, data packs, game rules. |
| Sampled threads, busiest first. |
| Hottest methods by self time (idle/native excluded). |
| Self-time per plugin/mod. |
| Pruned tree. |
| Find frames by substring or |
|
|
Token-cheap by design. Outputs = summaries + top-N. Full call tree never dumped. Reach it via get_call_tree (depth + minPercent capped) and search_call_tree. Parsed once, cached by profileId.
How it reads spark files
Vendored
proto/spark/*.proto(from lucko/spark) loaded at runtime byprotobufjs: no codegen..sparkprofile=SamplerData. Each thread = flattened call tree:ThreadNode.childrenis a flat pool,children_refsrebuild it. Self time = node total − Σ children. Native/idle frames flagged so the active hot path shows.vmArgssurfaced for JVM analysis. Credential-like-Dprops redacted.
Development
npm run dev # run from source (tsx)
npm test # vitest: decode example, check analysis + diagnosis
npm run smoke # end-to-end over stdio
npm run inspector # @modelcontextprotocol/inspectorPublishing (maintainer)
Releases are automated via GitHub Actions + npm Trusted Publishing (OIDC) — no npm token is
stored anywhere. One-time setup on npmjs.com: the package → Settings → Trusted Publisher →
GitHub Actions, with Organization Imanity-Software, Repository spark-profiler-mcp, Workflow
publish.yml. Then to cut a release:
# bump "version" in package.json, then:
git tag v0.1.1 && git push origin v0.1.1.github/workflows/publish.yml builds, tests, and runs npm publish authenticated by OIDC, with
provenance generated automatically. (Needs Node ≥ 22.14 + npm ≥ 11.5.1; the workflow upgrades
npm itself.)
files ships only dist/ + proto/ (schemas are loaded at runtime, so they must be included);
the 24 MB example and tests are excluded.
Manual fallback (no provenance): npm login && npm publish — prepublishOnly builds + tests first.
Prefer not to use npm at all? npx -y github:Imanity-Software/spark-profiler-mcp also works — the
prepare hook builds it on install.
License
MIT. spark is © lucko, GPLv3. Only its .proto schemas are vendored here.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Imanity-Software/spark-profiler-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server