| name | configuring-dbt-mcp-server |
| description | Generates MCP server configuration JSON, resolves authentication setup, and validates server connectivity for dbt. Use when setting up, configuring, or troubleshooting the dbt MCP server for AI tools like Kilo, Cursor, VS Code, or Claude Desktop. |
| user-invocable | false |
| metadata | {"author":"dbt-labs"} |
Configure dbt MCP Server
Overview
The dbt MCP server connects AI tools to dbt's CLI, Semantic Layer, Discovery API, and Admin API. This skill guides users through setup with the correct configuration for their use case.
Decision Flow
flowchart TB
start([User wants dbt MCP]) --> q1{Local or Remote?}
q1 -->|dev workflows,<br>CLI access needed| local[Local Server<br>uvx dbt-mcp]
q1 -->|consumption only,<br>no local install| remote[Remote Server<br>HTTP endpoint]
local --> q2{Which client?}
remote --> q2
q2 --> kilo[Kilo]
q2 --> claude_desktop[Claude Desktop]
q2 --> cursor[Cursor]
q2 --> vscode[VS Code]
kilo --> config[Generate config<br>+ test setup]
claude_desktop --> config
cursor --> config
vscode --> config
Questions to Ask
1. Server Type
Ask: "Do you want to use the local or remote dbt MCP server?"
| Local Server | Remote Server |
|---|
Runs on your machine via uvx | Connects via HTTP to dbt platform |
| Required for development (authoring models, tests, docs) but can also connect to the dbt platform for consumption (querying metrics, exploring metadata) | Best for consumption (querying metrics, exploring metadata) |
| Supports dbt CLI commands (run, build, test, show) | No CLI commands (run, build, test) |
| Works without a dbt platform account but can also connect to the dbt platform for development (authoring models, tests, docs) | Requires dbt platform account |
| No credit consumption | Consumes dbt Copilot credits |
2. MCP Client
Ask: "Which MCP client are you using?"
- Kilo (CLI or VS Code extension)
- Claude Desktop
- Cursor
- VS Code
3. Use Case (Local Server Only)
Ask: "What's your use case?"
| CLI Only | Platform Only | Platform + CLI |
|---|
| dbt Core/Fusion users | dbt Cloud without local project | Full access to both |
| No platform account needed | OAuth or token auth | Requires paths + credentials |
4. Tools to Enable
Ask: "Which tools do you want enabled?" (show defaults)
| Tool Category | Default | Environment Variable |
|---|
| dbt CLI (run, build, test, compile) | Enabled | DISABLE_DBT_CLI=true to disable |
| Semantic Layer (metrics, dimensions) | Enabled | DISABLE_SEMANTIC_LAYER=true to disable |
| Discovery API (models, lineage) | Enabled | DISABLE_DISCOVERY=true to disable |
| Admin API (jobs, runs) | Enabled | DISABLE_ADMIN_API=true to disable |
| SQL (text_to_sql, execute_sql) | Disabled | DISABLE_SQL=false to enable |
| Codegen (generate models/sources) | Disabled | DISABLE_DBT_CODEGEN=false to enable |
Prerequisites
Local Server
- Install
uv: https://docs.astral.sh/uv/getting-started/installation/
- Have a dbt project (for CLI commands)
- Find paths:
DBT_PROJECT_DIR: Folder containing dbt_project.yml
- macOS/Linux:
pwd from project folder
- Windows: Full path with forward slashes (e.g.,
C:/Users/name/project)
DBT_PATH: Path to dbt executable
- macOS/Linux:
which dbt
- Windows:
where dbt
Remote Server
- dbt Cloud account with AI features enabled
- Production environment ID (from Orchestration page)
- Personal access token or service token
See How to Find Your Credentials for detailed guidance on obtaining tokens and IDs.
Credential Security
- Always use environment variable references (e.g.,
${DBT_TOKEN}) instead of literal token values in configuration files that may be committed to version control
- Never log, display, or echo token values in terminal output
- When using
.env files, ensure they are added to .gitignore to prevent accidental commits
- Recommend users rotate tokens regularly and use the minimum required permission set
Configuration Templates
Local Server - CLI Only
{
"mcpServers": {
"dbt": {
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_PROJECT_DIR": "/path/to/your/dbt/project",
"DBT_PATH": "/path/to/dbt"
}
}
}
}
Local Server - Platform + CLI (OAuth)
{
"mcpServers": {
"dbt": {
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_HOST": "https://your-subdomain.us1.dbt.com",
"DBT_PROJECT_DIR": "/path/to/project",
"DBT_PATH": "/path/to/dbt"
}
}
}
}
Local Server - Platform + CLI (Token Auth)
{
"mcpServers": {
"dbt": {
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_HOST": "cloud.getdbt.com",
"DBT_TOKEN": "your-token",
"DBT_ACCOUNT_ID": "your-account-id",
"DBT_PROD_ENV_ID": "your-prod-env-id",
"DBT_PROJECT_DIR": "/path/to/project",
"DBT_PATH": "/path/to/dbt"
}
}
}
}
Local Server - Using .env File
{
"mcpServers": {
"dbt": {
"command": "uvx",
"args": ["--env-file", "/path/to/.env", "dbt-mcp"]
}
}
}
.env file contents:
DBT_HOST=cloud.getdbt.com
DBT_TOKEN=your-token
DBT_ACCOUNT_ID=your-account-id
DBT_PROD_ENV_ID=your-prod-env-id
DBT_DEV_ENV_ID=your-dev-env-id
DBT_USER_ID=your-user-id
DBT_PROJECT_DIR=/path/to/project
DBT_PATH=/path/to/dbt
Remote Server
{
"mcpServers": {
"dbt": {
"url": "https://cloud.getdbt.com/api/ai/v1/mcp/",
"headers": {
"Authorization": "Token your-token",
"x-dbt-prod-environment-id": "your-prod-env-id"
}
}
}
}
Additional headers for SQL/Fusion tools:
{
"headers": {
"Authorization": "Token your-token",
"x-dbt-prod-environment-id": "your-prod-env-id",
"x-dbt-dev-environment-id": "your-dev-env-id",
"x-dbt-user-id": "your-user-id"
}
}
Client-Specific Setup
Claude Desktop
- Click Claude menu in system menu bar (not in-app)
- Select Settings...
- Go to Developer tab
- Click Edit Config
- Add the JSON configuration
- Save and restart Claude Desktop
- Verify: Look for MCP server indicator in bottom-right of input box
Config location:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
- Windows:
%APPDATA%\Claude\claude_desktop_config.json
Kilo
Add the mcp block to your kilo.json config file.
Config locations:
- Global:
~/.config/kilo/kilo.json
- Project:
./kilo.json or ./.kilo/kilo.json in your project root
Project-level configuration takes precedence over global settings. For project-specific dbt setups, use .kilo/kilo.json so your team shares the same configuration.
Add the dbt MCP server under the mcp key:
{
"mcp": {
"dbt": {
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_PROJECT_DIR": "/path/to/project",
"DBT_PATH": "/path/to/dbt"
}
}
}
}
VS Code Extension: Open Kilo Settings > Agent Behaviour > MCP Servers, then click "Edit Global MCP" (or "Edit Project MCP" for project-specific config) and add the config above.
Cursor
- Open Cursor menu → Settings → Cursor Settings → MCP
- Add the JSON configuration
- Update paths and credentials
- Save
VS Code
- Open Command Palette (Cmd/Ctrl + Shift + P)
- Run "MCP: Open User Configuration" (or Workspace for project-specific)
- Add the JSON configuration (note: VS Code uses
servers not mcpServers):
{
"servers": {
"dbt": {
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_PROJECT_DIR": "/path/to/project",
"DBT_PATH": "/path/to/dbt"
}
}
}
}
- Open Settings → Features → Chat → Enable MCP
- Verify: Run "MCP: List Servers" from Command Palette
WSL Users: Configure in Remote settings, not local user settings:
- Run "Preferences: Open Remote Settings" from Command Palette
- Use full Linux paths (e.g.,
/home/user/project, not Windows paths)
Verification Steps
Test Local Server Config
Recommended: Use .env file
- Create a .env file in your project root directory and add minimum environment variables for the CLI tools:
DBT_PROJECT_DIR=/path/to/project
DBT_PATH=/path/to/dbt
- Test the server:
uvx --env-file .env dbt-mcp
Alternative: Environment variables
export DBT_PROJECT_DIR=/path/to/project
export DBT_PATH=/path/to/dbt
uvx dbt-mcp
No errors = successful configuration.
Verify in Client
After setup, ask the AI:
- "What dbt tools do you have access to?"
- "List my dbt metrics" (if Semantic Layer enabled)
- "Show my dbt models" (if Discovery enabled)
See Troubleshooting for common issues and fixes.
See Environment Variable Reference for the full list of supported variables.