airbyte-mcp
Allows interaction with an Airbyte instance (self-managed or Cloud) to manage workspaces, sources, destinations, connections, jobs, job logs, streams, tags, and connector definitions via the Airbyte Public API and internal Configuration API.
Click 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., "@airbyte-mcplist all workspaces"
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.
Airbyte MCP Server (airbyte-mcp)
MCP server for the Airbyte Public API. Built with the official MCP Python SDK (FastMCP).
Lets any MCP-compatible client (Cursor, Claude Desktop, Claude Code, MCP Inspector, etc.) interact with your Airbyte instance through natural language.
Features
30 tools covering workspaces, sources, destinations, connections, jobs, job logs, tags, streams, and connector definitions
Read and write operations for core resources (create, update, delete)
Job diagnostics via the internal Configuration API (self-managed): detailed failure reasons, per-stream stats, and structured logs
Automatic token exchange with in-memory caching and transparent 401 retry
Markdown and JSON response formats on summary tools; JSON-only for log tools
Pagination support (limit/offset) on all list tools
Two transport modes: stdio (local) and streamable HTTP (remote)
Works with self-managed Airbyte (abctl) and Airbyte Cloud
Available Tools
Tool | Description |
Health | |
| Ping the Airbyte API |
Workspaces | |
| List workspaces with pagination |
| Get workspace details by ID |
Sources | |
| List source connectors (filter by workspace) |
| Get source details by ID |
| Create a new source connector |
| Update an existing source |
Destinations | |
| List destination connectors (filter by workspace) |
| Get destination details by ID |
| Create a new destination connector |
| Update an existing destination |
Connections | |
| List connections / pipelines (filter by workspace) |
| Get connection details including stream config |
| Create a new connection (pipeline) |
| Update an existing connection |
Jobs | |
| List jobs (filter by connection, type, status, dates) |
| Get job details (status, duration, bytes/rows synced) |
| Trigger a sync or reset job |
| Cancel a running job |
Job Logs (Internal API) | |
| Per-attempt stats, failure reasons, and stacktraces |
| Structured log entries for all attempts |
| Structured log entries for a specific attempt |
Streams | |
| Get stream properties for a source/destination pair |
Tags | |
| List tags |
| Create a tag |
| Update a tag |
| Delete a tag |
Connector Definitions | |
| List source connector definitions |
| Get a source connector definition |
| List destination connector definitions |
| Get a destination connector definition |
See docs/endpoints.md for the full Airbyte API endpoint checklist.
Prerequisites
A running Airbyte instance — either:
Self-managed via abctl (see docs/local-setup.md)
One of the following to run the server:
Quickstart
1. Clone and install
git clone https://github.com/trustxai/airbyte-mcp.git
cd airbyte-mcp
uv sync2. Configure credentials
cp .env.example .envFor self-managed (abctl), retrieve credentials:
abctl local credentialsEdit .env with your client-id and client-secret. See docs/authentication.md for details.
3. Run the server
stdio (Cursor / Claude Desktop / Docker)
uv run airbyte-mcpStreamable HTTP (remote / MCP Inspector)
uv run airbyte-mcp-http
# Listening on http://127.0.0.1:8080/mcpClient Configuration
Every MCP client (Cursor, Claude Desktop, etc.) can run the server in one of two ways:
uv — quickest to set up, but requires uv installed locally.
Docker — no Python / uv required on the host; everything runs in a container. Build the image once and every client config reuses it.
Host networking note: if Airbyte is running on your host machine (e.g. via
abctl), inside the Docker containerlocalhostdoes not point to your host. Usehttp://host.docker.internal:8000/api/public/v1on macOS/Windows, or add--network=hostto thedocker runargs on Linux.
Build the Docker image (one-time)
docker build -t airbyte-mcp:latest .Cursor
Add to .cursor/mcp.json (project-level) or ~/.cursor/mcp.json (global):
Option A — uv
{
"mcpServers": {
"airbyte": {
"command": "uv",
"args": ["--directory", "/path/to/airbyte-mcp", "run", "airbyte-mcp"],
"env": {
"AIRBYTE_API_URL": "http://localhost:8000/api/public/v1",
"AIRBYTE_CLIENT_ID": "<your-client-id>",
"AIRBYTE_CLIENT_SECRET": "<your-client-secret>"
}
}
}
}Option B — Docker
{
"mcpServers": {
"airbyte": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"--name", "airbyte-mcp",
"-e", "AIRBYTE_API_URL",
"-e", "AIRBYTE_CLIENT_ID",
"-e", "AIRBYTE_CLIENT_SECRET",
"airbyte-mcp:latest"
],
"env": {
"AIRBYTE_API_URL": "http://host.docker.internal:8000/api/public/v1",
"AIRBYTE_CLIENT_ID": "<your-client-id>",
"AIRBYTE_CLIENT_SECRET": "<your-client-secret>"
}
}
}
}Claude Desktop
Add to claude_desktop_config.json:
Option A — uv
{
"mcpServers": {
"airbyte": {
"command": "uv",
"args": ["--directory", "/path/to/airbyte-mcp", "run", "airbyte-mcp"],
"env": {
"AIRBYTE_API_URL": "http://localhost:8000/api/public/v1",
"AIRBYTE_CLIENT_ID": "<your-client-id>",
"AIRBYTE_CLIENT_SECRET": "<your-client-secret>"
}
}
}
}Option B — Docker
{
"mcpServers": {
"airbyte": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"--name", "airbyte-mcp",
"-e", "AIRBYTE_API_URL",
"-e", "AIRBYTE_CLIENT_ID",
"-e", "AIRBYTE_CLIENT_SECRET",
"airbyte-mcp:latest"
],
"env": {
"AIRBYTE_API_URL": "http://host.docker.internal:8000/api/public/v1",
"AIRBYTE_CLIENT_ID": "<your-client-id>",
"AIRBYTE_CLIENT_SECRET": "<your-client-secret>"
}
}
}
}Claude Code (HTTP)
Option A — uv
uv run airbyte-mcp-http &
claude mcp add --transport http airbyte http://127.0.0.1:8080/mcpOption B — Docker
docker build -f Dockerfile.http -t airbyte-mcp-http:latest .
docker run -d --rm --name airbyte-mcp-http \
-p 8080:8080 \
-e AIRBYTE_API_URL=http://host.docker.internal:8000/api/public/v1 \
-e AIRBYTE_CLIENT_ID=<your-client-id> \
-e AIRBYTE_CLIENT_SECRET=<your-client-secret> \
airbyte-mcp-http:latest
claude mcp add --transport http airbyte http://127.0.0.1:8080/mcpMCP Inspector
# Start the server in HTTP mode (uv or docker — either works)
uv run airbyte-mcp-http
# or: docker run --rm -p 8080:8080 --env-file .env airbyte-mcp-http:latest
# In another terminal
npx @modelcontextprotocol/inspector
# Then connect to http://127.0.0.1:8080/mcp in the inspector UIRunning Manually (without a client)
If you just want to exercise the server from the CLI:
# stdio (uv)
uv run airbyte-mcp
# stdio (Docker)
docker run --rm -i --env-file .env airbyte-mcp:latest
# HTTP (uv)
uv run airbyte-mcp-http
# HTTP (Docker)
docker run --rm -p 8080:8080 --env-file .env airbyte-mcp-http:latestEnvironment Variables
Variable | Required | Default | Description |
| No |
| Airbyte API base URL |
| Yes* | — | Application client ID |
| Yes* | — | Application client secret |
| No | — | Pre-fetched token (skips exchange) |
| No |
| HTTP transport bind address |
| No |
| HTTP transport port |
*Not required if AIRBYTE_ACCESS_TOKEN is provided.
Documentation
Authentication — token exchange, credentials setup
Architecture — system design, package layout, token lifecycle
Endpoints Checklist — full Airbyte API coverage status
Local Setup — abctl installation walkthrough
Contributing — development workflow, PR guidelines
Security — vulnerability reporting
Changelog — release history
Contributing
Contributions are welcome! See docs/CONTRIBUTING.md to get started.
License
Apache-2.0 — see LICENSE for details.
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/trustxai/airbyte-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server