PMDaemon - Advanced Process Manager
A high-performance process manager built in Rust, inspired by PM2 with innovative features that exceed the original. PMDaemon is designed for modern application deployment with advanced port management, real-time monitoring, and production-ready web APIs.
๐ Table of Contents
- Key Features
- Installation
- Quick Start
- Command Reference
- Configuration Options
- Web API
- Monitoring
- Comparison with PM2
- Library Usage
- Testing
- Roadmap
- Contributing
- License
The CLI
๐ Key Features
Core Process Management
- Process Lifecycle - Start, stop, restart, reload, and delete operations
- Clustering - Run multiple instances with automatic load balancing
- Auto-restart - Automatic restart on crashes with configurable limits
- Signal Handling - Graceful shutdown with SIGTERM/SIGINT and custom signals
- Configuration Persistence - Process configs saved and restored between sessions
Advanced Monitoring
- Real-time Monitoring - CPU, memory, uptime tracking with system metrics
- Memory Limit Enforcement - Automatic restart when processes exceed memory limits
- Process Health Checks - Continuous monitoring with automatic failure detection
- Log Management - Separate stdout/stderr files with viewing and following
๐ Innovative Port Management (Beyond PM2)
- Port Range Distribution - Automatically distribute consecutive ports to cluster instances
- Auto-assignment - Find first available port in specified range
- Conflict Detection - Prevent port conflicts at the process manager level
- Runtime Port Overrides - Change ports during restart without modifying saved config
- Port Visibility - Display assigned ports in process listings
Web API & Real-time Updates
- REST API - Full process management via HTTP with PM2-compatible responses
- WebSocket Support - Live process status and system metrics streaming
- Production Web Server - Built on Axum with CORS and security headers
๐ฆ Installation
From Source
Using Cargo
๐ Quick Start
Basic Process Management
# Start a process
# List all processes
# Stop a process
# Restart a process
# Delete a process
Clustering with Port Management
# Start 4 instances with port range
# Auto-assign ports from range
# Runtime port override (doesn't modify saved config)
Memory Limits and Monitoring
# Set memory limit with auto-restart
# Real-time monitoring
# View logs
Web API Server
# Start web API server for remote monitoring
๐ Command Reference
Command | Description | Example |
---|---|---|
start |
Start a new process | pmdaemon start app.js --name myapp |
stop |
Stop a process | pmdaemon stop myapp |
restart |
Restart a process | pmdaemon restart myapp |
reload |
Graceful restart | pmdaemon reload myapp |
delete |
Delete a process | pmdaemon delete myapp |
list |
List all processes | pmdaemon list |
monit |
Real-time monitoring | pmdaemon monit |
logs |
View process logs | pmdaemon logs myapp |
info |
Process details | pmdaemon info myapp |
web |
Start web API server | pmdaemon web --port 9615 |
๐ง Configuration Options
Process Configuration
Port Management Options
Option | Description | Example |
---|---|---|
--port 3000 |
Single port assignment | Assigns port 3000 |
--port 3000-3005 |
Port range for clusters | Distributes 3000-3005 |
--port auto:4000-4100 |
Auto-find available port | First available in range |
๐ Web API
PMDaemon provides a comprehensive REST API compatible with PM2:
Endpoints
Method | Endpoint | Description |
---|---|---|
GET |
/api/processes |
List all processes |
POST |
/api/processes |
Start a new process |
DELETE |
/api/processes/:id |
Stop/delete a process |
GET |
/api/system |
System metrics |
GET |
/api/logs/:id |
Process logs |
WS |
/ws |
Real-time updates |
Example API Usage
# List processes
# Start a process
# WebSocket for real-time updates
๐ Monitoring
PMDaemon provides comprehensive monitoring capabilities:
Real-time Metrics
- CPU usage percentage
- Memory usage (RSS)
- Process uptime
- Restart count
- Port assignments
- Process state
Log Management
- Separate stdout/stderr files
- Automatic log rotation
- Real-time log following
- HTTP log access via API
๐ PMDaemon vs PM2
Feature | PMDaemon | PM2 |
---|---|---|
Port range distribution | โ | โ |
Auto port assignment | โ | โ |
Runtime port override | โ | โ |
Built-in port conflict detection | โ | โ |
Memory limit enforcement | โ | โ |
WebSocket real-time updates | โ | โ |
Rust performance | โ | โ |
PM2-compatible API | โ | โ |
๐ง Library Usage
PMDaemon can also be used as a Rust library:
use ;
async
๐งช Testing
PMDaemon has comprehensive test coverage:
# Run all tests
# Run with coverage
# Run documentation tests
# Run integration tests
# Run end-to-end tests
Test Coverage
- 158 Total Tests
- 120 Unit tests
- 11 Integration tests
- 8 End-to-end tests
- 19 Documentation tests
๐บ๏ธ Roadmap
Completed Features โ
- โ Core process management (Phase 1-3)
- โ CLI interface with all PM2-compatible commands (Phase 5)
- โ Advanced monitoring and logging (Phase 6)
- โ Web API and WebSocket support (Phase 7)
- โ Comprehensive test suite (Phase 9.1-9.3)
In Progress ๐ง
- ๐ API documentation beyond docs.rs
- ๐ Changelog and versioning strategy
- ๐ Release process documentation
Future Enhancements ๐ฎ
- ๐จ v2.0 - Enhanced CLI with ratatui for interactive terminal UI
- ๐ Advanced metrics visualization
- ๐ Plugin system for custom monitors
- ๐ Distributed process management
๐ค Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add some amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
Development Guidelines
- Follow Rust best practices and idioms
- Add tests for new features
- Update documentation as needed
- Ensure all tests pass before submitting PR
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
- Inspired by PM2 - The original Node.js process manager
- Built with Rust for performance and safety
- Uses Tokio for async runtime
- Web server powered by Axum
PMDaemon - Process management, evolved. ๐