Supervisor is process monitor for Linux. It automatically starts your console processes. For install on Ubuntu you need run command:
sudo apt-get install supervisor
Supervisor config files usually available in /etc/supervisor/conf.d
. You can create any number of
config files.
Config example:
[program:yii-queue-worker]
process_name=%(program_name)s_%(process_num)02d
command=/usr/bin/php /var/www/my_project/yii queue/listen --verbose=1 --color=0
autostart=true
autorestart=true
user=www-data
numprocs=4
redirect_stderr=true
stdout_logfile=/var/www/my_project/log/yii-queue-worker.log
In this case Supervisor must starts 4 queue/listen
workers. Worker output will write into log
file.
For more info about Supervisor's configure and usage see documentation.
Worker starting in daemon mode with queue/listen
command supports File, Db, Redis,
[RabbitMQ], [AMQP Interop], Beanstalk, Gearman drivers. For additional options see driver guide.
Systemd is an init system used in Linux to bootstrap the user space. To configure workers startup
using systemd, create a config file named yii-queue@.service
in /etc/systemd/system
with
the following contents:
[Unit]
Description=Yii Queue Worker %I
After=network.target
# the following two lines only apply if your queue backend is mysql
# replace this with the service that powers your backend
After=mysql.service
Requires=mysql.service
[Service]
User=www-data
Group=www-data
ExecStart=/usr/bin/php /var/www/my_project/yii queue/listen --verbose
Restart=on-failure
[Install]
WantedBy=multi-user.target
You need to reload systemd in order for it to re-read configuration:
systemctl daemon-reload
Set of commands to control workers:
# To start two workers
systemctl start yii-queue@1 yii-queue@2
# To get status of running workers
systemctl status "yii-queue@*"
# To stop the worker
systemctl stop yii-queue@2
# To stop all running workers
systemctl stop "yii-queue@*"
# To start two workers at system boot
systemctl enable yii-queue@1 yii-queue@2
To learn all features of systemd, check its documentation.
You can start worker using cron. You have to use queue/run
command. It works as long as queue
contains jobs.
Config example:
* * * * * /usr/bin/php /var/www/my_project/yii queue/run
In this case cron will start the command every minute.
queue/run
command is supported by File, Db, Redis, Beanstalk, Gearman drivers.
For additional options see driver guide.