A Model Context Protocol (MCP) server that bridges AI coding assistants (like ClaudeCode, OpenCode, Windsurf, and Cursor) with the OpenTelemetry ecosystem. It provides real-time access to OpenTelemetry repositories, documentation, examples, semantic conventions, and the instrumentation score specification to help engineers implement high-quality observability in their applications.
OpenTelemetry has extensive documentation and many implementation patterns. This MCP server helps AI assistants:
- Navigate the complexity of OpenTelemetry documentation
- Provide accurate, up-to-date instrumentation code
- Follow best practices and semantic conventions
- Generate instrumentation that scores qualitatively high
- Avoid common pitfalls and anti-patterns
The MCP server provides tools and prompts to help AI assistants with OpenTelemetry tasks:
- Repository & Issue Access - Browse OpenTelemetry repositories and search issues
- Examples & Documentation - Language-specific examples and documentation
- Semantic Conventions - Access to standardized attribute definitions
- Instrumentation Scoring - Evaluate telemetry quality based on best practices
- AI Prompts - Analyze code and generate instrumentation suggestions
Additional capabilities:
- Self-Instrumented - Full distributed tracing with OpenTelemetry
- Multi-Transport - Supports stdio (local), HTTP, and SSE protocols
- Production Ready - Kubernetes manifests, health checks, graceful shutdown
- GitHub Integration - Authenticated API access via GitHub App or Personal Access Token
Currently supported authentication methods:
- GitHub Personal Access Token (PAT) - For individual, local use.
- GitHub App - For hosted deployments.
IMPORTANT: OAuth support is planned for future implementations. Ensure your credentials are properly secured and never commit them to version control.
- Python 3.13+
- uv package manager
- GitHub authentication (Personal Access Token or GitHub App credentials)
- Clone the repository:
git clone https://github.com/liatrio/otel-instrumentation-mcp.git
cd otel-instrumentation-mcp- Install dependencies:
uv sync- Set up GitHub authentication (choose one):
Option A: Personal Access Token
export GITHUB_TOKEN="github_pat_..."Option B: GitHub App (recommended for production)
export GITHUB_APP_ID="123456"
export GITHUB_INSTALLATION_ID="654321"
export GITHUB_APP_PRIVATE_KEY_PATH="/path/to/private-key.pem"NOTE: Additional environment variables can be set, like the
OTEL_EXPORTER_OTLP_ENDPOINT. For a list of available environment variables, see .env.examples
- Run the MCP server:
uv run otel-instrumentation-mcpFor development with hot reload and local Kubernetes:
# Install development dependencies
task install
# Run with Tilt (includes local Kubernetes, OpenTelemetry Collector, hot reload)
tilt up
# Or run development server standalone with hot reload
task dev
# Run tests
task test
# Run linting and formatting
task lint
# Run all checks (test + lint)
task checksAdd to your Claude Desktop configuration:
{
"mcpServers": {
"otel-instrumentation-mcp": {
"command": "uv",
"args": ["run", "otel-instrumentation-mcp"],
"cwd": "/path/to/otel-instrumentation-mcp",
"env": {
"GITHUB_TOKEN": "your_github_token"
}
}
}
}VS Code supports MCP servers through the GitHub Copilot extension (requires Copilot
Chat). Add to your workspace's .vscode/mcp.json file:
{
"servers": {
"otel-instrumentation-mcp": {
"command": "uv",
"args": ["run", "otel-instrumentation-mcp"],
"cwd": "/path/to/otel-instrumentation-mcp",
"env": {
"GITHUB_TOKEN": "your_github_token"
}
}
}
}Alternatively, add to your VS Code settings.json for global configuration:
{
"mcp": {
"servers": {
"otel-instrumentation-mcp": {
"command": "uv",
"args": ["run", "otel-instrumentation-mcp"],
"cwd": "/path/to/otel-instrumentation-mcp",
"env": {
"GITHUB_TOKEN": "your_github_token"
}
}
}
}
}Note: Ensure
uvis in your PATH or use the full path to theuvexecutable. After adding the configuration, reload VS Code and the MCP server should appear in Copilot Chat's available tools.
Add to your MCP configuration file:
{
"mcpServers": {
"otel-instrumentation-mcp": {
"command": "uv",
"args": ["run", "otel-instrumentation-mcp"],
"cwd": "/path/to/otel-instrumentation-mcp",
"env": {
"GITHUB_TOKEN": "your_github_token"
}
}
}
}npx @modelcontextprotocol/inspector uv run otel-instrumentation-mcpFor network-accessible deployments:
# HTTP Transport
SERVICE_PORT=8080 uv run otel-instrumentation-mcp
# Access at: http://localhost:8080/mcp/
# SSE Transport
MCP_TRANSPORT=sse MCP_PORT=8080 uv run otel-instrumentation-mcp
# Access at: http://localhost:8080/Note: Remote access currently requires GitHub authentication configured via environment variables. OAuth support for client authentication is coming soon.
Once configured, you can ask your AI assistant to help with OpenTelemetry instrumentation:
User: Help me add OpenTelemetry instrumentation to my Python Flask application
AI Assistant: I'll help you add OpenTelemetry instrumentation to your Flask
application. Let me first check the latest OpenTelemetry documentation and
examples for Python.
[Uses get_opentelemetry_docs_by_language tool]
[Uses get_opentelemetry_examples_by_language tool]
[Uses get_semantic_conventions tool]
Based on the latest OpenTelemetry documentation, here's how to properly
instrument your Flask application...
[Provides relatively accurate* up-to-date instrumentation code following best
practices]
The repository includes Kubernetes manifests with:
- Deployment with health checks and resource limits
- Service for internal communication
- OpenTelemetry Collector integration
- ConfigMaps for feature flags
- Support for different environments via the Kustomize overlay pattern (dev, local, prod)
# Example
kubectl apply -k manifests/overlays/prod| Variable | Description | Default |
|---|---|---|
SERVICE_NAME |
Service name for telemetry | otel-instrumentation-mcp-server |
SERVICE_VERSION |
Service version | 0.15.0 |
SERVICE_INSTANCE_ID |
Instance identifier | local |
SERVICE_PORT |
Port for HTTP transport (overrides MCP_PORT) | - |
MCP_TRANSPORT |
Transport type (stdio, http, sse) |
stdio |
MCP_HOST |
Host binding for HTTP/SSE | Auto-detected |
MCP_PORT |
Port for HTTP/SSE transport | 8080 |
OTEL_EXPORTER_OTLP_ENDPOINT |
OTLP collector endpoint | http://localhost:4317 |
Choose one authentication method:
GitHub App (Recommended):
GITHUB_APP_ID- GitHub App IDGITHUB_INSTALLATION_ID- Installation IDGITHUB_APP_PRIVATE_KEY_PATH- Path to private key
Personal Access Token:
GITHUB_TOKEN- GitHub personal access token
# Run all tests
task test
# Run specific test
task test-single -- tests/test_main.py::test_list_opentelemetry_repos_tool
# Run with coverage
task test-coverage# Run all checks
task checks
# Format code
task lint# Start with hot reload
task dev
# Custom port
SERVICE_PORT=3000 task devThe MCP server is fully instrumented with OpenTelemetry, providing:
- Distributed tracing for MCP operations
- Custom semantic conventions for MCP and GenAI specific attributes
- Integration with standard OpenTelemetry collectors
- High instrumentation quality (measured with Instrumentation Score)
View traces in your preferred backend (Jaeger, Honeycomb, Datadog, Dash0, etc.)
by configuring OTEL_EXPORTER_OTLP_ENDPOINT.
- FastMCP Framework - Provides MCP protocol implementation
- OpenTelemetry SDK - Full observability with auto-instrumentation
- Async Python - High-performance async/await patterns
- GitHub GraphQL API - Efficient data fetching from repositories
- Multi-transport - Flexible deployment options (stdio, HTTP, SSE)
- OAuth Support - Full OAuth flow for MCP authentication
- Caching Layer - Native caching for GitHub API responses to improve performance
- Weaver Custom Semantic Conventions - Support for custom semantic convention registries through Weaver.
- OAuth flow for MCPs isn't implemented yet.
- GitHub API rate limits apply organizationally when self-hosting through an app.
- Currently optimized for OpenTelemetry repositories only.
We welcome contributions! Please submit issues and pull requests on GitHub. See CONTRIBUTING.md to get started.
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.
- Issues: GitHub Issues
- Discussions: GitHub Discussions
This is a derived worked from @sgsharma's original otel-instrumentation-mcp at this commit.