nyang64/databricks-mcp-server
If you are the rightful owner of databricks-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
This MCP server provides tools for interacting with Databricks clusters, jobs, and workspace operations, built as a learning exercise to understand the MCP protocol.
Databricks MCP Server - A Learning Implementation
This MCP (Model Context Protocol) server provides tools for interacting with Databricks clusters, jobs, and workspace operations. Built as a learning exercise to understand the MCP protocol with minimal dependencies, this implementation manually handles the protocol specification rather than relying on the official MCP SDK.
The server demonstrates how to implement MCP protocol compliance from scratch, making it an educational example for understanding the underlying protocol mechanics while delivering practical Databricks functionality.
It was tested on my macbook with claude desktop (0.13.19) and my personal databricks account. See a screenshot of this mcp server working: I was able to list my workspace sub folders correctly via claude desktop -> this databricks mcp server -> my databricks worksapce. Screenshot 2025-09-22 at 8.04.05 PM.png
Features
**Full compatibility with MCP clients using protocol version 2024-11-05
**Lightweight architecture with direct JSON-RPC 2.0 implementation
**Python 3.8+ compatibility for broader environment support
**Comprehensive Databricks integration without external MCP libraries
This MCP server provides the following tools:
- databricks_test_connection: Test connection to Databricks workspace
- databricks_list_clusters: List all clusters in the workspace
- databricks_get_cluster: Get detailed information about a specific cluster
- databricks_list_jobs: List all jobs in the workspace
- databricks_run_job: Run a Databricks job with optional parameters
- databricks_get_job_run: Get details about a specific job run
- databricks_execute_sql: Execute SQL queries (placeholder implementation)
- databricks_list_workspace: List contents of the Databricks workspace
Prerequisites
- Python 3.8 or higher
- A Databricks workspace with appropriate permissions
- A Databricks Personal Access Token
Installation
- Clone or download this repository
- Install the required dependencies:
pip install -r requirements.txt
Configuration
- Copy the example configuration file:
cp config.example.env .env
- Edit the
.env
file with your Databricks credentials:
DATABRICKS_HOST=https://your-workspace.cloud.databricks.com
DATABRICKS_TOKEN=your_personal_access_token_here
DATABRICKS_WORKSPACE_ID=your_workspace_id_here
Getting Your Databricks Credentials
- Host URL: Your Databricks workspace URL (e.g.,
https://adb-1234567890123456.7.azuredatabricks.net
) - Personal Access Token:
- Go to User Settings > Developer > Access Tokens
- Click "Generate new token"
- Give it a name and expiration date
- Copy the generated token
- Workspace ID (optional): Usually not needed for personal access tokens
Usage
Running the MCP Server
Run the simple server directly:
python mcp_server_simple.py
Using with MCP Clients
The server can be used with any MCP-compatible host. Here's an example configuration for Claude Desktop:
{
"mcpServers": {
"databricks": {
"command": "python",
"args": ["/path/to/mcp_server_simple.py"],
"env": {
"DATABRICKS_HOST": "https://your-workspace.cloud.databricks.com",
"DATABRICKS_TOKEN": "your_personal_access_token_here",
"DATABRICKS_WORKSPACE_ID": "your_workspace_id"
}
}
}
}
Available Tools
Test Connection
{
"name": "databricks_test_connection",
"arguments": {}
}
List Clusters
{
"name": "databricks_list_clusters",
"arguments": {}
}
Get Cluster Details
{
"name": "databricks_get_cluster",
"arguments": {
"cluster_id": "1234-567890-abcdef"
}
}
List Jobs
{
"name": "databricks_list_jobs",
"arguments": {}
}
Run Job
{
"name": "databricks_run_job",
"arguments": {
"job_id": "1234567890",
"parameters": {
"param1": "value1",
"param2": "value2"
}
}
}
Get Job Run Details
{
"name": "databricks_get_job_run",
"arguments": {
"run_id": "1234567890"
}
}
List Workspace Contents
{
"name": "databricks_list_workspace",
"arguments": {
"path": "/Users/your-email@domain.com"
}
}
Security Considerations
- Never commit your
.env
file to version control - Use environment variables for production deployments
- Regularly rotate your Databricks Personal Access Tokens
- Ensure your token has minimal required permissions
Troubleshooting
Common Issues
-
Connection Failed:
- Verify your
DATABRICKS_HOST
URL is correct - Check that your Personal Access Token is valid and not expired
- Ensure your workspace allows API access
- Verify your
-
Permission Denied:
- Verify your token has appropriate permissions
- Check that you have access to the clusters/jobs you're trying to interact with
-
Import Errors:
- Make sure all dependencies are installed:
pip install -r requirements.txt
- Check Python version compatibility
- Make sure all dependencies are installed:
Debug Mode
To enable debug logging, set the environment variable:
export PYTHONPATH=.
export LOG_LEVEL=DEBUG
python mcp_server_simple.py
Common Issues
Python Path Issues (spawn python ENOENT)
If you get spawn python ENOENT
errors in Claude Desktop, it means Claude Desktop can't find the python
command. This commonly happens with conda/virtual environments.
Solution: Use the full path to your Python executable in the Claude Desktop config:
{
"mcpServers": {
"databricks": {
"command": "/full/path/to/your/python",
"args": ["/path/to/mcp_server_simple.py"],
"env": {
"DATABRICKS_HOST": "https://your-workspace.cloud.databricks.com",
"DATABRICKS_TOKEN": "your_personal_access_token_here"
}
}
}
}
Find your Python path with:
which python
# or
which python3
Contributing
Feel free to submit issues and enhancement requests! contact nyang63@gmail.com
License
You are free to use it any way you would like to, but I do not assume any and all responsibility for any adverse effect.