nabeghe / process-finger
A PHP library providing utilities to inspect, manage, and interact with system processes across 🐧 Linux, 🍎 Mac, BSD, and 🪟 Windows.
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/nabeghe/process-finger
Requires
- php: >=7.4
README
Process Finger is a PHP utility library for interacting with system processes. It provides a unified, cross-platform interface to retrieve process information, manage processes, and inspect system resources.
⚠️ Warning: This library can terminate processes and manipulate system resources. Use responsibly. Improper usage may cause data loss or system instability.
Features
- Get current process ID and parent process ID
- Retrieve process script paths and process names
- Check if a process exists or is running as root/admin
- Detect zombie processes
- Retrieve memory and CPU usage of processes
- List child processes of a given PID
- Kill, wait for, and restart processes
- Access environment variables of processes (Unix only)
- Fully compatible with Linux, macOS, BSD, and Windows (with limitations)
Installation
Via Composer:
composer require nabeghe/process-finger
Or manually include the ProcessFinger.php file in your project.
Usage
use Nabeghe\ProcessFinger; // Get current PID $pid = Process::getId(); // Check if a process exists $exists = Process::exists($pid); // Kill a process Process::kill($pid, true); // Restart a process $newPid = Process::restart($pid, 'php script.php'); // Get memory usage $memory = Process::getMemoryUsage($pid); // Get CPU usage $cpu = Process::getCpuUsage($pid); // Get process environment (Unix only) $env = Process::getProcessEnv($pid); // List child processes $children = Process::listChildren($pid); // Get process name $name = Process::getProcessName($pid); // Check if running as root/admin $isRoot = Process::isRunningAsRoot(); // Check if process is zombie $isZombie = Process::isZombie($pid); // Wait for process to exit Process::wait($pid, 5); // Wait up to 5 seconds
Methods Overview
| Method | Description | Notes |
|---|---|---|
getId() |
Returns current process ID | |
getParentId(?int $pid = null) |
Returns parent PID | Defaults to current process |
getScriptPath(?int $pid = null) |
Absolute path of the process script | Requires shell_exec enabled |
getProcessName(?int $pid = null) |
Main command / process name | |
exists(int $pid) |
Check if a process exists | Returns true/false/null |
isRunningAsRoot() |
Check if current process has root/admin privileges | Windows uses net session command |
isZombie(int $pid) |
Detect zombie processes | Unix only |
getMemoryUsage(?int $pid = null) |
Memory usage in bytes | |
getCpuUsage(?int $pid = null) |
CPU usage percent | Limited precision on Windows |
getProcessEnv(?int $pid = null) |
Get process environment variables | Unix only |
listChildren(?int $pid = null) |
List child process IDs | |
kill(int $pid, bool $force = true) |
Terminate a process | Uses SIGKILL/SIGTERM on Unix, taskkill on Windows |
wait(int $pid, int $timeout = 0) |
Wait until process exits | Timeout in seconds, 0 = infinite |
restart(int $pid, string $command, bool $force = true) |
Kill and restart a process | Returns new PID if started successfully |
Security & Risks
- Process Termination: Misuse of
kill()orrestart()may terminate critical system processes. Always double-check PIDs before calling these methods. - Privilege Checks: Running with root/admin privileges increases risk. Avoid using these methods on critical processes.
- Environment Variables:
getProcessEnv()is only available on Unix-like systems. Accessing environment data may contain sensitive information. - Zombie Detection: Only meaningful on Unix-like systems. Windows does not support zombie processes.
- Cross-Platform Differences: Some commands behave differently on Windows vs Linux/macOS. Always test on your target OS.
📖 License
Licensed under the MIT license, see LICENSE.md for details.