music21-mcp-server
Provides Discord webhook integration for real-time notifications on CI/CD pipeline status, pull requests, and releases.
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., "@music21-mcp-serveranalyze the key of Bach chorale BWV 66.6"
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.
Music21 Analysis - Multi-Interface Music Server
Professional music analysis with 4 different interfaces - MCP server, HTTP API, CLI tools, and Python library. Built on the powerful music21 library with protocol-independent architecture for maximum reliability.
๐ฏ Why Multiple Interfaces?
Based on 2025 research showing MCP has 40-50% production success rate, this project provides multiple pathways to the same powerful music21 analysis functionality:
๐ก MCP Server - For Claude Desktop integration (when it works)
๐ HTTP API - For web applications (reliable backup)
๐ป CLI Tools - For automation (always works)
๐ Python Library - For direct programming access
๐ต Core Music Analysis Features
Analysis Tools (13 Available)
Import & Export: MusicXML, MIDI, ABC, Lilypond, music21 corpus
Key Analysis: Multiple algorithms (Krumhansl, Aarden, Bellman-Budge)
Harmony Analysis: Roman numerals, chord progressions, cadence detection
Voice Leading: Parallel motion detection, voice crossing analysis
Pattern Recognition: Melodic, rhythmic, and harmonic patterns
Advanced Capabilities
Harmonization: Bach chorale and jazz style harmonization
Counterpoint: Species counterpoint generation (1-5)
Style Imitation: Learn and generate music in composer styles
Score Manipulation: Transposition, time stretching, orchestration
๐ Quick Start
Installation
Install from PyPI (Recommended)
# Install the package
pip install music21-mcp-server
# Start the server
music21-mcp # MCP server for Claude Desktop
music21-http # REST API at localhost:8000
music21-cli # Interactive CLI
music21-analysis mcp # Unified launcher (positional arg)Install from Source
# Clone repository
git clone https://github.com/brightlikethelight/music21-mcp-server.git
cd music21-mcp-server
# Install with UV (recommended)
curl -LsSf https://astral.sh/uv/install.sh | sh
uv sync
# Or with pip
pip install .
# Configure music21 corpus
python -m music21.configureUsage - Pick Your Interface
๐ฏ Show All Available Interfaces
python -m music21_mcp.launcher๐ก MCP Server (for Claude Desktop)
# Start MCP server
python -m music21_mcp.launcher mcp
# Configure Claude Desktop with:
# ~/.config/claude-desktop/config.json
{
"mcpServers": {
"music21-analysis": {
"command": "python",
"args": ["-m", "music21_mcp.server_minimal"],
"env": {
"PYTHONPATH": "/path/to/music21-mcp-server/src"
}
}
}
}๐ HTTP API Server (for web apps)
# Start HTTP API server
python -m music21_mcp.launcher http
# Opens: http://localhost:8000
# API docs: http://localhost:8000/docs
# Example usage:
curl -X POST "http://localhost:8000/scores/import" \
-H "Content-Type: application/json" \
-d '{"score_id": "chorale", "source": "bach/bwv66.6", "source_type": "corpus"}'
curl -X POST "http://localhost:8000/analysis/key" \
-H "Content-Type: application/json" \
-d '{"score_id": "chorale"}'๐ป CLI Tools (for automation)
# Show CLI status
python -m music21_mcp.launcher cli status
# Import and analyze a Bach chorale
python -m music21_mcp.launcher cli import chorale bach/bwv66.6 corpus
python -m music21_mcp.launcher cli key-analysis chorale
python -m music21_mcp.launcher cli harmony chorale roman
# List all tools
python -m music21_mcp.launcher cli tools๐ Python Library (for programming)
from music21_mcp import create_sync_analyzer
# Create analyzer
analyzer = create_sync_analyzer()
# Import and analyze
analyzer.import_score("chorale", "bach/bwv66.6", "corpus")
key_result = analyzer.analyze_key("chorale")
harmony_result = analyzer.analyze_harmony("chorale", "roman")
print(f"Key: {key_result}")
print(f"Harmony: {harmony_result}")
# Quick comprehensive analysis
analysis = analyzer.quick_analysis("chorale")๐งช Testing & Development
Run Tests
# Run all tests
python -m pytest tests/ -v
# Run with coverage threshold
python -m pytest tests/ --cov=src/music21_mcp --cov-fail-under=82Development Setup
# Install development dependencies
uv sync --dev
# Set up pre-commit hooks
pre-commit install
# Run linting
ruff check src/
ruff format src/
# Type checking
mypy src/๐๏ธ Architecture
Protocol-Independent Design
Core Value Layer:
โโโ services.py # Music21 analysis service (protocol-independent)
โโโ tools/ # 13 music analysis tools
Protocol Adapter Layer:
โโโ adapters/mcp_adapter.py # MCP protocol isolation
โโโ adapters/http_adapter.py # HTTP/REST API
โโโ adapters/cli_adapter.py # Command-line interface
โโโ adapters/python_adapter.py # Direct Python access
Unified Entry Point:
โโโ launcher.py # Single entry point for all interfacesDesign Philosophy
Core Value First: Music21 analysis isolated from protocol concerns
Protocol Apocalypse Survival: Works even when MCP fails (30-40% of time)
Multiple Escape Hatches: Always have a working interface
Reality-Based: Built for today's MCP ecosystem, not enterprise dreams
๐ Interface Reliability
Interface | Success Rate | Best For |
MCP | 40-50% | AI assistant integration |
HTTP | 95%+ | Web applications |
CLI | 99%+ | Automation & scripting |
Python | 99%+ | Direct programming |
๐ Documentation
docs/architecture.md - System architecture overview
docs/getting-started.md - Quick start guide
examples/ - Working code examples
API Docs: http://localhost:8000/docs (when HTTP server running)
Discord Webhook Integration
.github/webhook-config.md - Complete Discord webhook setup guide
docs/webhook-integration.md - Advanced webhook configuration
scripts/test-webhook.sh - Test webhook connectivity
scripts/setup-webhook.sh - Automated webhook setup
๐ง Configuration
Environment Variables
# Server host and port (used by HTTP adapter and launcher)
export MUSIC21_MCP_HOST=127.0.0.1
export MUSIC21_MCP_PORT=8000
# Operation timeouts (seconds)
export MUSIC21_MCP_TIMEOUT=30 # General async operation timeout
export MUSIC21_TOOL_TIMEOUT=30 # Per-tool execution timeout
export MUSIC21_CHORD_ANALYSIS_TIMEOUT=60 # Chord analysis timeout
export MUSIC21_BATCH_TIMEOUT=30 # Batch processing timeout
# CORS origins for HTTP adapter (comma-separated)
export MUSIC21_CORS_ORIGINS="http://localhost:*"Music21 Setup
# Configure corpus path (one-time setup)
python -m music21.configure๐ ๏ธ Available Analysis Tools
import_score - Import from corpus, files, URLs
list_scores - List all imported scores
get_score_info - Detailed score information
export_score - Export to MIDI, MusicXML, etc.
delete_score - Remove scores from storage
analyze_key - Key signature analysis
analyze_chords - Chord progression analysis
analyze_harmony - Roman numeral/functional harmony
analyze_voice_leading - Voice leading quality analysis
recognize_patterns - Melodic/rhythmic patterns
harmonize_melody - Automatic harmonization
generate_counterpoint - Counterpoint generation
imitate_style - Style imitation and generation
๐ Quick Examples
Analyze a Bach Chorale
# CLI approach
python -m music21_mcp.launcher cli import chorale bach/bwv66.6 corpus
python -m music21_mcp.launcher cli key-analysis chorale
# Python approach
analyzer = create_sync_analyzer()
analyzer.import_score("chorale", "bach/bwv66.6", "corpus")
print(analyzer.analyze_key("chorale"))Start Services
# For Claude Desktop
python -m music21_mcp.launcher mcp
# For web development
python -m music21_mcp.launcher http
# For command-line work
python -m music21_mcp.launcher cli status๐ Migration from v1.0
The previous enterprise version has been simplified for reliability:
โ Kept: All music21 analysis functionality
โ Added: HTTP API, CLI, Python library interfaces
โ Removed: Docker, K8s, complex auth, monitoring (too unstable for MCP ecosystem)
๐ Changed: Focus on core value delivery through multiple interfaces
๐ Discord Webhook Integration
Get real-time notifications for CI/CD pipeline status, pull requests, and releases:
๐ Webhook Setup Guide
๐ ๏ธ Quick Setup Script
๐งช Test Your Webhook
๐ค Contributing
We welcome contributions! Please see our Contributing Guide for details on:
Development setup and requirements
Code style guidelines (Ruff, MyPy)
Testing requirements (maintain >82% coverage)
Pull request process
Branch protection rules
Quick start:
Fork the repository
Create feature branch:
git checkout -b feature/amazing-featureRun tests:
pytest tests/ --cov=src/music21_mcp --cov-fail-under=82Commit changes:
git commit -m 'feat: Add amazing feature'Push branch:
git push origin feature/amazing-featureSubmit pull request
๐ License
MIT License - see LICENSE file for details.
๐ Acknowledgments
Built on the excellent music21 library
Uses FastMCP for MCP protocol support
Inspired by the need for reliable music analysis tools
Choose the interface that works for you. All provide the same powerful music21 analysis capabilities! ๐ต
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/brightlikethelight/music21-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server