PagerDuty MCP Server
Enables AI assistants to manage PagerDuty incidents, view alerts, and check on-call schedules with both read-only and write operations.
README
PagerDuty MCP Server
Model Context Protocol server for PagerDuty incident management
Integrate PagerDuty with AI assistants (Claude Desktop, Claude Code) for intelligent incident management and on-call support.
šÆ Features
Incident Management (9 Tools)
list_incidents- List incidents with filters (status, urgency, team)get_incident- Get detailed incident informationget_my_incidents- Get incidents assigned to youacknowledge_incident- Mark incident as acknowledgedresolve_incident- Resolve incident with notesadd_incident_note- Add investigation notesget_incident_alerts- Get all alerts for an incidentget_incident_timeline- View incident activity historyget_oncall- Check current on-call schedules
Read-Only by Default
- List, query, and analyze incidents
- View alerts and timelines
- Check on-call schedules
Write Operations (Controlled)
- Acknowledge/resolve incidents (requires confirmation)
- Add investigation notes
- Secure: Uses From-email header for audit trail
š Quick Start
Prerequisites
- Python 3.10+
- PagerDuty account with API access
- Claude Desktop or Claude Code
1. Get PagerDuty API Token
- Login to PagerDuty: https://your-company.pagerduty.com
- User Icon ā My Profile
- User Settings ā API Access
- Click "Create API User Token"
- Description:
MCP-Integration - Copy token (starts with
u+ory1_)
2. Install Dependencies
cd pagerduty-mcp-server
# Using uv (recommended)
uv sync
# Or using pip
python -m venv venv
source venv/bin/activate # Windows: venv\Scripts\activate
pip install -e .
3. Set Environment Variable
# Linux/macOS
export PAGERDUTY_API_TOKEN="u+your-token-here"
# Or add to ~/.bashrc
echo 'export PAGERDUTY_API_TOKEN="u+your-token-here"' >> ~/.bashrc
source ~/.bashrc
4. Test the Server
# Run server (stdio mode)
uv run python main.py
# Or with pip
python main.py
āļø MCP Configuration
Claude Desktop
Config file: ~/.config/mcp/mcpServers.json (Linux) or ~/Library/Application Support/Claude/claude_desktop_config.json (macOS)
{
"mcpServers": {
"pagerduty": {
"command": "uv",
"args": [
"--directory",
"/path/to/pagerduty-mcp-server",
"run",
"python",
"main.py"
],
"env": {
"PAGERDUTY_API_TOKEN": "${PAGERDUTY_API_TOKEN}"
}
}
}
}
Claude Code (VS Code)
Config file: ~/.config/Code/User/mcp.json
{
"mcpServers": {
"pagerduty": {
"command": "uv",
"args": [
"--directory",
"/path/to/pagerduty-mcp-server",
"run",
"python",
"main.py"
],
"env": {
"PAGERDUTY_API_TOKEN": "${PAGERDUTY_API_TOKEN}"
}
}
}
}
Restart Claude Desktop/Code after config changes.
š Tool Usage Examples
List Active Incidents
"List all triggered PagerDuty incidents"
Claude will use: list_incidents(status="triggered")
Check Your Incidents
"Show me my assigned PagerDuty incidents"
Claude will use: get_my_incidents()
Investigate Incident
"Get details for PagerDuty incident Q26N8MQQHA6R0P"
Claude will use: get_incident(incident_id="Q26N8MQQHA6R0P")
View Alerts
"Show all alerts for this incident"
Claude will use: get_incident_alerts(incident_id="...")
Acknowledge Incident
"Acknowledge incident Q26N8MQQHA6R0P with note: Investigating database slowdown"
Claude will use: acknowledge_incident(incident_id="...", note="Investigating database slowdown")
Check On-Call
"Who is on-call right now?"
Claude will use: get_oncall()
š§ Advanced Configuration
Environment Variables
| Variable | Required | Description |
|---|---|---|
PAGERDUTY_API_TOKEN |
Yes | API User Token from PagerDuty |
PYTHONUNBUFFERED |
No | Set to 1 for proper logging (recommended) |
Custom Filters
# List high-urgency triggered incidents
list_incidents(status="triggered", urgency="high", limit=50)
# List incidents for specific team
list_incidents(team_ids=["P5KZERF"], status="acknowledged")
š ļø Development
Project Structure
pagerduty-mcp-server/
āāā main.py # Entry point
āāā src/
ā āāā server_mcp.py # MCP server with 9 tools
ā āāā helpers/
ā āāā pagerduty_client.py # Async API client
ā āāā utils.py # Formatting utilities
ā āāā constants.py # API constants
āāā pyproject.toml
āāā uv.lock
āāā README.md
Adding New Tools
- Implement in
src/server_mcp.py - Add helper functions to
src/helpers/if needed - Test with Claude
š API Reference
Incident Statuses
triggered- New incident, not acknowledgedacknowledged- Someone is working on itresolved- Incident fixed
Urgencies
high- High urgency (pages on-call)low- Low urgency (notification only)
Common Fields
incident_id- PagerDuty incident ID (e.g.,Q26N8MQQHA6R0P)incident_number- Human-readable number (e.g.,2914407)service- Affected serviceassigned_to- List of assigned usershtml_url- Link to incident in PagerDuty web UI
š Security
API Token Security
- ā Store token in environment variable (NOT in code)
- ā
Use
.gitignoreto prevent token commits - ā Token has same permissions as your PagerDuty user
- ā Audit trail: All actions logged with your email
Read-Only Tools
Safe to use without confirmation:
list_incidentsget_incidentget_my_incidentsget_incident_alertsget_incident_timelineget_oncall
Write Tools (Require Confirmation)
acknowledge_incident- Marks incident as acknowledgedresolve_incident- Closes incidentadd_incident_note- Adds investigation notes
š Troubleshooting
"Missing PAGERDUTY_API_TOKEN"
# Check environment variable
echo $PAGERDUTY_API_TOKEN
# If empty, set it
export PAGERDUTY_API_TOKEN="u+your-token-here"
source ~/.bashrc
"Authentication failed"
- Token expired or invalid
- Get new token from PagerDuty User Settings
- Verify token starts with
u+ory1_
"No incidents found"
- Check filters (status, urgency)
- Verify you have access to incidents
- Try without filters:
list_incidents(limit=10)
MCP Server Not Loading
- Restart Claude Desktop/Code
- Check config file path
- Verify
uvis installed:uv --version - Check logs:
tail -f ~/.config/Claude/logs/mcp*.log
šÆ Use Cases
1. Morning Incident Check
"Show me all active PagerDuty incidents from the last 24 hours"
2. On-Call Handoff
"Who is currently on-call? Show all open incidents."
3. Incident Investigation
"Get incident Q26N8MQQHA6R0P details, alerts, and timeline"
4. Alert Analysis
"Show all alerts for incident XYZ and summarize the root cause"
5. Team Status
"List all triggered incidents for my team"
š Integration with ServiceNow (Future)
Planned feature: Create ServiceNow incidents from PagerDuty alerts
PagerDuty Incident
ā
Claude AI (parses alert)
ā
ServiceNow MCP (create incident)
ā
Link PagerDuty ā ServiceNow
š¤ Contributing
See CONTRIBUTING.md.
š License
Apache License 2.0 - see LICENSE file.
Last updated: 2026-03-11
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.