by Devin Yang
(This article was automatically translated.)

Published - 7 years ago ( Updated - 7 years ago )

foreword

Since queue workers are a long-running program, we need a program manager supervisor to monitor whether the process on the Linux system is running continuously. For example, when the queue:work operation fails, the queue:work process can be automatically restarted. Fortunately, D-Laravel has a built-in supervisor, so it can be used without installing it on Mac OS.

When you want to use the queue function on Laravel and Laravle Echo and Events and Broadcasting or Notifications,
You should already be using the supervisor application.

Running supervisor on D-Laravel is quite simple.
You need to update to D-Laravel v1.2.15 to support ./console supervisor start command.

If you use the old version of D-Laravel, you can use Docker official instructions to execute, which will be mentioned in this article.
 

SUPERVISOR trilogy

1. Create a supervisor configuration file to the etc/supervisor folder in D-Laravel
In fact, there is already a sample in it,
So we can simply copy this sample to modify it.
It is assumed that dlaravel is installed in our home directory, so the command is as follows:
cd ~/dlaravel/etc/supervisor
cp laravel-worker.conf.sample laravel-worker.conf
vim laravel-work.conf laravl-work.conf
In the above command setting, I use Laravel's default queue, so I don't specify --quque=.
myproject is the project we want to execute queue:work in D-Laravel's sites folder.

2. Lift the seal
In docker-compose.yml, remove the # comment on the supervisor setting mount in the php service section.
comment out supervisor

3. Execute the super Xiaoqiang in the php container, oh wrong, it is supervisor.
D-Laravel is the environment of docker. Of course, we can use the official instructions to execute the commands in the container.
The syntax executed in the folder of dlaravel is as follows:
docker-compose exec php /etc/init.d/supervisor start

Remember, in the second step above , we removed the comment # , so that the php container can mount the etc/supervisor folder in the dlaravel directory on our host.
And in the first step , we also produced the laravel-work.conf file, so the supervisor in the php container can be started according to our laravel-work.conf settings.

For Linux beginners, it may be difficult to remember such a long command, so a simple bash is provided in the new version of D-Laravel ,
Let us save a few words, we can start or stop supervisor through ./console
./console supervisor start
or
./console supervisor restart

4. Detect whether the program in the container is executed (additional supplement).
We can check whether the supervisor program in the container is executed through ./console top command.
./console top php

./console top php
 

Tags: dlaravel

Devin Yang

Feel free to ask me, if you don't get it.:)

No Comment

Post your comment

Login is required to leave comments

Similar Stories


dlaravel

How to directly execute the php artisan of different projects in the container on the host.

This article is the application teaching of D-Laravel, how to directly execute php artisan in the container on the host side. After customizing the alias, you can directly execute php artisan in the contianer in the project folder on the host side. alias a="../../artisan.sh"

dlaravel

Description of .env.example file on D-Laravel

This article explains about the .env settings on D-Laravel MYSQL_ROOT_PASSWORD=secret LARAVEL_INSTALLER='container' DOCKER_SERVICES='docker-compose.yml service/redis.yml'

docker,dlaravel

D-Laravel 1.5.5 Change Notes

D-Laravel's fpm image was rebuilt using the official dockerfile of docker php before php 7.2.1. And so I can specify that the default owner of fpm is dlaravel, --with-fpm-user=USER Set the user for php-fpm to run as. (default: nobody) --with-fpm-group=GRP Set the group for php-fpm to run as.