A Model Context Protocol (MCP) server for executing Kusto Query Language (KQL) queries against Azure Data Explorer clusters. Seamlessly integrates with Claude Desktop and Visual Studio Code (VS Code). Supports Azure CLI authentication and provides a convenient kql_execute tool for execute KQL queries directly within your AI prompts, complete with optional visualizations.

- π Execute KQL Queries: Run KQL queries directly within your AI prompts using the
kql_executeMCP tool. - β‘ Plug-and-Play Simplicity: No manual tenant ID configuration or complex credential management. Simply authenticate via Azure CLI (
az login) and start querying immediately. - π€ Seamless Claude Integration: Execute KQL queries within Claude Desktop without switching interfaces or dashboards.
- π Secure and Efficient: Leverages Azure CLIβs robust authentication, ensuring secure credential handling and optimized query performance.
- π Visualization Ready: Optional Markdown table outputs make data analysis intuitive and engaging.
- π Azure CLI Authentication: Built-in Azure CLI authentication with retry and caching logic.
- π‘ Protocol Compatibility: Fully compatible with MCP protocol version
2024-11-05. - π οΈ Reliable Implementation: Uses
fastmcpfor a robust and reliable MCP server implementation.
| Feature | MCP KQL Server | Azure Data Explorer MCP | Standalone Scripts |
|---|---|---|---|
| Claude Integration | β | β | β |
| Plug-and-Play Authentication | β (Azure CLI) | β (Manual setup) | β (Custom code) |
| No Tenant ID Required | β | β | β |
| Data Visualization | β | β | β |
| Open-Source | β | β | Varies |
- Python 3.10 or higher
- Azure Data Explorer cluster access
- Azure CLI installed and authenticated (
az login) - Node.js (optional, for Claude Desktop filesystem server)
- VS Code with Claude extension or MCP client (for VS Code integration)
mcp-kql-server/
βββ mcp_kql_server/
β βββ __init__.py
β βββ mcp_server.py
β βββ kql_auth.py
β βββ execute_kql.py
βββ pyproject.toml
βββ README.md
git clone https://github.com/4R9UN/mcp-kql-server.git
cd mcp-kql-server- Windows:
winget install Python.Python.3.10
- macOS:
brew install python@3.10
- Linux:
sudo apt-get install python3.10
Verify installation:
python --version- Follow official instructions: Install Azure CLI
- Log in to Azure:
az config set core.login_experience_v2=off az login
python -m venv .venvActivate environment:
- Windows:
.venv\Scripts\activate
- macOS/Linux:
source .venv/bin/activate
pip install .-
Copy
claude_desktop_config.jsonto Claude's configuration directory:- Windows:
C:\Users\YourUser\AppData\Roaming\Claude\ - macOS:
/Users/YourUser/Library/Application Support/Claude/ - Linux: Currently not supported by Claude Desktop.
- Windows:
-
Update the configuration file with your Python path and project directory:
{
"mcpServers": {
"mcp-kql-server": {
"command": "C:\\Users\\YourUser\\mcp-kql-server\\.venv\\Scripts\\python.exe",
"args": [
"-m",
"mcp_kql_server.mcp_server"
]
}
}
}- Optional: Install Node.js for filesystem server support (Node.js).
- Restart Claude Desktop.
- Install VS Code.
- Install the
Copilot MCPclient extension. - Modify the MCP
settings.jsonwith the following configuration:
{
"mcpServers": {
"mcp-kql-server": {
"command": "C:\\Users\\YourUser\\mcp-kql-server\\.venv\\Scripts\\python.exe",
"args": [
"-m",
"mcp_kql_server.mcp_server"
],
"env": {
"PYTHONPATH": "C:\\Users\\YourUser\\Downloads\\mcp-kql-server",
"PYTHONUNBUFFERED": "1",
"AZURE_CORE_ONLY_SHOW_ERRORS": "true"
}
}
}
}- Run the
MCP: List Serverscommand in VS Codeβs Command Palette to verify setup. - Enable autodiscovery if using Claude Desktopβs configuration.
- Claude Desktop:
- Open Claude Desktop and provide the following prompt:
Use a tool to execute the attached KQL query, visualize the results, and provide high-level insights from the query output. KQL query: "cluster('mycluster').database('mydb').MyTable | take 10"
- Open Claude Desktop and provide the following prompt:
- Fork the repository.
- Create a feature branch:
git checkout -b feature/YourFeature
- Commit your changes:
git commit -m "Add YourFeature" - Push to your branch:
git push origin feature/YourFeature
- Open a Pull Request.
For issues or questions, please open a ticket on GitHub or contact the maintainer at
π Happy Querying!