dbt-cloud-migrate
Audits dbt Core projects for migration blockers and provides actionable guidance for migrating to dbt Cloud, including profiles migration, project structure checks, and deprecated syntax fixes.
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., "@dbt-cloud-migratecheck my dbt project for migration blockers"
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.
dbt-cloud-migrate
A CLI tool and MCP server that audits dbt Core projects and generates actionable guidance for migrating to dbt Cloud. Designed to work alongside the official dbt MCP server.
How it fits with the dbt MCP server
Tool | Role |
dbt MCP server ( | Runs dbt commands ( |
dbt-cloud-migrate (this tool) | Audits your project for migration blockers: profiles config, structure issues, deprecated syntax |
The typical workflow is:
Run
check_projectorcheck_deprecationsto find migration issuesRun
fix_deprecationsto auto-fix safe changesUse the dbt MCP server's
compileorbuildtools to confirm the project still works
Related MCP server: openclaw-upgrade-orchestrator-mcp
What it checks
Profiles migration — analyzes
profiles.yml, maps adapter types to dbt Cloud connection types, flags hardcoded credentials, and generates recommendedDBT_ENV_SECRET_environment variable mappingsProject structure — checks model layer organization (staging/intermediate/marts), naming conventions (
stg_,int_,fct_,dim_), source YAML definitions, documentation coverage, primary key test coverage, and.gitignoresettingsDeprecated syntax — detects renamed
dbt_project.ymlkeys, legacytests:YAML keys, deprecateddbt_utilsmacros,env_var()calls without defaults, hardcodedtarget.namereferences, hardcoded 3-part database references, and unpinned packages
Each issue includes a severity level (ERROR, WARNING, INFO) and a concrete fix recommendation.
Installation
Requires Python 3.10+.
git clone <repo>
cd dbt-refactoring-tool
python3 -m venv .venv
.venv/bin/pip install -e .MCP Server Setup
Prerequisites
Install uv for the dbt MCP server:
curl -LsSf https://astral.sh/uv/install.sh | shClaude Code — add both servers
# Official dbt MCP server
claude mcp add dbt -s user -- uvx dbt-mcp
# Migration audit server (this tool)
claude mcp add dbt-cloud-migrate -s user -- dbt-cloud-migrate-mcpSet your project path for the dbt MCP server — edit ~/.claude.json and add env vars:
{
"mcpServers": {
"dbt": {
"type": "stdio",
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_PROJECT_DIR": "/path/to/your/dbt/project",
"DBT_PATH": "/path/to/dbt"
}
},
"dbt-cloud-migrate": {
"type": "stdio",
"command": "dbt-cloud-migrate-mcp"
}
}
}Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"dbt": {
"command": "uvx",
"args": ["dbt-mcp"],
"env": {
"DBT_PROJECT_DIR": "/path/to/your/dbt/project",
"DBT_PATH": "/path/to/dbt"
}
},
"dbt-cloud-migrate": {
"command": "dbt-cloud-migrate-mcp"
}
}
}Available MCP tools
dbt-cloud-migrate tools (this server):
Tool | Description |
| Run all migration checks and return a full JSON report |
| Analyze |
| Audit model organization, naming, sources, docs, and tests |
| Scan for deprecated syntax and configuration |
| Auto-fix deprecated keys and |
dbt MCP server tools (complement these with):
Tool | Description |
| Compile models to validate SQL after fixes |
| Run and test models end-to-end |
| Preview model output |
| Query the Semantic Layer |
CLI Usage
Run all checks
dbt-cloud-migrate check /path/to/your/dbt/projectRun from your project root:
cd ~/projects/my_dbt_project
dbt-cloud-migrate check .Output formats
# Rich terminal output (default)
dbt-cloud-migrate check . --output rich
# JSON — useful for CI or piping to other tools
dbt-cloud-migrate check . --output json
# Compact summary table
dbt-cloud-migrate check . --output summaryRun specific checks only
dbt-cloud-migrate check . --only profiles
dbt-cloud-migrate check . --only deprecations
dbt-cloud-migrate check . --only profiles,deprecationsAvailable check names: profiles, structure, deprecations
Profiles-only command
dbt-cloud-migrate profiles /path/to/projectAuto-fix deprecated syntax
Fix renamed dbt_project.yml keys and tests: → data_tests: in schema YAML files:
# Preview changes without modifying files
dbt-cloud-migrate fix . --dry-run
# Apply fixes
dbt-cloud-migrate fix .After fixing, validate with the dbt MCP server or CLI:
dbt compileVersion
dbt-cloud-migrate versionChecks reference
Profiles migration
Adapter → dbt Cloud connection type mapping (Snowflake, BigQuery, Databricks, Redshift, Postgres, and more)
Hardcoded sensitive fields (
password,token,private_key, etc.) that should useenv_var()Recommended
DBT_ENV_SECRET_variable names per adapterMultiple targets → separate dbt Cloud Environments guidance
profiles.ymlcommitted to the project directory (security risk)
Project structure
profiles.ymlinside the project repoMissing or incomplete
.gitignore(target/,dbt_packages/,profiles.yml,logs/)Missing
dbt_project.ymlor required keys (name,version,profile)SQL models in the root
models/directory (not organized into layers)Missing standard layer folders (
staging/,intermediate/,marts/)Naming convention violations (
stg_in staging,int_in intermediate,fct_/dim_in marts)No source YAML files in
models/staging/Models with no schema YAML entry or empty
descriptionPrimary key columns (
id,*_id,*_key,*_pk) missingunique+not_nulltests
Deprecated syntax
Renamed
dbt_project.ymlkeys:source-paths→model-paths,data-paths→seed-paths,modules-path→packages-install-pathconfig-version: 2no longer required (dbt 1.5+)Legacy
tests:key in schema YAML (should bedata_tests:in dbt 1.8+)version: 2in schema YAML files (no longer required in dbt 1.5+)Unpinned Hub packages (no
version) and unpinned Git packages (norevision)Deprecated
dbt_utilsmacros moved to dbt core (dbt_utils.surrogate_key,dbt_utils.current_timestamp, type macros, date macros)env_var()calls without a default value (will fail in Cloud if variable is unset){{ target.name }}usage (recommend environment variable approach in Cloud)Hardcoded 3-part
database.schema.tablereferences in SQL (should useref()orsource())
Exit codes
0— all checks passed1— one or more ERROR or WARNING issues found
This makes dbt-cloud-migrate check suitable for use in CI pipelines.
This server cannot be installed
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/BrJan/dbt-cloud-migration-tool'
If you have feedback or need assistance with the MCP directory API, please join our Discord server