Hangfire MCP
MCP server for managing Hangfire background jobs
Hangfire MCP Server
A Model Context Protocol (MCP) server for managing Hangfire background jobs directly from VS Code Copilot and other MCP-compatible clients. Monitor job queues, retry failed jobs, manage recurring tasks, and view real-time statistics — all without leaving your editor.
Features
- Job Management: List, view, retry, delete, and requeue jobs
- Recurring Jobs: List, view, trigger, pause, and resume recurring jobs
- Statistics: View server stats, queues, and active servers
- Auto-Discovery: Automatically finds connection strings from appsettings.json
- Web Dashboard: Built-in web UI with real-time stats and job management
Quick Start (One-Click Setup)
# Clone the repo
git clone https://github.com/inansen/hangfire-mcp.git
cd hangfire-mcp
# Run cross-platform setup (Windows, macOS, Linux)
python setup.py
The setup script will:
- Create a virtual environment
- Install all dependencies (including dashboard)
- Prompt for your SQL Server connection string (or read from
.vscode/mcp.json) - Create VS Code MCP configuration
- Test the connection
- Optionally start the dashboard
Installation
pip install hangfire-mcp
Or with uvx:
uvx hangfire-mcp
Configuration
VS Code (Global Settings)
Add to your VS Code settings (settings.json):
{
"mcp": {
"servers": {
"hangfire-mcp": {
"command": "uvx",
"args": ["hangfire-mcp", "--workspace", "${workspaceFolder}"]
}
}
}
}
VS Code (Per-Project)
Create .vscode/mcp.json in your project:
{
"servers": {
"hangfire-mcp": {
"command": "uvx",
"args": ["hangfire-mcp", "--workspace", "${workspaceFolder}"]
}
}
}
With Explicit Connection String
Use ODBC-style connection strings:
{
"servers": {
"hangfire-mcp": {
"command": "python",
"args": ["-m", "hangfire_mcp", "--workspace", "${workspaceFolder}"],
"env": {
"HANGFIRE_CONNECTION_STRING": "Driver={ODBC Driver 17 for SQL Server};Server=localhost;Database=Hangfire;UID=sa;PWD=yourpassword;Encrypt=no;"
}
}
}
}
Note: This project uses
pyodbcand requires ODBC-format connection strings, not ADO.NET format.
Connection String Discovery
The server finds connection strings in this priority order:
--connection-stringCLI argumentHANGFIRE_CONNECTION_STRINGenvironment variable- Auto-discover from
${workspaceFolder}/**/appsettings*.json - User config at
~/.config/hangfire-mcp/connections.json(Linux/macOS) or%APPDATA%\hangfire-mcp\connections.json(Windows) - Use the
configuretool to set it manually
Available Tools
Job Tools
| Tool | Description |
|---|---|
list_jobs | List jobs by state (Enqueued, Processing, Succeeded, Failed, etc.) |
get_job | Get detailed job info including arguments and exception details |
get_job_history | Get the state history of a job |
retry_job | Retry a failed job |
delete_job | Delete a job |
requeue_job | Move a job back to queue |
Recurring Job Tools
| Tool | Description |
|---|---|
list_recurring_jobs | List all recurring jobs with cron schedules |
get_recurring_job | Get recurring job details |
trigger_recurring_job | Run a recurring job immediately |
pause_recurring_job | Pause scheduled executions |
resume_recurring_job | Resume a paused job |
Statistics Tools
| Tool | Description |
|---|---|
get_stats | Server statistics (succeeded, failed, processing counts) |
list_queues | List queues with pending job counts |
list_servers | List active Hangfire servers |
Configuration Tool
| Tool | Description |
|---|---|
configure | Set connection string for current workspace |
Usage Examples
In VS Code Copilot Chat:
User: Show me failed jobs
Agent: [calls list_jobs(state="Failed")]
Found 3 failed jobs:
| ID | State | Job Type | Created | Reason |
|----|-------|----------|---------|--------|
| 123 | Failed | OrderSyncJob.Execute | 2026-03-17 10:30 | Connection timeout |
| 124 | Failed | EmailJob.Send | 2026-03-17 10:45 | SMTP error |
User: Retry job 123
Agent: [calls retry_job(job_id=123)]
Job 123 has been requeued to 'default' queue.
User: When did CacheRefreshJob last run?
Agent: [calls get_recurring_job(job_id="CacheRefreshJob")]
Recurring Job: CacheRefreshJob
- Cron: 0 */5 * * * (every 5 minutes)
- Last Run: 2026-03-17 12:55:00
- Queue: default
User: Trigger CacheRefreshJob now
Agent: [calls trigger_recurring_job(job_id="CacheRefreshJob")]
CacheRefreshJob has been triggered. New job ID: 456
Web Dashboard
The package includes a built-in web dashboard for visual job management.
Installation
pip install hangfire-mcp[dashboard]
Running the Dashboard
# Windows
.\scripts\run-dashboard.ps1
# macOS / Linux
chmod +x scripts/run-dashboard.sh
./scripts/run-dashboard.sh
# Or manually (any platform)
export HANGFIRE_CONNECTION_STRING="Driver={ODBC Driver 17 for SQL Server};Server=localhost;Database=Hangfire;..."
python -m uvicorn hangfire_mcp.dashboard:app --host 127.0.0.1 --port 8080
Open http://127.0.0.1:8080 in your browser.
Dashboard Features
- Real-time Stats: Succeeded, Failed, Processing, Enqueued, Scheduled counts
- Job List: View all jobs with filtering by state
- Job Actions: Retry, Delete, View details with one click
- Recurring Jobs: Pause, Resume, Trigger recurring jobs
- Server Status: Online/Idle/Offline status based on heartbeat
- Auto-refresh: Updates every 10 seconds
Requirements
- Python 3.11+
- SQL Server with Hangfire database
- ODBC Driver 17 for SQL Server (or compatible)
Development
# Clone the repository
git clone https://github.com/inansen/hangfire-mcp.git
cd hangfire-mcp
# Install all dependencies
pip install -e ".[dev]"
# Run tests
pytest
Contributing
- Fork the repository
- Create a feature branch (
git checkout -b feature/my-feature) - Commit your changes (
git commit -am 'Add my feature') - Push to the branch (
git push origin feature/my-feature) - Open a Pull Request
License
MIT
相关服务器
Scout Monitoring MCP
赞助Put performance and error data directly in the hands of your AI assistant.
Alpha Vantage MCP Server
赞助Access financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
mcp-server-tibet
TIBET provenance tracking for AI decisions. Cryptographic audit trails with ERIN/ERAAN/EROMHEEN/ERACHTER intent logging for compliance and transparency.
Tmux MCP Server
Provides persistent shell execution through tmux sessions.
Compute MCP
An MCP server for evaluating arithmetic expressions using a Pratt parser in Rust.
Cygnus MCP Server
An MCP server demonstrating Cygnus tools for reading text files and invoking local APIs.
Sentry MCP Server
An MCP server for interacting with the Sentry error tracking and performance monitoring platform.
Wormhole
Logs file edits, decisions, and commands so agents stay in sync, avoid conflicts, and pick up where others left off.
MCP LaTeX Server
Create, edit, and manage LaTeX files. Requires an external LaTeX distribution like MiKTeX, TeX Live, or MacTeX.
Dev/Infra
MCP server that gives LLMs full control over local Kubernetes dev environments via k3d, kubectl, Tilt, Helm, and kustomize
Cucumber Studio
Provides LLM access to the Cucumber Studio testing platform for managing and executing tests.
MCP-CLI Adapter
Use command line tools in a secure fashion as MCP tools.