Hantera Laravel-arbetsköer med Beanstalk och Supervisor på Ubuntu 16.04

Beanstalk är en snabb och enkel arbetskö. Det låter dig köra tidskrävande uppgifter asynkront, som att skicka e-post, ansluta till externa API:er eller bearbeta bilder. Genom att göra det minskar du din webbapps latens. Laravel ger direkt support för beanstalkd.

I den här handledningen kommer vi att installera beanstalkd, konfigurera en demo Laravel-applikation och hantera köarbetarna genom Supervisor . Demoapplikationen kommer att få en lista över tillgängliga operativsystem från Vultr API och slumpmässigt välja ett.

Det antas att du redan har Supervisor installerad på ditt system. Om du inte gör det bör du läsa följande handledning om hur du ställer in Supervisor: Installera och konfigurera Supervisor på Ubuntu 16.04

Det antas också att du har SSH-åtkomst till din Vultr-instans.

Installera Beanstalk

Det första steget att ta är att installera beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Starta tjänsten.

sudo systemctl start beanstalkd

Du kan också aktivera tjänsten att starta vid systeminitiering.

sudo systemctl enable beanstalkd

Kontrollera tjänstens status genom att utfärda följande kommando.

sudo systemctl status beanstalkd

Som standard beanstalkdlyssnar på porten 11300. Beanstalk använder ett enkelt textbaserat protokoll som beskrivs i dess github-förråd . Du kan testa dess protokoll genom att köra telnet.

telnet localhost 11300

Skriv följande och tryck på ENTER.

list-tubes

Du bör se en lista över tillgängliga tuber på servern:

OK 14
---
- default

För att stänga anslutningen skriver du bara quitoch trycker på ENTER.

Rör i Beanstalk representerar arbetsköer. Bönstjälk består huvudsakligen av producenter , konsumenter , jobb och rör . Producenterna lägger jobb i ett rör för att konsumeras (bearbetas) av ett valfritt antal konsumenter. Observera att både producenter och konsumenter helt enkelt är kunder till Beanstalk-servern och är helt oberoende av varandra. Rent praktiskt betyder detta att du genom att använda Beanstalk kan producera dina jobb i din PHP-applikation och få dem bearbetade i till exempel en NodeJS-app. Lyckligtvis abstraherar Laravel allt detta och ger oss ett mycket enkelt API för att skicka och hantera jobb, som vi kommer att se härnäst.

Exempel på projekt

För att bygga vårt exempelprojekt måste vi först installera dess beroenden. Vi kommer att installera PHP och Composer.

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

Skapa nu projektet baserat på Laravel 5.5.

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

Nästa cdtill den nyligen skapade mappen. Vi kommer att arbeta i den här katalogen från och med nu. Denna mapp kan hänvisas till senare som PROJECT_ROOT.

cd vultr/

För att använda Beanstalk i Laravel måste vi installera ytterligare ett beroende, PHP Beanstalk-klienten.

composer require pda/pheanstalk ~3.0

Vi måste också skapa en jobbrepresentation. I Laravel är detta en klass inne i app/Jobsmappen. Laravel har ett konsolkommando som hjälper oss att skapa en jobbklass. Låt oss skapa vårt exempeljobb.

php artisan make:job FindFavoriteOS

Uppdatera app/Jobs/FindFavoriteOS.phpfilen till följande.

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

Hanteringsmetoden är vad som kommer att utföras effektivt när jobbet är förbrukat. Här hämtar vi data från Vultr API, väljer ett OS slumpmässigt och skriver det valda OS till loggfilen. Loggfilen finns på storage/logs/laravel.log.

Vi har redan installerat Beanstalk och definierat jobbet som ska utföras av det. Nu är det dags att berätta för Laravel att använda Beanstalk som standardarbetskö. Kopiera standardfilen som .envtillhandahålls av Laravel-installationen.

cp .env.example .env

Öppna nu .envfilen och uppdatera raden där ködrivrutinen är angiven.

QUEUE_DRIVER=beanstalkd

Till sist, generera en applikationsnyckel.

php artisan key:generate

Vi är nu redo att skicka jobb till Beanstalks arbetskö.

Utskick och kör jobb

Att skicka ett jobb i Laravel är ganska enkelt. Uppdatera routes/web.phpfilen.

<?php

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

    return '50 Jobs dispatched!';
});

Trots att vi inte rekommenderas att köra den inbyggda servern i produktion, kommer vi att använda den här för korthetens skull.

php artisan serve --host 0.0.0.0 --port 8000

Nu i en webbläsare, navigera till http://[vultr-instance-ip]:8000. Du kommer att se följande meddelande.

50 Jobs dispatched!

Öppna en ny SSH-anslutning till din server och inuti vår projektrot, kör följande.

php artisan queue:work --once

Detta är den förväntade produktionen:

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

Bekräfta att loggen skapades.

cat storage/logs/laravel.log

Konfigurera Supervisor

För att undvika behovet av att manuellt bearbeta kön kommer vi att använda supervisord. Skapa följande 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

Lägg märke till att den rätta sökvägen för att lägga Supervisor-konfigurationsfilen beror på din inställning. Kom också ihåg att ersätta [PROJECT_ROOT]med hela sökvägen till PROJECT_ROOTpå ditt system.

Här konfigurerar vi Supervisor för att automatiskt börja bearbeta kön och, om skriptet går sönder, starta om det. Observera också att vi inte instansierar en enskild arbetare, utan 8 processer. Du är fri att instansiera hur många processer du finner nödvändiga beroende på din applikation.

För att tillåta Supervisor att hantera vår arbetare, tvinga den att läsa om sin konfiguration.

sudo supervisorctl reread
sudo supervisorctl update

Om Arbetsledartjänsten inte har startats behöver ni många starta den.

sudo systemctl start supervisord

Låt oss nu se om jobben bearbetas.

tail -f storage/logs/laravel.log

Navigera till i en webbläsare http://[vultr-instance-ip]:8000. Du kommer att se loggarna som genereras på din konsol.

Slutsats

Vi har framgångsrikt konfigurerat en Laravel-applikation för att använda Beanstalk som en arbetskö. Vi visade också hur man använder Supervisor för att hantera arbetare.


Installera Plesk på CentOS 7

Installera Plesk på CentOS 7

Använder du ett annat system? Plesk är en egen kontrollpanel för webbhotell som tillåter användare att administrera sina personliga och/eller klienters webbplatser, databaser

Installera Cacti på Debian Jessie

Installera Cacti på Debian Jessie

Introduktion Cacti är ett övervaknings- och grafverktyg med öppen källkod som är helt baserat på RRD-data. Genom Cacti kan du övervaka nästan vilken typ av enhet som helst

Installera Lets Encrypt SSL på One-Click WordPress-appen

Installera Lets Encrypt SSL på One-Click WordPress-appen

Introduktion Lets Encrypt är en certifikatmyndighetstjänst som erbjuder gratis TLS/SSL-certifikat. Installationsprocessen förenklas av Certbot,

Hur man ställer in en Tekkit Classic-server på Ubuntu 16.10

Hur man ställer in en Tekkit Classic-server på Ubuntu 16.10

Använder du ett annat system? Vad är Tekkit Classic? Tekkit Classic är ett modpack för spelet som alla känner och älskar; Minecraft. Den innehåller några av ver

Konfigurera iRedMail på Debian Wheezy

Konfigurera iRedMail på Debian Wheezy

Använder du ett annat system? Den här handledningen visar dig hur du installerar groupware iRedMail på en ny installation av Debian Wheezy. Du bör använda en serve

Hur man installerar och konfigurerar PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

Hur man installerar och konfigurerar PHP 7.0 eller PHP 7.1 på Ubuntu 16.04

PHP och relaterade paket är de mest använda komponenterna när du distribuerar en webbserver. I den här artikeln kommer vi att lära oss hur du ställer in PHP 7.0 eller PHP 7.1 o

Hur man installerar Squid Proxy på CentOS

Hur man installerar Squid Proxy på CentOS

Squid är ett populärt, gratis Linux-program som låter dig skapa en webbproxy för vidarebefordran. I den här guiden ser du hur du installerar Squid på CentOS för att förvandla dig

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Inledning Lighttpd är en apachegaffel som syftar till att vara mycket mindre resurskrävande. Den är lätt, därav namnet, och är ganska enkel att använda. Installera

Tre gratis serverkontrollpaneler (snabbinstallation)

Tre gratis serverkontrollpaneler (snabbinstallation)

1. Virtualmin/Webmin Virtualmin är en kraftfull och flexibel kontrollpanel för webbhotell för Linux- och UNIX-system baserad på den välkända Open Source-webbasen

Konfigurera en Yii-applikation på Ubuntu 14.04

Konfigurera en Yii-applikation på Ubuntu 14.04

Yii är ett PHP-ramverk som låter dig utveckla applikationer snabbare och enklare. Att installera Yii på Ubuntu är enkelt, eftersom du kommer att lära dig exakt

Använder skärmen på Ubuntu 14.04

Använder skärmen på Ubuntu 14.04

Screen är ett program som tillåter flera terminalsessioner inom ett fönster. Detta låter dig simulera flera terminalfönster där det ma

Konfigurera din egen DNS-server på Debian/Ubuntu

Konfigurera din egen DNS-server på Debian/Ubuntu

Denna handledning förklarar hur man ställer in en DNS-server med Bind9 på Debian eller Ubuntu. Genomgående i artikeln, byt ut ditt-domännamn.com i enlighet med detta. Vid th

Använda Logrotate för att hantera loggfiler

Använda Logrotate för att hantera loggfiler

Inledning Logrotate är ett Linux-verktyg som förenklar administrationen av loggfiler. Den körs vanligtvis en gång om dagen via ett cron-jobb och hanterar loggbasen

Konfigurera statiskt nätverk och IPv6 på CentOS 7

Konfigurera statiskt nätverk och IPv6 på CentOS 7

VULTR har nyligen gjort ändringar på deras sida, och allt borde nu fungera bra direkt när NetworkManager är aktiverat. Om du vill inaktivera

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 är ett kraftfullt övervakningssystem, och när det används i en master-klient-modell kan det ersätta behovet av NRPE-baserade övervakningskontroller. Master-klienten

Konfigurera Red5 Media Server på Ubuntu 16.04

Konfigurera Red5 Media Server på Ubuntu 16.04

Använder du ett annat system? Red5 är en mediaserver med öppen källkod implementerad i Java som låter dig köra Flash fleranvändarapplikationer som livestreamin

Kompilera och installera Nginx med PageSpeed-modulen på Debian 8

Kompilera och installera Nginx med PageSpeed-modulen på Debian 8

I den här artikeln kommer vi att se hur man kompilerar och installerar Nginx mainline från de officiella källorna för Nginx med PageSpeed-modulen, som låter dig t

Hur man installerar Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Hur man installerar Apache Cassandra 3.11.x på Ubuntu 16.04 LTS

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Vanilla Forum på Ubuntu 16.04

Hur man installerar Vanilla Forum på Ubuntu 16.04

Använder du ett annat system? Vanilla forum är en open source forumapplikation skriven i PHP. Det är en helt anpassningsbar, enkel att använda och stöder externa

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer