| name | accessing-mlflow |
| description | Query and browse evaluation results stored in MLflow. Use when the user wants to look up runs by invocation ID, compare metrics across models, fetch artifacts (configs, logs, results), or set up the MLflow MCP server. ALWAYS triggers on mentions of MLflow, experiment results, run comparison, invocation IDs in the context of results, or MLflow MCP setup. |
| license | Apache-2.0 |
Accessing MLflow
MCP Server
mlflow-mcp gives agents direct access to MLflow ā query runs, compare metrics, browse artifacts, all through natural language.
ID Convention
When the user provides a hex ID (e.g. 71f3f3199ea5e1f0) without specifying what it is, assume it is an invocation_id (not an MLflow run_id). An invocation_id identifies a launcher invocation and is stored as both a tag and a param on MLflow runs. One invocation can produce multiple MLflow runs (one per task). You may need to search across multiple experiments if you don't know which experiment the run belongs to.
Querying Runs
MLflow:search_runs_by_tags(experiment_id, {"invocation_id": "<invocation_id>"})
MLflow:query_runs(experiment_id, "tags.model LIKE '%<model>%'")
MLflow:query_runs(experiment_id, "tags.task_name LIKE '%<task_name>%'")
MLflow:get_artifact_content(run_id, "config.yml")
MLflow:get_artifact_content(run_id, "artifacts/eval_factory_metrics.json")
NOTE: You WILL NOT find PENDING, RUNNING, KILLED, or FAILED runs in MLflow! Only SUCCESSFUL runs are exported to MLflow.
Workflow Tips
When comparing metrics across runs, fetch the data via MCP, then run the computation in Python for exact results rather than doing math in-context:
uv run --with pandas python3 << 'EOF'
import pandas as pd
EOF
Artifacts Structure
<harness>.<task>/
āāā artifacts/
ā āāā config.yml # Fully resolved config used during the evaluation
ā āāā launcher_unresolved_config.yaml # Unresolved config passed to the launcher
ā āāā results.yml # All results in YAML format
ā āāā eval_factory_metrics.json # Runtime stats (latency, tokens count, memory)
ā āāā report.html # Request-Response Pairs samples in HTML format (if enabled)
ā āāā report.json # Request-Response Pairs samples in JSON format (if enabled)
āāā logs/
āāā client-*.log # Evaluation client
āāā server-*-N.log # Deployment per node
āāā slurm-*.log # Slurm job
āāā proxy-*.log # Request proxy
Troubleshooting
If the MLflow MCP server fails to load or its tools are unavailable:
-
uvx not found ā install uv:
curl -LsSf https://astral.sh/uv/install.sh | sh
-
MCP server not configured ā add the config and restart the agent:
For Claude Code ā add to .claude/settings.json (project or user level), under "mcpServers":
"MLflow": {
"command": "uvx",
"args": ["mlflow-mcp"],
"env": {
"MLFLOW_TRACKING_URI": "https://<your-mlflow-server>/"
}
}
For Cursor ā edit ~/.cursor/mcp.json (Settings > Tools & MCP > New MCP Server):
{
"mcpServers": {
"MLflow": {
"command": "uvx",
"args": ["mlflow-mcp"],
"env": {
"MLFLOW_TRACKING_URI": "https://<your-mlflow-server>/"
}
}
}
}