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


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.

dlaravel,docker

D-Laravel learning three stages

Chat about the three stages of using D-Laravel, why use D-Laravel. Because the configuration files used by D-Laravel are quite simple, it is very suitable for beginners of Docker to learn, And users who do not know how to use Docker can also use the two commands ./console and ./create to create a project.

dlaravel

How to automatically detect and update the certificate issued by let's encrypt through getssl

It's really great that let's encrypt provides free certificates. However, is it a bit troublesome to update the certificate every three months? This article introduces how to generate multi-domain SAN certificate settings through getssl, and schedule automatic certificate renewal. It's very simple, just six steps to get it done.