Malloy MCP Server
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., "@Malloy MCP Serverrun a malloy query to get top users by spending"
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.
Malloy MCP Server
An MCP server implementation for executing Malloy queries and managing Malloy resources.
Features
Execute Malloy queries via MCP
Access Malloy project, package, and model metadata
Robust error handling with detailed context
Comprehensive test coverage
Type-safe implementation
Related MCP server: Snowflake Cube Server
Installation
# Install using uv (recommended)
uv pip install malloy-mcp-server
# Or using pip
pip install malloy-mcp-serverUsage
Starting the Server
from malloy_mcp_server import mcp
# Run the server
if __name__ == "__main__":
mcp.serve()Configuration
The server can be configured using environment variables:
Variable | Description | Default |
| URL of the Malloy Publisher API |
|
Example:
# Set the publisher URL
export MALLOY_PUBLISHER_ROOT_URL="http://malloy-publisher:4000"
# Run with custom configuration
python -m malloy_mcp_serverExecuting Queries
The server provides an MCP tool for executing Malloy queries:
from malloy_mcp_server import ExecuteMalloyQueryTool
# Example query execution
result = await ExecuteMalloyQueryTool(
query="select * from users",
model_path="my_package/users"
)Accessing Resources
The server provides the following resource endpoints:
malloy://project/home/metadata- Project metadatamalloy://project/home/package/{package_name}- Package metadatamalloy://project/home/model/{model_path}- Model metadata
Development
Setup
Clone the repository:
git clone https://github.com/namabile/malloy-mcp-server.git
cd malloy-mcp-serverInstall dependencies:
uv pip install -e ".[dev]"Running Tests
# Run all tests
pytest
# Run with coverage
pytest --cov=malloy_mcp_serverCode Quality
The project uses:
blackfor code formattingmypyfor type checkingrufffor linting
Run quality checks:
black .
mypy .
ruff check .Error Handling
The server provides detailed error handling with context:
from malloy_mcp_server.errors import QueryExecutionError
try:
result = await ExecuteMalloyQueryTool(...)
except QueryExecutionError as e:
print(f"Error: {e.message}")
print("Context:", e.context)Architecture
The server is built on:
FastMCP for the MCP server implementation
Malloy Publisher Client for Malloy interactions
Pydantic for data validation
Key components:
server.py- Core server implementationtools/query_executor.py- Query execution toolerrors.py- Error handling utilities
Contributing
Fork the repository
Create a feature branch
Make your changes
Add tests for new functionality
Submit a pull request
License
MIT License - see LICENSE file for details
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/namabile/malloy-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server