Heroku Mcp 伺服器
概覽
什麼是 Heroku MCP 伺服器?
Heroku MCP 伺服器是一個強大的工具,旨在增強 Heroku 平台的功能。它允許開發者使用 Heroku 命令行介面 (CLI) 更有效地管理他們的應用程式。這個伺服器充當 Heroku 平台和開發者之間的橋樑,提供無縫的應用程式部署和管理體驗。
Heroku MCP 伺服器的特點
- 與 Heroku CLI 的整合:該伺服器與 Heroku CLI 完全整合,允許用戶直接從終端執行命令。
- 友好的介面:它提供了一個簡單的介面,簡化了應用程式的管理,使開發者更容易部署和監控他們的項目。
- 實時監控:用戶可以實時監控他們的應用程式,接收有關性能和問題的更新和警報。
- 可擴展性:Heroku MCP 伺服器設計為隨著您的應用程式擴展,確保它能夠處理隨著用戶基數增長而增加的負載。
- 開源:作為一個公共庫,開發者可以參與其開發,確保持續改進和功能增強。
如何使用 Heroku MCP 伺服器
- 安裝:首先在您的機器上安裝 Heroku CLI。您可以在 Heroku 網站 上找到安裝說明。
- 克隆庫:使用以下命令從 GitHub 克隆 Heroku MCP 伺服器庫:
git clone https://github.com/heroku/heroku-mcp-server.git
- 進入目錄:切換到克隆的庫的目錄:
cd heroku-mcp-server
- 啟動伺服器:使用以下命令啟動伺服器:
heroku-mcp-server start
- 訪問介面:打開您的瀏覽器並導航到伺服器的 URL,以訪問用戶介面並開始管理您的應用程式。
常見問題解答
Heroku MCP 伺服器的目的是什么?
Heroku MCP 伺服器旨在促進在 Heroku 平台上管理應用程式,為開發者提供有效部署、監控和擴展應用程式的工具。
Heroku MCP 伺服器是免費使用的嗎?
是的,Heroku MCP 伺服器是開源的,並且可以免費使用。開發者可以參與其開發並免費使用。
我可以為 Heroku MCP 伺服器做貢獻嗎?
當然可以!Heroku MCP 伺服器是一個公共庫,歡迎貢獻。您可以提交問題、功能請求,甚至拉取請求來增強伺服器的功能。
Heroku MCP 伺服器支持哪些編程語言?
Heroku MCP 伺服器主要支持在 Heroku 平台上構建的應用程式,這包括 Ruby、Node.js、Python、Java 等多種編程語言。
我如何報告問題或錯誤?
如果您在使用 Heroku MCP 伺服器時遇到任何問題或錯誤,您可以在 GitHub 倉庫的問題追蹤器上報告。請確保提供有關問題的詳細信息,以幫助開發者快速解決。
詳細
heroku-mcp-server
The Heroku Platform MCP Server works on Common Runtime, Cedar Private and Shield Spaces, and Fir Private Spaces.
Prerequisites
- Heroku CLI must be installed globally on your system, version 10.8.1 or higher.
Deploy on Heroku
Overview
The Heroku Platform MCP Server is a specialized Model Context Protocol (MCP) implementation designed to facilitate seamless interaction between large language models (LLMs) and the Heroku Platform. This server provides a robust set of tools and capabilities that enable LLMs to read, manage, and operate Heroku Platform resources.
Key Features:
- Direct interaction with Heroku Platform resources through LLM-driven tools
- Secure and authenticated access to Heroku Platform APIs, leveraging the Heroku CLI
- Natural language interface for Heroku Platform interactions
Note: The Heroku Platform MCP Server is currently in early development. As we continue to enhance and refine the implementation, the available functionality and tools may evolve. We welcome feedback and contributions to help shape the future of this project.
Note: The Heroku Platform MCP Server requires the Heroku CLI to be installed globally (v10.8.1+). Ensure you have the correct version by running
heroku --version
.
Configure the Heroku Platform MCP Server
You can configure Claude Desktop, Zed, Cursor, Windsurf, and other clients to work with the Heroku Platform MCP Server.
Configure the Heroku Platform MCP Server with heroku mcp:start
Use heroku mcp:start
to launch the Heroku Platform MCP Server. We recommend this method as it leverages your existing
Heroku CLI authentication, so you don't need to set the
HEROKU_API_KEY
environment variable. The
heroku mcp:start
command is available in Heroku CLI version 10.8.1 and later.
There are several benefits to configuring with heroku mcp:start
:
- No need to manage or expose your Heroku API key
- Uses your current Heroku CLI authentication context
- Works seamlessly with supported clients
Example configuration for Claude Desktop:
{
"mcpServers": {
"heroku": {
"command": "heroku mcp:start"
}
}
}
Example configuration for Zed:
{
"context_servers": {
"heroku": {
"command": {
"path": "heroku",
"args": ["mcp:start"]
}
}
}
}
Example configuration for Cursor:
{
"mcpServers": {
"heroku": {
"command": "heroku mcp:start"
}
}
}
Example configuration for Windsurf:
{
"mcpServers": {
"heroku": {
"command": "heroku mcp:start"
}
}
}
Example configuration for Cline:
{
"mcpServers": {
"heroku": {
"command": "heroku mcp:start"
}
}
}
Example configuration for VSCode:
{
"mcp": {
"servers": {
"heroku": {
"type": "stdio",
"command": "heroku",
"args": ["mcp:start"]
}
}
}
}
Example configuration for Trae:
{
"mcpServers": {
"heroku": {
"command": "heroku mcp:start"
}
}
}
Note: When you use
heroku mcp:start
, the server authenticates using your current Heroku CLI session so you don't need to set theHEROKU_API_KEY
environment variable. We recommend you useheroku mcp:start
, but if you prefer to use an API key, you can use the alternate configuration below.
Configure the Heroku Platform MCP Server with npx -y @heroku/mcp-server
You can also launch the Heroku Platform MCP Server using the npx -y @heroku/mcp-server
command. This method requires
you to set the HEROKU_API_KEY
environment
variable with your Heroku
authorization token.
Generating the HEROKU_API_KEY
Generate a Heroku authorization token with one of these methods:
-
Use the Heroku CLI command:
heroku authorizations:create
-
Use an existing token in the CLI
heroku auth:token
Copy the token and use it as your
HEROKU_API_KEY
in the following steps. -
In your Heroku Dashboard:
- Select your avatar, then select Account Settings.
- Open the Applications tab.
- Next to Authorizations, click Create authorization.
Example configuration for Claude Desktop:
{
"mcpServers": {
"heroku": {
"command": "npx",
"args": ["-y", "@heroku/mcp-server"],
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>"
}
}
}
}
Example configuration for Zed:
{
"context_servers": {
"heroku": {
"command": {
"path": "npx",
"args": ["-y", "@heroku/mcp-server"],
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>"
}
}
}
}
}
Example configuration for Cursor:
{
"mcpServers": {
"heroku": {
"command": "npx -y @heroku/mcp-server",
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>"
}
}
}
}
Example configuration for Windsurf:
{
"mcpServers": {
"heroku": {
"command": "npx",
"args": ["-y", "@heroku/mcp-server"],
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>"
}
}
}
}
Example configuration for Cline:
{
"mcpServers": {
"heroku": {
"command": "npx",
"args": ["-y", "@heroku/mcp-server"],
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>"
}
}
}
}
Example configuration for VSCode:
{
"mcp": {
"servers": {
"heroku": {
"type": "stdio",
"command": "npx",
"args": ["-y", "@heroku/mcp-server"],
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>"
}
}
}
}
}
Example configuration for Trae:
{
"mcpServers": {
"heroku": {
"command": "npx",
"args": ["-y", "@heroku/mcp-server"],
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>"
}
}
}
}
Note: When you use
npx -y @heroku/mcp-server
, you must set theHEROKU_API_KEY
environment variable with your Heroku authorization token.
Available Tools
Application Management
list_apps
- List all Heroku apps. You can filter apps by personal, collaborator, team, or space.get_app_info
- Get detailed information about an app, including its configuration, dynos, and add-ons.create_app
- Create a new app with customizable settings for region, team, and space.rename_app
- Rename an existing app.transfer_app
- Transfer ownership of an app to another user or team.deploy_to_heroku
- Deploy projects to Heroku with anapp.json
configuration, supporting team deployments, private spaces, and environment setups.deploy_one_off_dyno
- Execute code or commands in a sandboxed environment on a Heroku one-off dyno. Supports file creation, network access, environment variables, and automatic cleanup. Ideal for running scripts, tests, or temporary workloads.
Process & Dyno Management
ps_list
- List all dynos for an app.ps_scale
- Scale the number of dynos up or down, or resize dynos.ps_restart
- Restart specific dynos, process types, or all dynos.
Add-ons
list_addons
- List all add-ons for all apps or for a specific app.get_addon_info
- Get detailed information about a specific add-on.create_addon
- Provision a new add-on for an app.
Maintenance & Logs
maintenance_on
- Enable maintenance mode for an app.maintenance_off
- Disable maintenance mode for an app.get_app_logs
- View application logs.
Pipeline Management
pipelines_create
- Create a new pipeline.pipelines_promote
- Promote apps to the next stage in a pipeline.pipelines_list
- List available pipelines.pipelines_info
- Get detailed pipeline information.
Team & Space Management
list_teams
- List teams you belong to.list_private_spaces
- List available spaces.
PostgreSQL Database Management
pg_psql
- Execute SQL queries against the Heroku PostgreSQL database.pg_info
- Display detailed database information.pg_ps
- View active queries and execution details.pg_locks
- View database locks and identify blocking transactions.pg_outliers
- Identify resource-intensive queries.pg_credentials
- Manage database credentials and access.pg_kill
- Terminate specific database processes.pg_maintenance
- Show database maintenance information.pg_backups
- Manage database backups and schedules.pg_upgrade
- Upgrade PostgreSQL to a newer version.
Debugging
You can use the MCP inspector or the VS Code Run and Debug function to run and debug the server.
- Link the project as a global CLI using
npm link
from the project root. - Build with
npm run build:dev
or watch for file changes and build automatically withnpm run build:watch
.
Use the MCP Inspector
Use the MCP inspector with no breakpoints in the code:
### Breakpoints are not available
npx @modelcontextprotocol/inspector heroku-mcp-server
Alternatively, if you installed the package in a specific directory or are actively developing on the Heroku MCP server:
cd /path/to/servers
npx @modelcontextprotocol/inspector dist/index.js
Use the VS Code Run and Debug Function
Use the VS Code Run and Debug launcher with fully functional breakpoints in the code:
- Locate and select the run debug.
- Select the configuration labeled "
MCP Server Launcher
" in the dropdown. - Select the run/debug button.
VS Code / Cursor Debugging Setup
To set up local debugging with breakpoints:
-
Store your Heroku auth token in the VS Code user settings:
- Open the Command Palette (Cmd/Ctrl + Shift + P).
- Type
Preferences: Open User Settings (JSON)
. - Add the following snippet:
{ "heroku.mcp.authToken": "your-token-here" }
-
Create or update
.vscode/launch.json
:{ "version": "0.2.0", "configurations": [ { "type": "node", "request": "launch", "name": "MCP Server Launcher", "skipFiles": ["<node_internals>/**"], "program": "${workspaceFolder}/node_modules/@modelcontextprotocol/inspector/bin/cli.js", "outFiles": ["${workspaceFolder}/**/dist/**/*.js"], "env": { "HEROKU_API_KEY": "${config:heroku.mcp.authToken}", "DEBUG": "true" }, "args": ["heroku-mcp-server"], "sourceMaps": true, "console": "integratedTerminal", "internalConsoleOptions": "neverOpen", "preLaunchTask": "npm: build:watch" }, { "type": "node", "request": "attach", "name": "Attach to Debug Hook Process", "port": 9332, "skipFiles": ["<node_internals>/**"], "sourceMaps": true, "outFiles": ["${workspaceFolder}/dist/**/*.js"] }, { "type": "node", "request": "attach", "name": "Attach to REPL Process", "port": 9333, "skipFiles": ["<node_internals>/**"], "sourceMaps": true, "outFiles": ["${workspaceFolder}/dist/**/*.js"] } ], "compounds": [ { "name": "Attach to MCP Server", "configurations": ["Attach to Debug Hook Process", "Attach to REPL Process"] } ] }
-
Create
.vscode/tasks.json
:{ "version": "2.0.0", "tasks": [ { "type": "npm", "script": "build:watch", "group": { "kind": "build", "isDefault": true }, "problemMatcher": ["$tsc"] } ] }
-
(Optional) Set breakpoints in your TypeScript files.
-
Press F5 or use the
Run and Debug
sidebar.
Note: the debugger automatically builds your TypeScript files before launching.
Installing via Smithery
To install Heroku Platform MCP Server for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @heroku/heroku-mcp-server --client claude
Environment Variables
The Heroku Platform MCP Server supports the following environment variables:
HEROKU_API_KEY
Your Heroku authorization token. Required for authentication with the Heroku Platform.
MCP_SERVER_REQUEST_TIMEOUT
Timeout in milliseconds for command execution. Defaults to 15000 (15 seconds) if not set.
Example configuration with custom timeout:
{
"mcpServers": {
"heroku": {
"command": "npx",
"args": ["-y", "@heroku/mcp-server"],
"env": {
"HEROKU_API_KEY": "<YOUR_HEROKU_AUTH_TOKEN>",
"MCP_SERVER_REQUEST_TIMEOUT": "30000"
}
}
}
}
伺服器配置
{
"mcpServers": {
"heroku-mcp-server": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"ghcr.io/metorial/mcp-container--heroku--heroku-mcp-server--heroku-mcp-server",
"heroku mcp:start"
],
"env": {
"HEROKU_API_KEY": "heroku-api-key"
}
}
}
}