Håndtering af Laravel-arbejdskøer med Beanstalk og Supervisor på Ubuntu 16.04

Beanstalk er en hurtig og enkel arbejdskø. Det giver dig mulighed for at køre tidskrævende opgaver asynkront, såsom at sende e-mails, oprette forbindelse til eksterne API'er eller behandle billeder. Ved at gøre det reducerer du din webapp-forsinkelse. Laravel giver out-of-the-box support til beanstalkd.

I denne vejledning vil vi installere beanstalkd, opsætte en demo Laravel-applikation og administrere køarbejderne gennem Supervisor . Demoapplikationen vil få en liste over tilgængelige OS'er fra Vultr API og tilfældigt vælge en.

Det antages, at du allerede har Supervisor installeret på dit system. Hvis du ikke gør det, bør du læse følgende vejledning om, hvordan du opsætter Supervisor: Installation og konfiguration af Supervisor på Ubuntu 16.04

Det antages også, at du har SSH-adgang til din Vultr-instans.

Installation af Beanstalk

Det første skridt at tage er at installere beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Start tjenesten.

sudo systemctl start beanstalkd

Du kan også aktivere tjenesten til at starte ved systeminitialisering.

sudo systemctl enable beanstalkd

Tjek servicestatus ved at udstede følgende kommando.

sudo systemctl status beanstalkd

Lytter som standard beanstalkdpå porten 11300. Beanstalk bruger en simpel tekstbaseret protokol beskrevet i dets github-lager . Du kan teste dens protokol ved at køre telnet.

telnet localhost 11300

Skriv følgende og tryk på ENTER.

list-tubes

Du bør se en liste over tilgængelige rør på serveren:

OK 14
---
- default

For at lukke forbindelsen skal du blot skrive quitog derefter trykke på ENTER.

Rør i Beanstalk repræsenterer arbejdskøer. Bønnestilk består grundlæggende af producenter , forbrugere , jobs og rør . Producenterne lægger job i et rør for at blive forbrugt (bearbejdet) af et vilkårligt antal forbrugere. Bemærk, at både producenter og forbrugere simpelthen er klienter af Beanstalk-serveren og er fuldstændig uafhængige af hinanden. Rent praktisk betyder det, at du ved at bruge Beanstalk kan producere dine jobs i din PHP-applikation og få dem behandlet i en NodeJS-app for eksempel. Heldigvis abstraherer Laravel alt dette og giver os en meget enkel API til at sende og håndtere job, som vi vil se næste gang.

Eksempel på projekt

For at bygge vores eksempelprojekt skal vi først installere dets afhængigheder. Vi skal installere PHP og Composer.

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

Opret nu projektet baseret på Laravel 5.5.

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

Næste cdi den nyligt oprettede mappe. Vi vil arbejde i denne mappe fra nu af. Denne mappe kan senere henvises til som PROJECT_ROOT.

cd vultr/

For at bruge Beanstalk i Laravel skal vi installere endnu en afhængighed, PHP Beanstalk-klienten.

composer require pda/pheanstalk ~3.0

Vi skal også oprette en jobrepræsentation. I Laravel er dette en klasse inde i app/Jobsmappen. Laravel har en konsolkommando til at hjælpe os med at oprette en jobklasse. Lad os skabe vores eksempeljob.

php artisan make:job FindFavoriteOS

Opdater 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åndteringsmetoden er det, der effektivt vil blive udført, når jobbet er opbrugt. Her henter vi data fra Vultr API, vælger tilfældigt et OS og skriver det valgte OS til logfilen. Logfilen er placeret på storage/logs/laravel.log.

Vi har allerede installeret Beanstalk og defineret det job, der skal udføres af det. Nu er det tid til at fortælle Laravel at bruge Beanstalk som standard arbejdskø. Kopier standardfilen .envfra Laravel-installationen.

cp .env.example .env

Åbn nu .envfilen og opdater linjen, hvor kødriveren er angivet.

QUEUE_DRIVER=beanstalkd

Til sidst skal du generere en applikationsnøgle.

php artisan key:generate

Vi er nu klar til at sende jobs til Beanstalk-arbejdskøen.

Ekspediering og afvikling af jobs

At sende et job i Laravel er ret simpelt. Opdater routes/web.phpfilen.

<?php

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

    return '50 Jobs dispatched!';
});

Selvom det ikke anbefales at køre den indbyggede server i produktionen, vil vi bruge den her for korthedens skyld.

php artisan serve --host 0.0.0.0 --port 8000

Naviger nu til i en webbrowser http://[vultr-instance-ip]:8000. Du vil se følgende besked.

50 Jobs dispatched!

Åbn en ny SSH-forbindelse til din server og inde i vores projektrod, udfør følgende.

php artisan queue:work --once

Dette er det forventede output:

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

Bekræft, at loggen blev genereret.

cat storage/logs/laravel.log

Konfiguration af Supervisor

For at undgå behovet for manuelt at behandle køen, vil vi bruge supervisord. Opret følgende programkonfiguration 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

Bemærk, at den rigtige vej til at placere Supervisor-konfigurationsfilen afhænger af din opsætning. Husk også at erstatte [PROJECT_ROOT]med den fulde sti til PROJECT_ROOTpå dit system.

Her konfigurerer vi Supervisor til automatisk at begynde at behandle køen og, i tilfælde af at scriptet går i stykker, genstarte det. Bemærk også, at vi ikke instansierer en enkelt arbejder, men 8 processer. Du er fri til at instansiere, hvor mange processer du finder nødvendige afhængigt af din applikation.

For at tillade Supervisor at administrere vores medarbejder, tving den til at genlæse sin konfiguration.

sudo supervisorctl reread
sudo supervisorctl update

Hvis Supervisor-tjenesten ikke er startet, er I mange nødt til at starte den.

sudo systemctl start supervisord

Lad os nu se, om opgaverne bliver behandlet.

tail -f storage/logs/laravel.log

Naviger til i en webbrowser http://[vultr-instance-ip]:8000. Du vil se logfilerne blive genereret på din konsol.

Konklusion

Vi har konfigureret en Laravel-applikation til at bruge Beanstalk som en arbejdskø. Vi demonstrerede også, hvordan man bruger Supervisor til at styre medarbejdere.


Installer Plesk på CentOS 7

Installer Plesk på CentOS 7

Bruger du et andet system? Plesk er et proprietært webhost kontrolpanel, der giver brugerne mulighed for at administrere deres personlige og/eller klienters websteder, databaser

Sådan konfigureres uovervågede opgraderinger på Debian 9 (Stretch)

Sådan konfigureres uovervågede opgraderinger på Debian 9 (Stretch)

Bruger du et andet system? Hvis du køber en Debian-server, bør du altid have de nyeste sikkerhedsrettelser og opdateringer, uanset om du sover eller ej

Sådan installeres Squid Proxy på CentOS

Sådan installeres Squid Proxy på CentOS

Squid er et populært, gratis Linux-program, der giver dig mulighed for at oprette en webproxy til videresendelse. I denne vejledning vil du se, hvordan du installerer Squid på CentOS for at gøre dig

Opsæt din egen DNS-server på Debian/Ubuntu

Opsæt din egen DNS-server på Debian/Ubuntu

Denne vejledning forklarer, hvordan man opsætter en DNS-server ved hjælp af Bind9 på Debian eller Ubuntu. Gennem hele artiklen skal du erstatte dit-domænenavn.com i overensstemmelse hermed. Ved th

Konfigurer Red5 Media Server på Ubuntu 16.04

Konfigurer Red5 Media Server på Ubuntu 16.04

Bruger du et andet system? Red5 er en open source medieserver implementeret i Java, der giver dig mulighed for at køre Flash multi-bruger applikationer såsom live streamin

Sådan installeres Vanilla Forum på Ubuntu 16.04

Sådan installeres Vanilla Forum på Ubuntu 16.04

Bruger du et andet system? Vanilla forum er en open source forumapplikation skrevet i PHP. Det er en fuldt tilpasselig, nem at bruge og understøtter ekstern

Installer Lynis på Debian 8

Installer Lynis på Debian 8

Introduktion Lynis er et gratis, open source-systemrevisionsværktøj, der bruges af mange systemadministratorer til at verificere integriteten og hærde deres systemer. jeg

Sådan installeres Microweber på CentOS 7

Sådan installeres Microweber på CentOS 7

Bruger du et andet system? Microweber er en open source træk og slip CMS og online shop. Microweber-kildekoden er hostet på GitHub. Denne guide vil vise dig

Installation af Microweber på Ubuntu 16.04

Installation af Microweber på Ubuntu 16.04

Bruger du et andet system? Microweber er en open source træk og slip CMS og online shop. Microweber-kildekoden er hostet på GitHub. Denne guide vil vise dig

Sådan installeres Mattermost 4.1 på CentOS 7

Sådan installeres Mattermost 4.1 på CentOS 7

Bruger du et andet system? Mattermost er et open source, selvhostet alternativ til Slack SAAS-meddelelsestjenesten. Med andre ord, med Mattermost er du ca

Sådan installeres dotCMS på Ubuntu 16.04

Sådan installeres dotCMS på Ubuntu 16.04

Bruger du et andet system? DotCMS er et open source, enterprise-grade content management system skrevet i Java. Den indeholder næsten alle nødvendige funktioner

Sådan installeres BigTree CMS på en Fedora 26 LAMP VPS

Sådan installeres BigTree CMS på en Fedora 26 LAMP VPS

Bruger du et andet system? BigTree CMS 4.2 er et hurtigt og let, gratis og open source, enterprise-grade content management system (CMS) med omfattende

Oprettelse af et netværk af Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Oprettelse af et netværk af Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Hvad skal du bruge En Vultr VPS med mindst 1 GB RAM. SSH-adgang (med root/administrative rettigheder). Trin 1: Installation af BungeeCord Første ting først

Installation af Docker CE på Ubuntu 16.04

Installation af Docker CE på Ubuntu 16.04

Bruger du et andet system? Docker er et program, der gør det muligt at implementere programmer, der køres som containere. Det blev skrevet i det populære Go-programmin

Sådan installeres Golang 1.8.3 på CentOS 7, Ubuntu 16.04 og Debian 9

Sådan installeres Golang 1.8.3 på CentOS 7, Ubuntu 16.04 og Debian 9

Golang er et programmeringssprog udviklet af Google. Takket være sin alsidighed, enkelhed og pålidelighed er Golang blevet en af ​​de mest populære

Lad os kryptere på Plesk

Lad os kryptere på Plesk

Plesk-kontrolpanelet har en meget flot integration til Lets Encrypt. Lets Encrypt er en af ​​de eneste SSL-udbydere, der udleverer certifikater komplet

Lader kryptere på cPanel

Lader kryptere på cPanel

Lets Encrypt er en certifikatmyndighed dedikeret til at levere SSL-certifikater gratis. cPanel har bygget en pæn integration, så du og din klient

Nulstil MySQL Root Password på Debian/Ubuntu

Nulstil MySQL Root Password på Debian/Ubuntu

Hvis du har glemt din MySQL root-adgangskode, kan du nulstille den ved at følge trinene i denne artikel. Processen er ret enkel og fungerer på disse

Sådan installeres GoAccess på Ubuntu 16.04

Sådan installeres GoAccess på Ubuntu 16.04

Bruger du et andet system? GoAccess er en open source weblog-analysator. Du kan bruge det til analyse af logs på realtidsbasis i enten terminalen eller

Sådan installeres YOURLS på CentOS 7

Sådan installeres YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) er en open source URL-forkortelse og dataanalyseapplikation. I denne artikel vil vi dække installationsprocessen

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 lige i nuet I denne blog Læs, hvordan kunstig intelligens-applikationer har påvirket forskellige sektorer.

DDOS-angreb: et kort overblik

DDOS-angreb: et kort overblik

Er du også et offer for DDOS-angreb og forvirret over forebyggelsesmetoderne? Læs denne artikel for at løse dine spørgsmål.

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Du har måske hørt, at hackere tjener mange penge, men har du nogensinde spekuleret på, hvordan tjener de den slags penge? lad os diskutere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Vil du se revolutionerende opfindelser fra Google, og hvordan disse opfindelser ændrede livet for ethvert menneske i dag? Læs derefter til bloggen for at se opfindelser fra Google.

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Konceptet med selvkørende biler til at køre på vejene ved hjælp af kunstig intelligens er en drøm, vi har haft i et stykke tid nu. Men på trods af flere løfter er de ingen steder at se. Læs denne blog for at lære mere...

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Efterhånden som videnskaben udvikler sig i et hurtigt tempo og overtager en stor del af vores indsats, stiger risikoen for at udsætte os selv for en uforklarlig Singularitet. Læs, hvad singularitet kunne betyde for os.

Udvikling af datalagring – Infografik

Udvikling af datalagring – Infografik

Opbevaringsmetoderne for dataene har været under udvikling, kan være siden fødslen af ​​dataene. Denne blog dækker udviklingen af ​​datalagring på basis af en infografik.

Funktioner af Big Data Reference Architecture Layers

Funktioner af Big Data Reference Architecture Layers

Læs bloggen for at kende forskellige lag i Big Data-arkitekturen og deres funktionaliteter på den enkleste måde.

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

I denne digitalt drevne verden er smarte hjemmeenheder blevet en afgørende del af livet. Her er et par fantastiske fordele ved smarte hjemmeenheder om, hvordan de gør vores liv værd at leve og enklere.

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

For nylig udgav Apple macOS Catalina 10.15.4 en supplerende opdatering for at løse problemer, men det ser ud til, at opdateringen forårsager flere problemer, hvilket fører til mursten af ​​mac-maskiner. Læs denne artikel for at lære mere