OpenTelemetry Instrumentation MCP Server
Project description
OpenTelemetry MCP Server
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.
Why use this?
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
Features
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
Security Notice
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.
Quick Start
Prerequisites
- Python 3.13+
- uv package manager
- GitHub authentication (Personal Access Token or GitHub App credentials)
Installation
- 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-mcp
Local Development
For 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 checks
Usage Examples
Configuration with AI Assistants
Claude Desktop
Add 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
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.
Windsurf or Cursor
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"
}
}
}
}
Testing and Development
MCP Inspector
npx @modelcontextprotocol/inspector uv run otel-instrumentation-mcp
Using HTTP/SSE Transports (Remote Access)
For 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.
Real-World Example: Instrumenting Your Code
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]
Production Deployment
Kubernetes
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
Configuration
Environment Variables
| 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 |
GitHub Authentication
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
Development
Running Tests
# 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
Linting and Formatting
# Run all checks
task checks
# Format code
task lint
Development Server
# Start with hot reload
task dev
# Custom port
SERVICE_PORT=3000 task dev
Observability
The 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.
Architecture
- 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)
Roadmap
Coming Soon
- 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.
Known Limitations
- 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.
Contributing
We welcome contributions! Please submit issues and pull requests on GitHub. See CONTRIBUTING.md to get started.
License
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.
Support
- Issues: GitHub Issues
- Discussions: GitHub Discussions
Notice of Attribution
This is a derived worked from @sgsharma's original otel-instrumentation-mcp at this commit.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file iflow_mcp_liatrio_labs_otel_instrumentation_mcp-0.5.0.tar.gz.
File metadata
- Download URL: iflow_mcp_liatrio_labs_otel_instrumentation_mcp-0.5.0.tar.gz
- Upload date:
- Size: 62.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d1c2f7ace06339cdf0dc070edc2356df46e1cef8602e69a3d93569d5fd69ec43
|
|
| MD5 |
4312fcbd82a78199d922f4adde031fce
|
|
| BLAKE2b-256 |
c04cdca33073ef2635c1fe0e3757b66da046dc1786444c9b0ffca457d4a954af
|
File details
Details for the file iflow_mcp_liatrio_labs_otel_instrumentation_mcp-0.5.0-py3-none-any.whl.
File metadata
- Download URL: iflow_mcp_liatrio_labs_otel_instrumentation_mcp-0.5.0-py3-none-any.whl
- Upload date:
- Size: 69.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ab47594ca19e3fe00e36a5577f4cef43eb74ed9f0413fecb28bc5bc8ef113309
|
|
| MD5 |
1d09a48e936c058847f9ea268ddfcdb7
|
|
| BLAKE2b-256 |
36949d5f532ce01b36a58731b313564077c6b23be01d43b2b4dfb4fa98e6bad1
|