MCP Java Dev Tools
Bridges agentic coding tools and live Java runtime behavior through a lightweight sidecar agent.
mcp-java-dev-tools
MCP Java Dev Tools bridges agentic coding tools and live Java runtime behavior through a lightweight sidecar agent.
Static analysis only gets you so far. By attaching directly to a running JVM, this tool surfaces bytecode-level runtime signals that static analysis alone can't see — enabling probe-verified inspection, targeted regression checks, runtime-path validation, and deterministic debugging workflows.
The runtime agent is built with ByteBuddy and works alongside JDWP rather than replacing it. On top of the probe layer, the system adds framework-aware data synthesis and strict, fail-closed tool contracts — so agent orchestrators can make decisions grounded in actual runtime proof, not inference.
The current focus is HTTP entrypoints. Non-HTTP protocol support is on the horizon but not yet implemented — it will need concrete models and validation targets before the core contracts can be generalized.
For operator workflows and end-to-end execution flows, see docs/how-it-works/README.md.
Requirements
| Requirement | Version |
|---|---|
| Node.js | v24.13.0 (tested) |
| npm | 11.6.2 (tested) |
| JDK | 17+ |
| Maven | any recent |
Build
npm.cmd install
npm.cmd run build
mvn -f java-agent\pom.xml package
This produces two artifacts:
- MCP server →
dist/server.js - Java agent bundle →
java-agent/core/core-probe/target/mcp-java-dev-tools-agent-0.1.0-all.jar
Installation
Installer
Installer flow is split into install and update scripts (Codex and Kiro skills).
./scripts/install.sh
This installs the default skill set:
mcp-java-dev-tools-line-probe-runmcp-java-dev-tools-regression-suitemcp-java-dev-tools-regression-plan-craftermcp-java-dev-tools-regression-resultmcp-java-dev-tools-issue-reportmcp-java-dev-tools-probe-registry-manager
To update/overwrite existing installed skills (and add missing new skills):
./scripts/update.sh
Both scripts:
- run
npm run build:compile - run
mvn -f java-agent/pom.xml package - sync shipped skills into the target client skill directory
- by default prompt for a first workspace and generate MCP env config block output (Codex/Kiro specific)
Default MCP registry env input can be skipped:
./scripts/install.sh --client codex --no-configure-mcp-env
MCP env input captures:
MCP_PROBE_BASE_URL(defaulthttp://127.0.0.1:9193)MCP_WORKSPACE_ROOT(required)MCP_PROBE_CONFIG_FILE(defaults to<workspace>/.mcpjvm/probe-config.json)MCP_PROBE_PROFILE(defaultdev)
Spring Integration Launcher
Use the helper launcher to run a Spring app with auto-inferred Java agent include scope and probe port:
./spring-integration/run-spring-app-with-mcp.sh
Behavior:
- prompts for Spring project absolute path, app port (default
8080), optional JDWP port, and Java 21 compatibility - infers include package from
src/main/java - assigns probe port starting at
9173and increments if occupied - opens a new Git Bash window and starts the Spring app with
JAVA_TOOL_OPTIONSincluding-javaagent
Manual Setup
Java Agent Setup
The target JVM must run on Java 17 or newer. If you're on Java 21, see Java 21 compatibility mode before continuing.
Add the following as a JVM argument when launching your application, replacing {desktopName}:
-javaagent:C:\Users\{desktopName}\repository\mcp-java-dev-tools\java-agent\core\core-probe\target\mcp-java-dev-tools-agent-0.1.5.jar=host=0.0.0.0;port=9191;exclude=com.nimbly.mcpjavadevtools.agent.**,**.config.**,**Test
Tip: The
includefilter is optional. If omitted, the agent infers an include scope from startup command metadata (sun.java.command), usually the startup class package (for examplecom.acme.app.**). Setincludeexplicitly when inference is ambiguous or too broad.MCP_WORKSPACE_ROOTdoes not control Java instrumentation scope.
includesupports comma-separated basepaths:
- package globs (for example
com.thirdparty.service.**)- exact class FQCNs (for example
com.example.ApiClass)- mixed module/class targeting in one value (for example
com.example.app.**,com.example.api.**,com.thirdparty.SomeClass)
To confirm the agent is instrumenting your classes, check the startup logs for lines like:
[mcp-probe]: com.yourpackagename.yourclassname
If you don't see your classes listed, check your include filter.
IntelliJ IDEA — Step by Step
- Open Run > Edit Configurations... from the top menu
- Select the run configuration for your target application (or create one if it doesn't exist)
- Expand the Modify options dropdown and enable Add VM options if it isn't already visible
- In the VM options field, paste the full
-javaagent:...argument from above - Click Apply, then OK
- Run your application normally — the agent attaches on startup
Finding the JAR path: If you're unsure of the absolute path, right-click the agent JAR in the Project panel and choose Copy Path > Absolute Path.
On Windows, use backslashes in the path (
C:\Users\...). On macOS/Linux, use forward slashes (/home/...or/Users/...).
Eclipse — Step by Step
- Go to Run > Run Configurations... (or Debug Configurations... if you're debugging)
- Select your application under Java Application, or create a new one
- Open the Arguments tab
- In the VM arguments field, paste the full
-javaagent:...argument from above - Click Apply, then Run (or Debug)
Finding the JAR path: Navigate to the JAR in your file system, right-click it, and copy the full path. Paste it into the agent argument, replacing the placeholder path.
On Windows, Eclipse accepts both forward and backslashes in paths, but backslashes are safer. Wrap the path in quotes if it contains spaces:
-javaagent:"C:\path with spaces\agent.jar"=...
Runtime Configuration
Java Agent Options
Capture History Buffer Size
Controls how many method captures the agent retains per probe point.
| Method | Value |
|---|---|
| Agent arg | captureMethodBufferSize=<1..32> |
| JVM property | -Dmcp.probe.capture.method.buffer.size=<1..32> |
| Environment variable | MCP_PROBE_CAPTURE_METHOD_BUFFER_SIZE=<1..32> |
Default is 3. Increase this if you need deeper capture history for a single probe point.
Java 21 Compatibility Mode
Required if your target JVM runs on Java 21. Enables ByteBuddy's experimental support for newer JVM internals.
| Method | Value |
|---|---|
| Agent arg | allowJava21=true (aliases: java21Compat=true, byteBuddyExperimental=true) |
| JVM property | -Dmcp.probe.bytebuddy.experimental=true (legacy alias: -Dmcp.probe.allow.java21=true) |
| Environment variable | MCP_PROBE_BYTEBUDDY_EXPERIMENTAL=true (legacy alias: MCP_PROBE_ALLOW_JAVA21=true) |
Default is false.
MCP Server Environment Variables
Required
| Variable | Purpose |
|---|---|
MCP_PROBE_BASE_URL | URL of the running probe agent |
MCP_PROBE_CONFIG_FILE | Path to probe registry JSON for multi-probe mode |
Optional
| Variable | Default | Notes |
|---|---|---|
MCP_WORKSPACE_ROOT | — | Project root hint for path resolution only (does not control Java instrumentation scope) |
MCP_JAVA_REQUEST_MAPPING_RESOLVER_JAR | — | |
MCP_JAVA_REQUEST_MAPPING_RESOLVER_CLASSPATH | — | |
MCP_JAVA_BIN | — | |
MCP_PROBE_LINE_SELECTION_MAX_SCAN_LINES | 120 | Range: 10–2000 |
MCP_PROBE_WAIT_MAX_RETRIES | 1 | Max: 10 |
MCP_PROBE_WAIT_UNREACHABLE_RETRY_ENABLED | false | |
MCP_PROBE_WAIT_UNREACHABLE_MAX_RETRIES | 3 | Max: 10 |
MCP_PROBE_INCLUDE_EXECUTION_PATHS | false | Set true to include executionPaths arrays in probe payloads |
Configuration Scope Matrix
| Setting | Consumed By | Affects |
|---|---|---|
MCP_WORKSPACE_ROOT / --workspace-root | MCP server | Path resolution for project validation and synthesis search roots |
MCP_PROBE_BASE_URL / --probe-base-url | MCP server | Default probe endpoint for tool calls |
MCP_PROBE_CONFIG_FILE | MCP server | Multi-probe registry file with workspaces/profiles/probes |
MCP_PROBE_PROFILE | MCP server | Explicit profile override when registry mode is enabled |
If MCP_PROBE_CONFIG_FILE is not set, MCP will auto-discover only:
.mcpjvm/probe-config.json|include/excludein-javaagent:...(ormcp.probe.include/MCP_PROBE_INCLUDE) | Java agent | Which classes are instrumented at runtime | |MCP_PROBE_INCLUDE_EXECUTION_PATHS| MCP server | WhetherexecutionPathsarrays are included in returned probe payloads |
Probe Endpoints
These paths are fixed and cannot be overridden.
| Endpoint | Path |
|---|---|
| Status | /__probe/status |
| Reset | /__probe/reset |
| Capture | /__probe/capture |
Skills
| Skill | Purpose |
|---|---|
mcp-java-dev-tools-line-probe-run | Line-level probe execution |
mcp-java-dev-tools-regression-suite | Regression check orchestration |
mcp-java-dev-tools-regression-plan-crafter | Craft and refine deterministic persisted regression plan specs (metadata.json, contract.json, plan.md) |
mcp-java-dev-tools-regression-result | Artifact-derived result rendering with extensible display templates (default endpoint table) |
mcp-java-dev-tools-issue-report | Sanitized issue reporting from session, runtime, and probe evidence |
Contributing
Contribution guidance lives in CONTRIBUTING.md.
The guide distinguishes between:
- synthesizer and adapter contributions
- probe tools and recipe generation contributions
Start there before opening a large pull request or changing public tool contracts.
MCP Tools
| Tool | |
|---|---|
debug_check | |
project_context_validate | |
probe_check | |
probe_target_infer | |
probe_recipe_create | |
probe_get_status | |
probe_get_capture | |
probe_reset | |
probe_wait_for_hit | |
probe_enable | |
probe_registry_list | |
probe_registry_reload |
Probe registry runtime behavior:
- Registry config is loaded on startup.
- When
MCP_PROBE_CONFIG_FILE(or workspace.mcpjvm/probe-config.json) is active, file edits are auto-reloaded with debounce. probe_registry_reloadremains available as deterministic manual refresh/fallback.
Serveurs connexes
Alpha Vantage MCP Server
sponsorAccess financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
Xcode
Tools for Xcode project management, building, testing, archiving, code signing, and iOS development utilities.
MCPfinder
A Node.js server for AI agents to discover, install, and manage new capabilities on demand via the MCP protocol.
Typst MCP Server
Provides Typst documentation to MCP clients like Claude Code.
Testplane MCP
A server for Testplane that enables LLMs to interact with web applications.
Swift Package Index
Search for Swift packages and retrieve their READMEs and metadata from the Swift Package Index.
CCXT MCP Server
Interact with over 100 cryptocurrency exchange APIs using the CCXT library.
Code Assistant
A server for code modification and generation using Large Language Models.
Codacy
Access the Codacy API to analyze code quality, coverage, and security for your repositories.
ContextKeeper
Provides perfect memory for AI-assisted development by capturing project context snapshots, enabling natural language search, evolution tracking, and code intelligence.
MCP Spec Navigator
Navigate and explore the Model Context Protocol specification with dynamic markdown tree generation and intelligent section navigation.