mcp-slurm
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., "@mcp-slurmlist my jobs in the queue"
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.
SLURM MCP Server
A Model Context Protocol (MCP) server for managing SLURM (Simple Linux Utility for Resource Management) clusters. This server allows AI assistants to interact with HPC clusters via SSH to submit jobs, check resources, manage queues, and monitor job status.
Features
Cluster Information: Query node status, partitions, and resource availability
Job Submission: Submit jobs with customizable parameters including resource requests
Job Management: Cancel, hold, release, suspend, resume, and modify running jobs
Script Upload: Upload and execute job scripts directly to the cluster
File Operations: View job outputs, list directories, and manage files
SSH Connectivity: Secure connection to login nodes with password or key authentication
Related MCP server: slurm_MCP
Quick Start
1. Installation
# Clone the repository
git clone <your-repo>
cd mcp-slurm
# Install dependencies
npm install
# Build the project
npm run build2. Configuration
Create a .env file in the project root with your cluster connection details:
# Required: Cluster connection details
SLURM_HOST=your-cluster-login-node.example.com
SLURM_USERNAME=your-username
# Authentication (choose one)
SLURM_PASSWORD=your-password
# OR
SLURM_SSH_KEY_PATH=/path/to/your/private/key
# Optional: Connection settings
SLURM_PORT=22
# Optional: Default SLURM parameters
SLURM_DEFAULT_PARTITION=compute
SLURM_DEFAULT_ACCOUNT=your-account3. Running the Server
# Start the server
npm start
# Or run in development mode
npm run watchThe server will start on port 1337 by default.
Tools Available
1. slurm_info
Get cluster information including nodes, partitions, queues, and job accounting.
Parameters:
command_type: Type of command (sinfo,squeue,sacct,scontrol)detailed: Get detailed output (optional)partition: Query specific partition (optional)node: Query specific node (optional)
Examples:
Check node status:
{command_type: "sinfo", detailed: true}View job queue:
{command_type: "squeue"}Check specific partition:
{command_type: "sinfo", partition: "gpu"}
2. slurm_submit
Submit jobs to the SLURM scheduler with customizable parameters.
Parameters:
job_name: Name for the jobcommand: Command or script to executepartition: Partition to submit to (optional)nodes: Number of nodes (optional)cpus_per_task: CPUs per task (optional)memory: Memory per node (optional)time_limit: Time limit (optional)account: Account to charge (optional)And many more...
Example:
{
"job_name": "my_simulation",
"command": "python simulate.py",
"nodes": 2,
"cpus_per_task": 16,
"memory": "64G",
"time_limit": "2:00:00",
"partition": "compute"
}3. slurm_job_control
Control SLURM jobs: cancel, hold, release, suspend, resume, requeue, or modify.
Parameters:
job_id: Job ID to controlaction: Action to perform (cancel,hold,release, etc.)reason: Reason for action (optional)modify_parameter: Parameter to modify (for modify action)modify_value: New value (for modify action)
Examples:
Cancel job:
{job_id: "12345", action: "cancel", reason: "User request"}Hold job:
{job_id: "12345", action: "hold"}Modify time limit:
{job_id: "12345", action: "modify", modify_parameter: "TimeLimit", modify_value: "4:00:00"}
4. slurm_script
Upload job scripts and submit them to SLURM.
Parameters:
script_name: Name for the script filescript_content: Content of the job scriptremote_path: Directory to store script (optional)submit_immediately: Whether to submit after upload (default: true)additional_sbatch_args: Extra sbatch arguments (optional)
Example:
{
"script_name": "job.slurm",
"script_content": "#!/bin/bash\n#SBATCH --job-name=test\n#SBATCH --time=1:00:00\n\necho 'Hello from SLURM!'",
"submit_immediately": true
}5. slurm_files
Manage files on the cluster including viewing job outputs.
Parameters:
action: Action to perform (list,view,tail,head,delete,find_outputs)path: File or directory path (optional)job_id: Job ID to find outputs for (optional)lines: Number of lines to show (optional)pattern: Search pattern (optional)
Examples:
List home directory:
{action: "list"}View job output:
{action: "view", path: "slurm-12345.out"}Find job outputs:
{action: "find_outputs", job_id: "12345"}Tail log file:
{action: "tail", path: "job.log", lines: 100}
Claude Desktop Integration
Local Development
Add this to your Claude Desktop configuration:
Windows: %APPDATA%/Claude/claude_desktop_config.json
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"mcp-slurm": {
"command": "node",
"args": ["C:/Users/tejasv/Documents/mcp-slurm/dist/index.js"],
"env": {
"SLURM_HOST": "your-cluster.example.com",
"SLURM_USERNAME": "your-username",
"SLURM_PASSWORD": "your-password"
}
}
}
}After Publishing to npm
{
"mcpServers": {
"mcp-slurm": {
"command": "npx",
"args": ["mcp-slurm"],
"env": {
"SLURM_HOST": "your-cluster.example.com",
"SLURM_USERNAME": "your-username",
"SLURM_PASSWORD": "your-password"
}
}
}
}Security Considerations
Store sensitive credentials securely (use SSH keys when possible)
Limit the MCP server's access to specific user accounts
Consider using dedicated service accounts for automated operations
Review and audit job submissions regularly
Use network restrictions to limit access to trusted hosts
Common Use Cases
Checking Cluster Status
Ask Claude: "What's the current status of the cluster?" or "Show me available nodes in the GPU partition"
Submitting Jobs
Ask Claude: "Submit a job named 'data_analysis' that runs 'python analyze.py' using 4 CPUs and 16GB memory for 2 hours"
Monitoring Jobs
Ask Claude: "Show me all my running jobs" or "What's the status of job 12345?"
Managing Outputs
Ask Claude: "Show me the output of job 12345" or "Find all output files for my recent jobs"
Script Management
Ask Claude: "Upload and submit this job script: [paste script content]"
Troubleshooting
Connection Issues
Verify SSH connectivity:
ssh username@hostnameCheck firewall rules and network access
Ensure SSH key permissions are correct (600)
Authentication Errors
Verify username and password/key path
Check if two-factor authentication is required
Ensure the user has SLURM access
Job Submission Failures
Check if default partition/account are set correctly
Verify resource requests are within limits
Check SLURM configuration and policies
Development
To add new SLURM functionality:
Create a new tool in
src/tools/Extend the
SlurmSSHClientif neededBuild and test:
npm run build && npm start
The framework automatically discovers and loads tools from the src/tools/ directory.
License
This project is licensed under the MIT License.
This server cannot be installed
Maintenance
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/tejasvinu/mcp-slurm'
If you have feedback or need assistance with the MCP directory API, please join our Discord server