ADLS2 MCP Server 🚀
Microsoft Azure Data Lake Storage MCP Server
erikhoward
README
ADLS2 MCP Server 🚀
A Model Context Protocol (MCP) server implementation for Azure Data Lake Storage Gen2. This service provides a standardized interface for interacting with ADLS2 storage, enabling file operations through MCP tools.
Setup 🛠️
Installation 📦
Requires Python 3.13 or higher.
Install the package using uv
:
uv pip install adls2-mcp-server
MCP Configuration ⚙️
Claude Desktop Configuration
1 - Edit Claude Desktop Configuration:
Open claude_desktop_config.json
and add the following configuration.
On MacOs, the file is located here:
~/Library/Application Support/Claude Desktop/claude_desktop_config.json
.
On Windows, the file is located here:
%APPDATA%\Claude Desktop\claude_desktop_config.json
.
{
"mcpServers": {
"adls2": {
"command": "adls2-mcp-server",
"env": {
"LOG_LEVEL": "DEBUG",
"UPLOAD_ROOT": "/path/to/store/uploads",
"DOWNLOAD_ROOT": "/path/to/store/downloads",
"AZURE_STORAGE_ACCOUNT_NAME": "your-azure-adls2-storage-account-name",
"READ_ONLY_MODE": "false"
}
}
}
}
The following is a table of available environment configuration variables:
Variable | Description | Default |
---|---|---|
LOG_LEVEL |
Logging level | INFO |
UPLOAD_ROOT |
Root directory for file uploads | ./uploads |
DOWNLOAD_ROOT |
Root directory for file downloads | ./downloads |
AZURE_STORAGE_ACCOUNT_NAME |
Azure ADLS2 storage account name | None |
AZURE_STORAGE_ACCOUNT_KEY |
Azure ADLS2 storage account key (optional) | None |
READ_ONLY_MODE |
Whether the server should operate in read-only mode | true |
If AZURE_STORAGE_ACCOUNT_KEY
is not set, the server will attempt to authenticate using Azure CLI credentials. Ensure you have logged in with Azure CLI before running the server:
az login
2 - Restart Claude Desktop.
Available Tools 🔧
Filesystem (container) Operations
list_filesystems
- List all filesystems in the storage accountcreate_filesystem
- Create a new filesystemdelete_filesystem
- Delete an existing filesystem
File Operations
upload_file
- Upload a file to ADLS2download_file
- Download a file from ADLS2file_exists
- Check if a file existsrename_file
- Rename/move a fileget_file_properties
- Get file propertiesget_file_metadata
- Get file metadataset_file_metadata
- Set file metadataset_file_metadata_json
- Set multiple metadata key-value pairs using JSON
Directory Operations
create_directory
- Create a new directorydelete_directory
- Delete a directoryrename_directory
- Rename/move a directorydirectory_exists
- Check if a directory existsdirectory_get_paths
- Get all paths under the specified directory
Development 💻
Local Development Setup
1 - Clone the repository:
git clone https://github.com/erikhoward/adls2-mcp-server.git
cd adls2-mcp-server
2 - Create and activate virtual environment:
Linux/macOS:
python -m venv .venv
source .venv/bin/activate
Windows:
.venv\Scripts\activate
3 - Install dependencies:
uv pip install -e ".[dev]"
4 - Copy and configure environment variables:
cp .env.example .env
Edit .env with your settings.
AZURE_STORAGE_ACCOUNT_NAME=your_azure_adls2_storage_account_name
AZURE_STORAGE_ACCOUNT_KEY=your_azure_adls2_storage_key (optional)
DOWNLOAD_ROOT=/path/to/download/folder
UPLOAD_ROOT=/path/to/upload/folder
READ_ONLY_MODE=True
LOG_LEVEL=INFO
If AZURE_STORAGE_ACCOUNT_KEY
is not set, the server will attempt to authenticate using Azure CLI credentials. Ensure you have logged in with Azure CLI before running the server:
az login
5 - Claude Desktop Configuration
Open claude_desktop_config.json
and add the following configuration.
On MacOs, the file is located here:
~/Library/Application Support/Claude Desktop/claude_desktop_config.json
.
On Windows, the file is located here:
%APPDATA%\Claude Desktop\claude_desktop_config.json
.
{
"mcpServers": {
"adls2": {
"command": "uv",
"args": [
"--directory",
"/path/to/adls2-mcp-server/repo",
"run",
"adls2-mcp-server"
],
"env": {
"LOG_LEVEL": "DEBUG",
"UPLOAD_ROOT": "/path/to/store/uploads",
"DOWNLOAD_ROOT": "/path/to/store/downloads",
"AZURE_STORAGE_ACCOUNT_NAME": "your-azure-adls2-storage-account-name",
"READ_ONLY_MODE": "false"
}
}
}
}
6 - Restart Claude Desktop.
Contributions 🤝
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/AmazingFeature
) - Commit your changes (
git commit -m '✨ Add some AmazingFeature'
) - Push to the branch (
git push origin feature/AmazingFeature
) - Open a Pull Request
License ⚖️
Licensed under MIT - see LICENSE.md file.
This is not an official Microsoft product.
Recommended Servers
Google Drive MCP Server
Enables integration with Google Drive for listing, reading, and searching over files, supporting various file types with automatic export for Google Workspace files.

AWS MCP Server
A Model Context Protocol server implementation that enables Claude to perform AWS operations on S3 and DynamoDB services through natural language commands.
mcp-gsuite
MCP server to interact with Google produts.

Filesystem MCP Server
A Model Context Protocol server that provides file system operations, analysis, and manipulation capabilities through a standardized tool interface.
Google Drive MCP Server
Integrates with Google Drive to enable listing, searching, and reading files, plus reading and writing to Google Sheets.

MCP TODO Checklist Server
A server that implements a checklist management system with features like task creation, progress tracking, data persistence, and item comments.

s3-tools
An MCP server that provides tools for interacting with AWS S3 buckets, enabling direct access to S3 operations through the Model Context Protocol.
Azure MCP Server
This server implements the Model Context Protocol for seamless interaction with Azure Blob Storage and Cosmos DB, enabling automatic logging and audit tracking of operations.
Box MCP Server
The Box MCP Server facilitates searching and reading PDF and Word files in Box using Developer Token authentication.
MCP JSON Document Collection Server
A Model Context Protocol server that allows creation and management of multiple Fireproof JSON databases with CRUD operations, querying capabilities, and cloud synchronization for sharing databases with others.