Ambari MCP Server
Provides tools to interact with Apache Ambari clusters, enabling management of clusters, services, hosts, alerts, and configurations via the Ambari REST API.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Ambari MCP Serverlist all services in production cluster"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Ambari MCP Server
A Model Context Protocol (MCP) server for Apache Ambari, built with the TypeScript SDK. This server provides tools to interact with Ambari clusters through the MCP protocol.
Overview
This MCP server allows AI assistants and other MCP clients to interact with Apache Ambari clusters by exposing common Ambari REST API operations as MCP tools.
Features
Cluster Management: Get cluster information, create clusters
Service Management: List and get details of cluster services
Host Management: List and get details of cluster hosts
Alert Management: Manage alert targets
Secure Authentication: Basic authentication with Ambari server
Configurable: Environment-based configuration
Type-Safe: Built with TypeScript for better reliability
Available Tools
Cluster Operations
ambari_clusters_getclusters- Returns all clustersambari_clusters_getcluster- Returns information about a specific clusterambari_clusters_createcluster- Creates a new cluster
Service Operations
ambari_services_getservices- Get all services for a clusterambari_services_getservice- Get details of a specific serviceambari_services_getservicestate- Get detailed state information for a specific serviceambari_services_startservice- Start a specific service on the clusterambari_services_stopservice- Stop a specific service on the cluster
Service Restart & Configuration Management
ambari_services_getserviceswithstaleconfigs- Get services and components that have stale configurations requiring restartambari_services_gethostcomponentswithstaleconfigs- Get host components that need restart due to stale configurationsambari_services_restartservice- Restart a specific service on the cluster (supports rolling restart)ambari_services_restartcomponents- Restart specific components that have stale configurationsambari_services_getrollingrestartstatus- Get the status of rolling restart operations for services
Service Maintenance Mode Management
ambari_services_enablemaintenancemode- Enable maintenance mode for a service or componentambari_services_disablemaintenancemode- Disable maintenance mode for a service or component
Service Check Operations
ambari_services_runservicecheck- Run service check for a specific service to verify it is working correctlyambari_services_isservicechecksupported- Check if service check is supported for a specific service in the stackambari_services_getservicecheckstatus- Get the status of recent service check operations for a service
Host Operations
ambari_hosts_gethosts- Returns a collection of all hostsambari_hosts_gethost- Returns information about a single host
Alert Operations
ambari_alerts_gettargets- Returns all alert targetsambari_alerts_getalerts- Get all alerts for a cluster with filtering optionsambari_alerts_getalertsummary- Get alert summary in grouped format for a clusterambari_alerts_getalertdetails- Get details for a specific alert definitionambari_alerts_getalertdefinitions- Get all alert definitions for a clusterambari_alerts_updatealertdefinition- Update an alert definition (enable/disable or modify properties)
Alert Group Management
ambari_alerts_getalertgroups- Get all alert groups for a clusterambari_alerts_createalertgroup- Create a new alert groupambari_alerts_updatealertgroup- Update an existing alert groupambari_alerts_deletealertgroup- Delete an alert groupambari_alerts_duplicatealertgroup- Duplicate an existing alert group with a new nameambari_alerts_adddefinitiontogroup- Add an alert definition to an alert groupambari_alerts_removedefinitionfromgroup- Remove an alert definition from an alert group
Alert Notification Management
ambari_alerts_getnotifications- Get all alert notification targetsambari_alerts_createnotification- Create a new alert notification targetambari_alerts_updatenotification- Update an existing alert notification targetambari_alerts_deletenotification- Delete an alert notification targetambari_alerts_addnotificationtogroup- Add a notification target to an alert groupambari_alerts_removenotificationfromgroup- Remove a notification target from an alert group
Alert Settings
ambari_alerts_savealertsettings- Save cluster-level alert settings (like repeat tolerance)
Installation
Clone or copy this server to your local machine
Install dependencies:
npm installInstall dev dependencies (if not already installed):
npm install typescript @types/node --save-dev
Configuration
Copy the example environment file:
cp .env.example .envEdit the
.envfile with your Ambari server details:AMBARI_BASE_URL=http://your-ambari-server:8080/api/v1 AMBARI_USERNAME=admin AMBARI_PASSWORD=admin TIMEOUT_MS=30000
Building
Build the TypeScript code:
npm run buildUsage
As a Standalone Server
Run the server directly:
npm startWith MCP Clients
Claude Desktop
Add to your Claude Desktop configuration:
{
"mcpServers": {
"ambari": {
"command": "node",
"args": ["/path/to/ambari-mcp-server/dist/index.js"]
}
}
}Other MCP Clients
The server communicates via stdio and follows the MCP protocol specification.
Development
Project Structure
ambari-mcp-server/
├── src/
│ └── index.ts # Main server implementation
├── dist/ # Compiled JavaScript (after build)
├── .env.example # Environment configuration template
├── package.json # Node.js dependencies and scripts
├── tsconfig.json # TypeScript configuration
└── README.md # This fileDevelopment Commands
npm run build- Compile TypeScript to JavaScriptnpm run dev- Build and run the servernpm start- Run the compiled server
Adding New Tools
Add the tool definition to the
AMBARI_TOOLSarrayImplement the tool executor in the
toolExecutorsobjectUpdate this README with the new tool documentation
Example:
// Add to AMBARI_TOOLS
{
name: 'ambari_new_operation',
description: 'Description of the new operation',
inputSchema: {
type: 'object',
properties: {
// Define input parameters
},
required: ['requiredParam']
}
}
// Add to toolExecutors
ambari_new_operation: async (args) => {
return executeAmbariRequest('GET', '/new-endpoint', args);
}Error Handling
The server includes comprehensive error handling:
Network timeouts and connection errors
HTTP error responses from Ambari
Invalid tool parameters
Authentication failures
Errors are returned as MCP error responses with appropriate error codes and messages.
Security Considerations
Store sensitive credentials in environment variables
Use HTTPS for Ambari server connections in production
Implement proper authentication and authorization
Consider network security between MCP client and server
Troubleshooting
Common Issues
Connection Refused: Check if Ambari server is running and accessible
Authentication Failed: Verify username and password in
.envTimeout Errors: Increase
TIMEOUT_MSvalueBuild Errors: Ensure TypeScript and dependencies are installed
Debug Mode
Set environment variable DEBUG=1 for verbose logging:
DEBUG=1 npm startContributing
Fork the repository
Create a feature branch
Make your changes
Add tests if applicable
Submit a pull request
License
ISC License - see package.json for details
Related Links
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/nikita15p/ambari-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server