Home > Backend Development > PHP Tutorial > Supervisor Guide for PHP Developers

Supervisor Guide for PHP Developers

Patricia Arquette
Release: 2025-01-20 12:03:12
Original
991 people have browsed it

Supervisor Guide for PHP Developers

Supervisor: A Robust Process Control System for PHP Applications

Supervisor is a powerful tool for managing background processes, a necessity for PHP developers handling long-running tasks, queue workers, and other background jobs. This guide details Supervisor setup, PHP application integration, and comprehensive configuration for optimal performance.

Understanding Supervisor

Supervisor excels at managing background tasks by:

  • Automatically restarting crashed processes.
  • Centralized logging for easier monitoring.
  • Command-line and web interface control.

It's particularly beneficial for PHP projects employing:

  • Laravel queues for asynchronous processing.
  • Persistent processes like WebSocket servers.
  • Scheduled tasks akin to cron jobs.

Installing Supervisor

Ubuntu/Debian:

<code class="language-bash">sudo apt update
sudo apt install supervisor</code>
Copy after login
Copy after login

CentOS/RedHat:

<code class="language-bash">sudo yum install epel-release
sudo yum install supervisor</code>
Copy after login
Copy after login

Post-installation, activate and enable Supervisor:

<code class="language-bash">sudo systemctl start supervisord
sudo systemctl enable supervisord</code>
Copy after login
Copy after login

Supervisor Configuration

Supervisor utilizes configuration files (typically located in /etc/supervisor/conf.d/) to manage individual programs.

Basic Configuration Example:

Create /etc/supervisor/conf.d/my_php_worker.conf with this content:

<code class="language-ini">[program:my_php_worker]
command=php /path/to/worker.php
autostart=true
autorestart=true
stderr_logfile=/var/log/my_php_worker.err.log
stdout_logfile=/var/log/my_php_worker.out.log</code>
Copy after login

The --tries=3 option (within the command directive) limits restart attempts to three before failure.

Apply the configuration:

<code class="language-bash">sudo supervisorctl reread
sudo supervisorctl update
sudo supervisorctl start my_php_worker:*</code>
Copy after login

Detailed Configuration Options

Here's a detailed breakdown of Supervisor configuration options:

  1. command: The command to execute. Example: command=php /path/to/worker.php

  2. autostart: Automatically starts the program with Supervisor. Values: true (default), false. Example: autostart=true

  3. autorestart: Automatic restart on failure. Values: true, false, unexpected. Example: autorestart=unexpected

  4. startsecs: Minimum runtime (seconds) before a process is considered started. Default: 1. Example: startsecs=5

  5. startretries: Maximum restart attempts before failure. Default: 3. Example: startretries=5

  6. exitcodes: Acceptable exit codes preventing restarts. Default: 0,2. Example: exitcodes=0,1

  7. stopwaitsecs: Time (seconds) to wait for graceful shutdown before forceful termination. Default: 10. Example: stopwaitsecs=20

  8. redirect_stderr: Redirect standard error to standard output. Values: true, false (default). Example: redirect_stderr=true

  9. stdout_logfile / stderr_logfile: Log file paths for standard output and error. Example: stdout_logfile=/var/log/my_program.out.log

  10. stdout_logfile_maxbytes / stderr_logfile_maxbytes: Maximum log file size before rotation. Default: 50MB. Example: stdout_logfile_maxbytes=10MB

  11. stdout_logfile_backups / stderr_logfile_backups: Number of rotated log files to retain. Default: 10. Example: stdout_logfile_backups=3

  12. user: System user to run the program as. Example: user=www-data

  13. environment: Environment variables. Example: environment=APP_ENV="production",DB_HOST="localhost"

  14. priority: Start order (lower values start first). Default: 999. Example: priority=100

  15. directory: Working directory. Example: directory=/path/to/your/app

  16. stopasgroup: Send stop signal to the process and its children. Values: true, false (default). Example: stopasgroup=true

  17. killasgroup: Forcefully kill the process and its children after stopwaitsecs. Values: true, false (default). Example: killasgroup=true

PHP-Specific Use Cases

  1. Laravel Queues: Manage queue:work command for reliable job processing.

    <code class="language-bash">sudo apt update
    sudo apt install supervisor</code>
    Copy after login
    Copy after login
  2. Scheduled Tasks: Replace cron for more robust scheduled script execution.

    <code class="language-bash">sudo yum install epel-release
    sudo yum install supervisor</code>
    Copy after login
    Copy after login
  3. Long-Running Scripts: Manage persistent scripts like WebSocket servers.

    <code class="language-bash">sudo systemctl start supervisord
    sudo systemctl enable supervisord</code>
    Copy after login
    Copy after login

Automating Supervisor Startup

Ensure Supervisor starts on system boot:

  1. Enable Supervisor service: sudo systemctl enable supervisord

  2. Start the service (if needed): sudo systemctl start supervisord

Best Practices

  • Use descriptive program names.
  • Configure log rotation using stdout_logfile_maxbytes and stdout_logfile_backups.
  • Utilize the environment directive to manage variables.

Conclusion

Supervisor is an essential tool for PHP developers managing background processes. This guide provides a comprehensive introduction to its installation, configuration, and practical applications, ensuring reliable and efficient task management for your PHP projects.

The above is the detailed content of Supervisor Guide for PHP Developers. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template