selfhosted-sentry-mcp
MCP server for self-hosted Sentry instances, providing tools to query and triage issues and events, inspect stack frames, manage releases, and access raw Sentry API.
README
selfhosted-sentry-mcp
MCP server for self-hosted Sentry instances with debugging-focused tools.
Overview
This server provides MCP tools for querying and triaging issues and events in self-hosted Sentry.
Key capabilities:
- Issue and project listing with pagination and search.
- Event inspection with stack frame extraction.
- Grouping analysis via issue hashes.
- Debug symbol (dSYM) checks for iOS/macOS crashes.
- Raw Sentry API access for edge cases.
Quickstart
Prerequisites
- Node.js 20+
- Self-hosted Sentry instance
Getting Sentry Credentials
You need 3 environment variables from your Sentry instance:
1. SENTRY_URL
https://your-sentry-instance.com
The base URL of your self-hosted Sentry.
2. SENTRY_AUTH_TOKEN
- Go to Settings > Auth Tokens
- Click Create New Token
- Select scopes:
issue:read,project:read,event:read,issue:write,comment:write - Copy the token
3. SENTRY_ORG_SLUG
- Go to Settings > General in your organization
- Find Organization Slug (e.g.,
my-org) - Or check the URL:
https://your-sentry.com/organizations/[slug]/
Install
Option 1: Install from npm (recommended)
npm install -g selfhosted-sentry-mcp
Option 2: Install from source
git clone https://github.com/HieuAnh87/sentry-selfhosted-mcp.git
cd sentry-selfhosted-mcp
npm install
npm run build
Tools
24 tools available across 6 categories:
Issue Tools
| Tool | Purpose | Input |
|---|---|---|
get_sentry_issue |
Issue details by ID or URL | issue_id_or_url + optional filters |
list_sentry_projects |
List all projects in org | {} |
list_sentry_issues |
List issues in a project | project_slug + optional filters |
list_issues |
Search issues with Sentry query syntax | query, sort, limit, cursor |
update_sentry_issue_status |
Update issue status | issue_id, status |
create_sentry_issue_comment |
Add issue comment | issue_id, comment_text |
get_issue_hashes |
Get fingerprint hashes | issue_id, optional cursor |
bulk_update_issues |
Bulk resolve/ignore issues | project_slug + optional query, status, assigned_to, has_seen |
Event Tools
| Tool | Purpose | Input |
|---|---|---|
get_sentry_event_details |
Event details with entry filtering | project_slug, event_id |
list_issue_events |
List events for an issue | issue_id, optional limit, cursor, full |
list_error_events |
Search error events in a project | project_slug + optional filters |
get_stack_frames |
Extract structured stack frames | project_slug, event_id, in_app_only, max_frames |
check_dsym_status |
Check missing dSYM symbols | project_slug, optional event_id |
list_breadcrumbs |
Extract breadcrumbs from event | project_slug, event_id, optional limit, type |
Release Tools
| Tool | Purpose | Input |
|---|---|---|
list_releases |
List releases in org | query, date, limit, cursor, sort |
get_release_details |
Release details with health stats | version, optional full |
Organization Tools
| Tool | Purpose | Input |
|---|---|---|
list_teams |
List all teams in org | {} |
get_issue_tags |
List all tags for an issue | issue_id |
get_issue_tag_values |
Get tag value distribution | issue_id, tag_key, optional limit |
list_activity |
Issue activity log | issue_id, optional limit, cursor |
Advanced Tools
| Tool | Purpose | Input |
|---|---|---|
get_trace_details |
Distributed trace with spans | trace_id, optional max_spans |
get_grouping_config |
Fingerprinting rules | issue_id |
merge_issues |
Merge issues by hash | issue_id, target_ids |
Raw API
| Tool | Purpose | Input |
|---|---|---|
raw_sentry_api |
Any Sentry API endpoint | endpoint + optional method, params, body, grep_pattern |
Configuration
Set environment variables:
SENTRY_URL: Base URL of your self-hosted Sentry instance.SENTRY_AUTH_TOKEN: Sentry API token (recommended scopes:issue:read,project:read,event:read,issue:write,comment:write).SENTRY_ORG_SLUG: Organization slug.
Claude Code / Cursor Configuration
Add to your MCP client configuration file:
- Claude Code:
~/.claude/settings.jsonor project-level.claude/settings.json - Cursor:
~/.cursor/mcp.json(global) or.cursor/mcp.json(project-level)
Option 1: Using npx (recommended - simplest)
{
"mcpServers": {
"sentry-selfhosted-mcp": {
"command": "npx",
"args": ["-y", "selfhosted-sentry-mcp"],
"env": {
"SENTRY_URL": "https://your-sentry-instance.com",
"SENTRY_AUTH_TOKEN": "your-auth-token",
"SENTRY_ORG_SLUG": "your-org-slug"
}
}
}
}
Option 2: Using global npm install
{
"mcpServers": {
"sentry-selfhosted-mcp": {
"command": "selfhosted-sentry-mcp",
"args": [],
"env": {
"SENTRY_URL": "https://your-sentry-instance.com",
"SENTRY_AUTH_TOKEN": "your-auth-token",
"SENTRY_ORG_SLUG": "your-org-slug"
}
}
}
}
Option 3: From local source
{
"mcpServers": {
"sentry-selfhosted-mcp": {
"command": "node",
"args": ["<full/path/to/sentry-selfhosted-mcp/build/index.js>"],
"env": {
"SENTRY_URL": "https://your-sentry-instance.com",
"SENTRY_AUTH_TOKEN": "your-auth-token",
"SENTRY_ORG_SLUG": "your-org-slug"
}
}
}
}
Docker
Build:
docker build -t sentry-selfhosted-mcp:latest .
Claude Code config:
{
"mcpServers": {
"sentry-selfhosted-mcp": {
"command": "docker",
"args": [
"run", "-i", "--rm",
"-e", "SENTRY_URL",
"-e", "SENTRY_AUTH_TOKEN",
"-e", "SENTRY_ORG_SLUG",
"sentry-selfhosted-mcp:latest"
],
"env": {
"SENTRY_URL": "https://your-sentry-instance.com",
"SENTRY_AUTH_TOKEN": "your-auth-token",
"SENTRY_ORG_SLUG": "your-org-slug"
}
}
}
}
Use env file:
SENTRY_URL=https://your-sentry-instance.com
SENTRY_AUTH_TOKEN=your-auth-token
SENTRY_ORG_SLUG=your-org-slug
{
"mcpServers": {
"sentry-selfhosted-mcp": {
"command": "docker",
"args": [
"run", "-i", "--rm",
"--env-file", "/path/to/.env",
"sentry-selfhosted-mcp:latest"
]
}
}
}
Verify:
echo '{"jsonrpc":"2.0","id":1,"method":"tools/list"}' | docker run -i --rm \
-e SENTRY_URL=https://example.com \
-e SENTRY_AUTH_TOKEN=test \
-e SENTRY_ORG_SLUG=test \
sentry-selfhosted-mcp:latest
Development
npm install
npm run build
Run MCP inspector:
npx @modelcontextprotocol/inspector build/index.js
Security
- Use least-privilege Sentry API tokens.
- Avoid logging sensitive data in MCP client logs.
Troubleshooting
Server not starting or tools not showing:
- Verify
SENTRY_URL,SENTRY_AUTH_TOKEN, andSENTRY_ORG_SLUGare set correctly. - Check the token has required scopes (
issue:read,project:read,event:read,issue:write,comment:write). - Ensure Node.js 20+ is installed:
node --version.
"Unauthorized" or "403" errors:
- Verify your Sentry API token is valid and not expired.
- Check that the token has permissions for the organization specified in
SENTRY_ORG_SLUG.
"Project not found" errors:
- Confirm the project slug exists in your Sentry organization.
- Use
list_sentry_projectstool to see available projects.
Empty or truncated responses:
- For event details, use
limitparameter to paginate through large events. - For
raw_sentry_api, usegrep_patternto filter responses from large endpoints.
Docker container exits immediately:
- Ensure all three environment variables are passed:
SENTRY_URL,SENTRY_AUTH_TOKEN,SENTRY_ORG_SLUG. - Check Docker logs:
docker logs <container-id>.
FAQ
Q: Is this server self-hosted only? A: It is designed for self-hosted Sentry, but it should also work with Sentry SaaS if the API token and org slug are valid.
Q: Why use raw_sentry_api if other tools exist?
A: It exposes any API endpoint for edge cases not covered by typed tools. Use grep_pattern on event endpoints to keep responses small.
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.