Gestió de cues de treball de Laravel amb Beanstalk i Supervisor a Ubuntu 16.04

Beanstalk és una cua de treball ràpida i senzilla. Us permet executar tasques que requereixen temps de manera asíncrona, com ara enviar correus electrònics, connectar-vos a API externes o processar imatges. En fer-ho, reduireu la latència de l'aplicació web. Laravel ofereix assistència immediata per a beanstalkd.

En aquest tutorial instal·larem beanstalkd, configurarem una aplicació de demostració Laravel i gestionarem els treballadors de la cua mitjançant Supervisor . L'aplicació de demostració obtindrà una llista de sistemes operatius disponibles de l' API Vultr i en triarà un a l'atzar.

Se suposa que ja teniu Supervisor instal·lat al vostre sistema. Si no ho feu, hauríeu de llegir el següent tutorial sobre com configurar Supervisor: Instal·lació i configuració del Supervisor a Ubuntu 16.04

També se suposa que teniu accés SSH a la vostra instància Vultr.

Instal·lació de Beanstalk

El primer pas a fer és instal·lar beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Inicieu el servei.

sudo systemctl start beanstalkd

També podeu habilitar el servei per iniciar-se després de la inicialització del sistema.

sudo systemctl enable beanstalkd

Comproveu l'estat del servei emetent l'ordre següent.

sudo systemctl status beanstalkd

Per defecte, beanstalkdescolta al port 11300. Beanstalk utilitza un protocol senzill basat en text descrit al seu repositori github . Podeu provar el seu protocol executant telnet.

telnet localhost 11300

Escriu el següent i fes clic ENTER.

list-tubes

Hauríeu de veure una llista de tubs disponibles al servidor:

OK 14
---
- default

Per tancar la connexió, simplement escriviu quiti després premeu ENTER.

Els tubs de Beanstalk representen cues de treball. Beanstalk està compost bàsicament per productors , consumidors , llocs de treball i tubs . Els productors posen llocs de treball en un tub per ser consumits (processats) per qualsevol nombre de consumidors. Tingueu en compte que tant els productors com els consumidors són simplement clients del servidor Beanstalk i són totalment independents els uns dels altres. En termes pràctics, això vol dir que utilitzant Beanstalk podeu produir els vostres treballs a la vostra aplicació PHP i processar-los en una aplicació NodeJS, per exemple. Afortunadament, Laravel resumeix tot això i ens proporciona una API molt senzilla per enviar i gestionar treballs, com veurem a continuació.

Projecte de mostra

Per construir el nostre projecte de mostra, primer hem d'instal·lar-ne les dependències. Instal·larem PHP i Composer.

sudo apt-get install php php-mbstring php-xml php-common php-zip composer

Ara, creeu el projecte basat en Laravel 5.5.

composer create-project --prefer-dist laravel/laravel vultr "5.5.*"

A continuació, cda la carpeta creada recentment. A partir d'ara treballarem en aquest directori. Aquesta carpeta es pot fer referència més endavant com a PROJECT_ROOT.

cd vultr/

Per utilitzar Beanstalk a Laravel hem d'instal·lar una dependència més, el client PHP Beanstalk.

composer require pda/pheanstalk ~3.0

També hem de crear una representació laboral. A Laravel, aquesta és una classe dins de la app/Jobscarpeta. Laravel té una comanda de consola per ajudar-nos a crear una classe de treball. Creem el nostre treball de mostra.

php artisan make:job FindFavoriteOS

Actualitzeu el app/Jobs/FindFavoriteOS.phpfitxer al següent.

<?php

namespace App\Jobs;

use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Support\Facades\Log;

class FindFavoriteOS implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;

    /**
     * Create a new job instance.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        $rawData = file_get_contents('https://api.vultr.com/v1/os/list');
        $list = json_decode($rawData, true);
        shuffle($list);
        $key = array_rand($list);
        $favorite = $list[$key];
        Log::info('My Favorite OS is: ' . $favorite['name']);
    }
}

El mètode de manipulació és el que s'executarà de manera efectiva quan es consumeixi el treball. Aquí, obtenim dades de l'API Vultr, escollim un sistema operatiu aleatòriament i escrivim el sistema operatiu escollit al fitxer de registre. El fitxer de registre es troba a storage/logs/laravel.log.

Ja hem instal·lat Beanstalk i hem definit el treball que ha d'executar-lo. Ara és el moment de dir-li a Laravel que utilitzi Beanstalk com a cua de treball predeterminada. Copieu el .envfitxer predeterminat proporcionat per la instal·lació de Laravel.

cp .env.example .env

Ara obriu el .envfitxer i actualitzeu la línia on s'especifica el controlador de la cua.

QUEUE_DRIVER=beanstalkd

Finalment, genereu una clau d'aplicació.

php artisan key:generate

Ara estem preparats per enviar treballs a la cua de treball de Beanstalk.

Despatx i execució de feines

Enviar una feina a Laravel és bastant senzill. Actualitza el routes/web.phpfitxer.

<?php

Route::get('/', function () {
    for ($i = 0; $i < 50; $i++) {
        \App\Jobs\FindFavoriteOS::dispatch();
    }

    return '50 Jobs dispatched!';
});

Tot i que no se'ns recomana executar el servidor proporcionat integrat en producció, aquí l'utilitzarem per a la brevetat.

php artisan serve --host 0.0.0.0 --port 8000

Ara, en un navegador web, navegueu a http://[vultr-instance-ip]:8000. Veureu el missatge següent.

50 Jobs dispatched!

Obriu una nova connexió SSH al vostre servidor i dins de l'arrel del nostre projecte, executeu el següent.

php artisan queue:work --once

Aquesta és la sortida esperada:

[2018-02-14 00:03:52] Processing: App\Jobs\FindFavoriteOS
[2018-02-14 00:03:53] Processed:  App\Jobs\FindFavoriteOS

Confirmeu que s'ha generat el registre.

cat storage/logs/laravel.log

Configuració del supervisor

Per evitar la necessitat de processar manualment la cua, farem servir supervisord. Creeu la configuració del programa següent a /etc/supervisor/conf.d/vultr.conf.

[program:vultr]
process_name=%(program_name)s_%(process_num)02d
command=php [PROJECT_ROOT]/artisan queue:work
autostart=true
autorestart=true
numprocs=8
redirect_stderr=true
stdout_logfile=/var/log/worker.log

Tingueu en compte que el camí correcte per posar el fitxer de configuració del supervisor dependrà de la vostra configuració. A més, recordeu substituir-lo [PROJECT_ROOT]amb el camí complet PROJECT_ROOTal vostre sistema.

Aquí estem configurant el Supervisor perquè comenci automàticament a processar la cua i, en cas de trencar l'script, el reiniciï. Tingueu en compte també que no estem instanciant un sol treballador, sinó 8 processos. Sou lliure d'instanciar tots els processos que considereu necessaris en funció de la vostra aplicació.

Per permetre que el supervisor gestioni el nostre treballador, obligueu-lo a tornar a llegir la seva configuració.

sudo supervisorctl reread
sudo supervisorctl update

Si el servei de supervisor no s'ha iniciat, molts haureu d'iniciar-lo.

sudo systemctl start supervisord

Ara vegem si s'estan processant les feines.

tail -f storage/logs/laravel.log

En un navegador web, navegueu a http://[vultr-instance-ip]:8000. Veureu els registres que es generen a la vostra consola.

Conclusió

Hem configurat correctament una aplicació Laravel per utilitzar Beanstalk com a cua de treball. A més, vam demostrar com utilitzar Supervisor per gestionar els treballadors.


Leave a Comment

Instal·leu Plesk a CentOS 7

Instal·leu Plesk a CentOS 7

Utilitzeu un sistema diferent? Plesk és un tauler de control d'amfitrió web propietari que permet als usuaris administrar els seus llocs web personals i/o de clients, bases de dades

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Instal·leu Lets Encrypt SSL a laplicació de WordPress dun sol clic

Introducció Lets Encrypt és un servei d'autoritat de certificació que ofereix certificats TLS/SSL gratuïts. El procés d'instal·lació està simplificat per Certbot,

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Com configurar un servidor Tekkit Classic a Ubuntu 16.10

Utilitzeu un sistema diferent? Què és Tekkit Classic? Tekkit Classic és un modpack per al joc que tothom coneix i estima; Minecraft. Conté algunes de la ver

Creació dun bloc Jekyll a Ubuntu 16.04

Creació dun bloc Jekyll a Ubuntu 16.04

Utilitzeu un sistema diferent? Jekyll és una gran alternativa a WordPress per crear blocs o compartir contingut. No requereix cap base de dades i és molt fàcil

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Com configurar actualitzacions desateses a Debian 9 (Stretch)

Utilitzeu un sistema diferent? Si compres un servidor Debian, sempre hauríeu de tenir els darrers pedaços i actualitzacions de seguretat, tant si esteu adormit com si no.

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

Com instal·lar i configurar PHP 7.0 o PHP 7.1 a Ubuntu 16.04

PHP i els paquets relacionats són els components més utilitzats quan es desplega un servidor web. En aquest article, aprendrem a configurar PHP 7.0 o PHP 7.1 o

Com instal·lar Squid Proxy a CentOS

Com instal·lar Squid Proxy a CentOS

Squid és un popular programa Linux gratuït que us permet crear un servidor intermediari web de reenviament. En aquesta guia, veureu com instal·lar Squid a CentOS per convertir-vos-hi

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Introducció Lighttpd és una bifurcació d'Apache destinada a ser molt menys intensiu en recursos. És lleuger, d'aquí el seu nom, i és bastant senzill d'utilitzar. Instal·lant

Tres panells de control de servidor gratuïts (instal·lació ràpida)

Tres panells de control de servidor gratuïts (instal·lació ràpida)

1. Virtualmin/Webmin Virtualmin és un tauler de control d'allotjament web potent i flexible per a sistemes Linux i UNIX basat en la coneguda base web de codi obert

Configuració duna aplicació Yii a Ubuntu 14.04

Configuració duna aplicació Yii a Ubuntu 14.04

Yii és un framework PHP que permet desenvolupar aplicacions de manera més ràpida i senzilla. Instal·lar Yii a Ubuntu és senzill, ja que aprendràs exactament

Ús de Screen a Ubuntu 14.04

Ús de Screen a Ubuntu 14.04

Screen és una aplicació que permet l'ús múltiple de sessions de terminal dins d'una finestra. Això us permet simular diverses finestres de terminal on es fa

Configura el teu propi servidor DNS a Debian/Ubuntu

Configura el teu propi servidor DNS a Debian/Ubuntu

Aquest tutorial explica com configurar un servidor DNS amb Bind9 a Debian o Ubuntu. Al llarg de l'article, substituïu el vostre-nom-domini.com en conseqüència. Al th

Ús de Logrotate per gestionar fitxers de registre

Ús de Logrotate per gestionar fitxers de registre

Introducció Logrotate és una utilitat Linux que simplifica l'administració dels fitxers de registre. Normalment s'executa un cop al dia mitjançant un treball cron i gestiona la base de registres

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Recentment, VULTR ha fet canvis al seu extrem, i ara tot hauria de funcionar bé des de la caixa amb NetworkManager habilitat. Si voleu desactivar

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Icinga2 és un sistema de supervisió potent i, quan s'utilitza en un model de client mestre, pot substituir la necessitat de controls de monitoratge basats en NRPE. El mestre-client

Configura Red5 Media Server a Ubuntu 16.04

Configura Red5 Media Server a Ubuntu 16.04

Utilitzeu un sistema diferent? Red5 és un servidor multimèdia de codi obert implementat a Java que us permet executar aplicacions Flash multiusuari com ara la transmissió en directe.

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

Compileu i instal·leu Nginx amb el mòdul PageSpeed ​​a Debian 8

En aquest article, veurem com compilar i instal·lar la línia principal de Nginx des de les fonts oficials de Nginx amb el mòdul PageSpeed, que us permet

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Com instal·lar Apache Cassandra 3.11.x a Ubuntu 16.04 LTS

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Vanilla Forum a Ubuntu 16.04

Com instal·lar Vanilla Forum a Ubuntu 16.04

Utilitzeu un sistema diferent? Vanilla Forum és una aplicació de fòrum de codi obert escrita en PHP. És totalment personalitzable, fàcil d'utilitzar i admet externa

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació