Administrere Laravel-arbeidskøer med Beanstalk og Supervisor på Ubuntu 16.04

Beanstalk er en rask og enkel arbeidskø. Den lar deg kjøre tidkrevende oppgaver asynkront, som å sende e-post, koble til eksterne APIer eller behandle bilder. Ved å gjøre det vil du redusere ventetiden for nettappen din. Laravel gir direkte støtte for beanstalkd.

I denne opplæringen vil vi installere beanstalkd, sette opp en demo Laravel-applikasjon og administrere køarbeiderne gjennom Supervisor . Demoapplikasjonen vil få en liste over tilgjengelige operativsystemer fra Vultr API og tilfeldig velge ett.

Det antas at du allerede har Supervisor installert på systemet ditt. Hvis du ikke gjør det, bør du lese følgende veiledning om hvordan du setter opp Supervisor: Installere og konfigurere Supervisor på Ubuntu 16.04

Det antas også at du har SSH-tilgang til din Vultr-instans.

Installere Beanstalk

Det første trinnet å ta er å installere beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Start tjenesten.

sudo systemctl start beanstalkd

Du kan også aktivere tjenesten for å starte ved systeminitialisering.

sudo systemctl enable beanstalkd

Sjekk tjenestestatusen ved å gi følgende kommando.

sudo systemctl status beanstalkd

Som standard, beanstalkdlytter på porten 11300. Beanstalk bruker en enkel tekstbasert protokoll beskrevet i dets github-lager . Du kan teste protokollen ved å kjøre telnet.

telnet localhost 11300

Skriv følgende og trykk ENTER.

list-tubes

Du bør se en liste over tilgjengelige rør på serveren:

OK 14
---
- default

For å lukke tilkoblingen, skriv ganske enkelt quitog trykk deretter ENTER.

Rør i Beanstalk representerer arbeidskøer. Bønnestengel er hovedsakelig sammensatt av produsenter , forbrukere , jobber og rør . Produsenter legger jobber i et rør for å bli konsumert (bearbeidet) av et hvilket som helst antall forbrukere. Merk at både produsenter og forbrukere ganske enkelt er klienter av Beanstalk-serveren og er helt uavhengige av hverandre. Rent praktisk betyr dette at du ved å bruke Beanstalk kan produsere jobbene dine i PHP-applikasjonen din og få den behandlet i for eksempel en NodeJS-app. Heldigvis abstraherer Laravel alt dette og gir oss et veldig enkelt API for å sende og håndtere jobber, som vi vil se neste gang.

Eksempel på prosjekt

For å bygge vårt eksempelprosjekt, må vi først installere avhengighetene. Vi skal installere PHP og Composer.

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

Lag nå prosjektet basert på Laravel 5.5.

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

Neste cdinn i den nylig opprettede mappen. Vi vil jobbe i denne katalogen fra nå av. Denne mappen kan bli referert til senere som PROJECT_ROOT.

cd vultr/

For å bruke Beanstalk i Laravel må vi installere en avhengighet til, PHP Beanstalk-klienten.

composer require pda/pheanstalk ~3.0

Vi må også opprette en jobbrepresentasjon. I Laravel er dette en klasse inne i app/Jobsmappen. Laravel har en konsollkommando for å hjelpe oss med å lage en jobbklasse. La oss lage prøvejobben vår.

php artisan make:job FindFavoriteOS

Oppdater app/Jobs/FindFavoriteOS.phpfilen til følgende.

<?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']);
    }
}

Håndtaksmetoden er det som effektivt vil bli utført når jobben er oppbrukt. Her henter vi data fra Vultr API, velger tilfeldig et OS og skriver det valgte OS til loggfilen. Loggfilen ligger på storage/logs/laravel.log.

Vi har allerede installert Beanstalk og definert jobben som skal utføres av den. Nå er det på tide å fortelle Laravel å bruke Beanstalk som standard arbeidskø. Kopier standardfilen .envfra Laravel-installasjonen.

cp .env.example .env

Åpne nå .envfilen og oppdater linjen der kødriveren er spesifisert.

QUEUE_DRIVER=beanstalkd

Til slutt, generer en applikasjonsnøkkel.

php artisan key:generate

Vi er nå klare til å sende jobber til Beanstalk-arbeidskøen.

Ekspedering og kjøring av jobber

Å sende en jobb i Laravel er ganske enkelt. Oppdater routes/web.phpfilen.

<?php

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

    return '50 Jobs dispatched!';
});

Til tross for at det ikke er anbefalt å kjøre den innebygde serveren i produksjon, vil vi bruke den her for korthets skyld.

php artisan serve --host 0.0.0.0 --port 8000

Nå i en nettleser, naviger til http://[vultr-instance-ip]:8000. Du vil se følgende melding.

50 Jobs dispatched!

Åpne en ny SSH-tilkobling til serveren din og inn i prosjektroten vår, utfør følgende.

php artisan queue:work --once

Dette er forventet utgang:

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

Bekreft at loggen ble generert.

cat storage/logs/laravel.log

Konfigurere Supervisor

For å unngå behovet for å behandle køen manuelt, vil vi bruke supervisord. Opprett følgende programkonfigurasjon i /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

Legg merke til at den riktige banen for å sette Supervisor-konfigurasjonsfilen vil avhenge av oppsettet ditt. Husk også å erstatte [PROJECT_ROOT]med hele banen til PROJECT_ROOTpå systemet ditt.

Her konfigurerer vi Supervisor til å automatisk begynne å behandle køen og, i tilfelle skriptet går i stykker, å starte det på nytt. Vær også oppmerksom på at vi ikke instansierer en enkelt arbeider, men 8 prosesser. Du står fritt til å instansiere hvor mange prosesser du finner nødvendige avhengig av søknaden din.

For å la Supervisor administrere arbeideren vår, tving den til å lese konfigurasjonen på nytt.

sudo supervisorctl reread
sudo supervisorctl update

Hvis Veiledertjenesten ikke er startet, må dere mange starte den.

sudo systemctl start supervisord

La oss nå se om jobbene blir behandlet.

tail -f storage/logs/laravel.log

Naviger til i en nettleser http://[vultr-instance-ip]:8000. Du vil se loggene som genereres på konsollen din.

Konklusjon

Vi har konfigurert en Laravel-applikasjon til å bruke Beanstalk som en arbeidskø. Vi demonstrerte også hvordan man bruker Supervisor til å administrere arbeidere.


Hvordan sette opp en Tekkit Classic Server på Ubuntu 16.10

Hvordan sette opp en Tekkit Classic Server på Ubuntu 16.10

Bruker du et annet system? Hva er Tekkit Classic? Tekkit Classic er en modpack for spillet alle kjenner og elsker; Minecraft. Den inneholder noe av ver

Opprette en Jekyll-blogg på Ubuntu 16.04

Opprette en Jekyll-blogg på Ubuntu 16.04

Bruker du et annet system? Jekyll er et flott alternativ til WordPress for blogging eller deling av innhold. Det krever ingen databaser, og det er veldig enkelt, jeg

Hvordan installere og konfigurere PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

Hvordan installere og konfigurere PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

PHP og relaterte pakker er de mest brukte komponentene når du distribuerer en webserver. I denne artikkelen vil vi lære hvordan du setter opp PHP 7.0 eller PHP 7.1 o

Slik installerer du Squid Proxy på CentOS

Slik installerer du Squid Proxy på CentOS

Squid er et populært, gratis Linux-program som lar deg lage en webproxy for videresending. I denne veiledningen vil du se hvordan du installerer Squid på CentOS for å gjøre deg om

Slik installerer du Lighttpd (LLMP Stack) på CentOS 6

Slik installerer du Lighttpd (LLMP Stack) på CentOS 6

Introduksjon Lighttpd er en apachegaffel som har som mål å være mye mindre ressurskrevende. Den er lett, derav navnet, og er ganske enkel å bruke. Installer

Sette opp en Yii-applikasjon på Ubuntu 14.04

Sette opp en Yii-applikasjon på Ubuntu 14.04

Yii er et PHP-rammeverk som lar deg utvikle applikasjoner raskere og enklere. Det er enkelt å installere Yii på Ubuntu, som du vil lære nøyaktig

Sett opp din egen DNS-server på Debian/Ubuntu

Sett opp din egen DNS-server på Debian/Ubuntu

Denne opplæringen forklarer hvordan du setter opp en DNS-server ved å bruke Bind9 på Debian eller Ubuntu. Bytt ut ditt-domenenavn.com gjennom hele artikkelen. På th

Konfigurering av statisk nettverk og IPv6 på CentOS 7

Konfigurering av statisk nettverk og IPv6 på CentOS 7

VULTR har nylig gjort endringer på sin side, og alt skal nå fungere bra ut av boksen med NetworkManager aktivert. Skulle du ønske å deaktivere

Endring av Icinga2 for å bruke hoved-/klientmodell på CentOS 6 eller CentOS 7

Endring av Icinga2 for å bruke hoved-/klientmodell på CentOS 6 eller CentOS 7

Icinga2 er et kraftig overvåkingssystem, og når det brukes i en master-klient-modell, kan det erstatte behovet for NRPE-baserte overvåkingskontroller. Mester-klienten

Sett opp Red5 Media Server på Ubuntu 16.04

Sett opp Red5 Media Server på Ubuntu 16.04

Bruker du et annet system? Red5 er en åpen kildekode medieserver implementert i Java som lar deg kjøre Flash flerbrukerapplikasjoner som live streamin

Kompiler og installer Nginx med PageSpeed-modulen på Debian 8

Kompiler og installer Nginx med PageSpeed-modulen på Debian 8

I denne artikkelen vil vi se hvordan du kompilerer og installerer Nginx mainline fra de offisielle kildene til Nginx med PageSpeed-modulen, som lar deg t

Hvordan installere Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Hvordan installere Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Bruker du et annet system? Apache Cassandra er et gratis og åpen kildekode NoSQL-databasebehandlingssystem som er designet for å gi skalerbarhet, høy

Slik installerer du Apache Cassandra 3.11.x på CentOS 7

Slik installerer du Apache Cassandra 3.11.x på CentOS 7

Bruker du et annet system? Apache Cassandra er et gratis og åpen kildekode NoSQL-databasebehandlingssystem som er designet for å gi skalerbarhet, høy

Hvordan installere Vanilla Forum på Ubuntu 16.04

Hvordan installere Vanilla Forum på Ubuntu 16.04

Bruker du et annet system? Vanilla forum er en åpen kildekode-forumapplikasjon skrevet i PHP. Det er en fullt tilpassbar, enkel å bruke og støtter ekstern

Hvordan installere Kanboard på Ubuntu 18.04 LTS

Hvordan installere Kanboard på Ubuntu 18.04 LTS

Bruker du et annet system? Introduksjon Kanboard er et gratis og åpen kildekodeprogram for prosjektledelse som er designet for å forenkle og visualisere

Hvordan installere Kanboard på Debian 9

Hvordan installere Kanboard på Debian 9

Bruker du et annet system? Introduksjon Kanboard er et gratis og åpen kildekodeprogram for prosjektledelse som er designet for å forenkle og visualisere

Hvordan installere Gitea på Debian 9

Hvordan installere Gitea på Debian 9

Bruker du et annet system? Gitea er et alternativt åpen kildekode, selvdrevet versjonskontrollsystem drevet av Git. Gitea er skrevet på Golang og er

Hvordan installere Gitea på Ubuntu 18.04

Hvordan installere Gitea på Ubuntu 18.04

Bruker du et annet system? Gitea er et alternativt, selvdrevet versjonskontrollsystem med åpen kildekode drevet av git. Gitea er skrevet på Golang og er

Hvordan installere Thelia 2.3 på Debian 9

Hvordan installere Thelia 2.3 på Debian 9

Bruker du et annet system? Thelia er et åpen kildekodeverktøy for å lage e-business-nettsteder og administrere nettinnhold skrevet i PHP. Thelia kildekode i

Hvordan installere MODX Revolution på en Ubuntu 16.04 LAMP VPS

Hvordan installere MODX Revolution på en Ubuntu 16.04 LAMP VPS

Bruker du et annet system? MODX Revolution er et raskt, fleksibelt, skalerbart, gratis og åpen kildekode, enterprise-grade Content Management System (CMS) skrevet i

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Kunstig intelligens er ikke i fremtiden, det er her akkurat i nåtiden I denne bloggen Les hvordan kunstig intelligens-applikasjoner har påvirket ulike sektorer.

DDOS-angrep: en kort oversikt

DDOS-angrep: en kort oversikt

Er du også et offer for DDOS-angrep og forvirret over forebyggingsmetodene? Les denne artikkelen for å løse spørsmålene dine.

Har du noen gang lurt på hvordan hackere tjener penger?

Har du noen gang lurt på hvordan hackere tjener penger?

Du har kanskje hørt at hackere tjener mye penger, men har du noen gang lurt på hvordan tjener de den slags penger? la oss diskutere.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Vil du se revolusjonerende oppfinnelser fra Google og hvordan disse oppfinnelsene forandret livet til alle mennesker i dag? Les deretter til bloggen for å se oppfinnelser fra Google.

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Konseptet med selvkjørende biler som skal ut på veiene ved hjelp av kunstig intelligens er en drøm vi har hatt en stund nå. Men til tross for flere løfter, er de ingen steder å se. Les denne bloggen for å lære mer...

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Ettersom vitenskapen utvikler seg raskt og tar over mye av innsatsen vår, øker også risikoen for å utsette oss for en uforklarlig singularitet. Les hva singularitet kan bety for oss.

Evolusjon av datalagring – infografikk

Evolusjon av datalagring – infografikk

Lagringsmetodene for dataene har vært i utvikling kan være siden fødselen av dataene. Denne bloggen dekker utviklingen av datalagring på grunnlag av en infografikk.

Funksjonaliteter til Big Data Reference Architecture Layers

Funksjonaliteter til Big Data Reference Architecture Layers

Les bloggen for å kjenne ulike lag i Big Data Architecture og deres funksjoner på den enkleste måten.

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

I denne digitaldrevne verden har smarthusenheter blitt en avgjørende del av livet. Her er noen fantastiske fordeler med smarthusenheter om hvordan de gjør livet vårt verdt å leve og enklere.

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

Nylig lanserte Apple macOS Catalina 10.15.4 en tilleggsoppdatering for å fikse problemer, men det ser ut til at oppdateringen forårsaker flere problemer som fører til muring av mac-maskiner. Les denne artikkelen for å lære mer