MCP gateway with a built-in skill library.
One YAML. One endpoint. Every MCP server plus the skills you author alongside them.
Gridctl aggregates tools from MCP servers into a single gateway and serves Agent Skills as MCP prompts to upstream clients. Define your stack in YAML, apply with one command, and connect Claude Desktop (or any MCP client) through one endpoint.
gridctl apply stack.yamlDesigned for fast, ephemeral, stateless environments, inspired by Containerlab.
MCP servers are everywhere: different transports, different hosting models, different .json files accumulating like dust. Skills are a separate sprawl on top. Switching projects shouldn't mean rewriting every client config.
Gridctl gives you one declarative file for everything you want connected, one local endpoint your client talks to, and a UI that shows you what's actually running. Build fast, throw it away, rebuild it tomorrow.
version: "1"
name: stack
mcp-servers:
# Containerized stdio MCP server
- name: github
image: ghcr.io/github/github-mcp-server:latest
transport: stdio
tools: ["get_file_contents", "search_code", "list_commits", "get_pull_request"]
env:
GITHUB_PERSONAL_ACCESS_TOKEN: "${GITHUB_PERSONAL_ACCESS_TOKEN}"
# External SaaS MCP server (OAuth flow)
- name: atlassian
command: ["npx", "mcp-remote", "https://mcp.atlassian.com/v1/sse"]
# Any REST API as MCP tools via OpenAPI
- name: my-api
openapi:
spec: https://api.example.com/openapi.json
baseUrl: https://api.example.comThree servers, three transports, one endpoint. Navigate to localhost:8180 to visualize the stack π
curl -fsSL https://raw.githubusercontent.com/gridctl/gridctl/main/install.sh | shInstalls the latest release to ~/.local/bin/gridctl. Full instructions for Homebrew, pre-built binaries, building from source, container runtime setup, and updating/uninstalling are in the Installation guide.
# Apply the example stack
gridctl apply examples/getting-started/skills-basic.yaml
# Check what's running
gridctl status
# Open the web UI
open http://localhost:8180
# Clean up
gridctl destroy examples/getting-started/skills-basic.yamlThe easiest way to connect is with gridctl link, which auto-detects installed LLM clients and injects the gateway configuration:
gridctl link # Interactive: detect and select clients
gridctl link claude # Link a specific client
gridctl link --all # Link all detected clients at onceSupported clients: Claude Desktop, Claude Code, Cursor, Windsurf, VS Code, Gemini, Antigravity, OpenCode, Grok Build, Continue, Cline, AnythingLLM, Roo, Zed, Goose
Manual configuration
{
"mcpServers": {
"gridctl": {
"url": "http://localhost:8180/sse"
}
}
}{
"mcpServers": {
"gridctl": {
"command": "npx",
"args": ["-y", "mcp-remote", "http://localhost:8180/sse", "--allow-http", "--transport", "sse-only"]
}
}
}Restart Claude Desktop after editing. All tools from your stack are now available.
{
"mcpServers": {
"gridctl": {
"serverUrl": "http://localhost:8180/mcp"
}
}
}Antigravity borrows Windsurf's serverUrl field but speaks streamable HTTP, so point it at the /mcp endpoint (not /sse). The IDE and CLI share ~/.gemini/config/mcp_config.json on Antigravity 2.0. Since Antigravity caps each MCP server at 100 tools, pair a large stack with gateway.code_mode: on.
Declarative, version-controlled MCP environments. Validate before you commit, plan before you apply, and detect the moment your environment drifts from what's in version control. Drift detection runs in the background: the canvas flags servers running but absent from your spec, and declarations in your spec that haven't been deployed.
gridctl validate stack.yaml # Lint and schema-check the spec (exit 0/1/2)
gridctl plan stack.yaml # Diff against running state
gridctl apply stack.yaml # Apply the spec
gridctl export # Reverse-engineer stack.yaml from a running stackLearn more β Configuration Reference
Every tool call is priced against an embedded snapshot of LiteLLM model rates. gridctl optimize scans the running gateway and surfaces actionable findings with weekly USD impact (unused servers, unused tools, schema overhead, format-conversion shortfalls, and expensive-model-on-cheap-task patterns), plus a paste-ready YAML remediation for each.
gridctl optimize # styled findings table
gridctl optimize --format json # machine-readable OptimizeReport
gridctl optimize --severity warn,critical # narrow to actionable findingsLearn more β Cost Observability
Tool call results default to JSON. Set output_format at the gateway or per-server level to convert structured responses into TOON or CSV before they reach the client, reducing token consumption by 25β61% for tabular and key-value data. Non-JSON responses and payloads over 1 MB are passed through unchanged.
gateway:
output_format: toon # Default for all servers: json, toon, csv, text
mcp-servers:
- name: analytics
output_format: csv # Override per serverLearn more β Configuration Reference
Every SKILL.md in your registry surfaces to upstream MCP clients as a prompt. Author in the Library workspace in the web UI (or via gridctl skill * on the CLI), activate, and the prompt becomes available to Claude Desktop, Claude Code, Cursor, Codex, or anything that speaks MCP.
gridctl skill list # Show what's in the registry
gridctl skill add <git-repo> # Import skills from a remote repo
gridctl activate my-skill # Promote a draft β activeSkills follow the agentskills.io specification: author them as plain markdown with frontmatter and they work with every skill-aware client, not just gridctl.
Learn more β Skills guide
| Example | What It Shows |
|---|---|
mcp-basic.yaml |
Stack with multiple MCP servers and tool filtering |
local-mcp.yaml |
Local process and SSH-tunneled MCP transports |
openapi-basic.yaml |
Turn a REST API into MCP tools via OpenAPI spec |
code-mode-basic.yaml |
Gateway code mode with search + execute meta-tools |
github-mcp.yaml |
GitHub MCP server integration |
registry-basic.yaml |
Skills registry with a single server |
var-basic.yaml |
Reference variable-store secrets with ${var:KEY} syntax |
otlp-jaeger.yaml |
Export traces to Jaeger via OTLP |
- Getting started: Installation
- Reference: CLI Β· Configuration Β· REST API
- Guides: Skills Β· Scaling Β· Cost Observability
- Operations: Project Status Β· Troubleshooting
Full index at docs/.
See CONTRIBUTING.md. PRs welcome for new transport types, example stacks, and documentation improvements.
Built for engineers who'd rather be building and hate the absence of repeatable environments.


