Laravel-werkwachtrijen beheren met Beanstalk en Supervisor op Ubuntu 16.04

Beanstalk is een snelle en eenvoudige werkwachtrij. Hiermee kunt u tijdrovende taken asynchroon uitvoeren, zoals het verzenden van e-mails, verbinding maken met externe API's of het verwerken van afbeeldingen. Door dit te doen, vermindert u de latentie van uw web-app. Laravel biedt out-of-the-box ondersteuning voor beanstalkd.

In deze tutorial zullen we beanstalkdeen demo-Laravel-applicatie installeren , opzetten en de wachtrijwerkers beheren via Supervisor . De demo-applicatie krijgt een lijst met beschikbare besturingssystemen van de Vultr API en kiest er willekeurig een.

Aangenomen wordt dat u Supervisor al op uw systeem hebt geïnstalleerd. Als je dat niet doet, lees dan de volgende tutorial over het instellen van Supervisor: Supervisor installeren en configureren op Ubuntu 16.04

Er wordt ook aangenomen dat je SSH-toegang hebt tot je Vultr-instantie.

Beanstalk installeren

De eerste stap die u moet nemen, is installeren beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Start de dienst.

sudo systemctl start beanstalkd

U kunt de service ook inschakelen om te starten bij systeeminitialisatie.

sudo systemctl enable beanstalkd

Controleer de servicestatus door de volgende opdracht te geven.

sudo systemctl status beanstalkd

Luistert standaard beanstalkdop de poort 11300. Beanstalk gebruikt een eenvoudig op tekst gebaseerd protocol dat wordt beschreven in de github-repository . U kunt het protocol testen door het uit te voeren telnet.

telnet localhost 11300

Schrijf het volgende en druk op ENTER.

list-tubes

U zou een lijst met beschikbare buizen op de server moeten zien:

OK 14
---
- default

Typ quiten druk op om de verbinding te verbreken ENTER.

Buizen in Beanstalk vertegenwoordigen werkwachtrijen. Beanstalk wordt voornamelijk samengesteld door producenten , consumenten , banen en buizen . Producenten stoppen banen in een buis om door een onbeperkt aantal consumenten te worden geconsumeerd (verwerkt). Merk op dat zowel producenten als consumenten gewoon klanten zijn van de Beanstalk-server en volledig onafhankelijk van elkaar zijn. Concreet betekent dit dat je door Beanstalk te gebruiken je jobs in je PHP-applicatie kunt produceren en laten verwerken in bijvoorbeeld een NodeJS-app. Gelukkig vat Laravel dit allemaal samen en biedt het ons een zeer eenvoudige API om taken te verzenden en af ​​te handelen, zoals we hierna zullen zien.

Voorbeeldproject

Om ons voorbeeldproject te bouwen, moeten we eerst de afhankelijkheden ervan installeren. We gaan PHP en Composer installeren.

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

Maak nu het project op basis van Laravel 5.5.

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

Volgende cdin de onlangs gemaakte map. We zullen vanaf nu in deze map werken. Naar deze map kan later worden verwezen als PROJECT_ROOT.

cd vultr/

Om Beanstalk in Laravel te gebruiken, moeten we nog een afhankelijkheid installeren, de PHP Beanstalk-client.

composer require pda/pheanstalk ~3.0

We moeten ook een functievertegenwoordiging creëren. In Laravel is dit een klasse in de app/Jobsmap. Laravel heeft een console-commando om ons te helpen een Job-klasse te creëren. Laten we onze voorbeeldjob maken.

php artisan make:job FindFavoriteOS

Werk het app/Jobs/FindFavoriteOS.phpbestand bij naar het volgende.

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

De handle-methode is wat effectief wordt uitgevoerd wanneer de taak wordt verbruikt. Hier halen we gegevens op van de Vultr API, kiezen willekeurig een besturingssysteem en schrijven het gekozen besturingssysteem naar het logbestand. Het logbestand bevindt zich op storage/logs/laravel.log.

We hebben Beanstalk al geïnstalleerd en de taak gedefinieerd die ermee moet worden uitgevoerd. Nu is het tijd om Laravel te vertellen dat hij Beanstalk als de standaardwerkwachtrij moet gebruiken. Kopieer het standaardbestand .envvan de Laravel-installatie.

cp .env.example .env

Open nu het .envbestand en werk de regel bij waar het wachtrijstuurprogramma is gespecificeerd.

QUEUE_DRIVER=beanstalkd

Genereer ten slotte een toepassingssleutel.

php artisan key:generate

We zijn nu klaar om taken naar de Beanstalk-werkwachtrij te sturen.

Verzenden en uitvoeren van taken

Een baan versturen in Laravel is vrij eenvoudig. Werk het routes/web.phpbestand bij.

<?php

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

    return '50 Jobs dispatched!';
});

Ondanks dat het niet wordt aanbevolen om de ingebouwde meegeleverde server in productie te laten, zullen we deze hier kortheidshalve gebruiken.

php artisan serve --host 0.0.0.0 --port 8000

Navigeer nu in een webbrowser naar http://[vultr-instance-ip]:8000. Je ziet het volgende bericht.

50 Jobs dispatched!

Open een nieuwe SSH-verbinding met uw server en voer in de projectroot het volgende uit.

php artisan queue:work --once

Dit is de verwachte output:

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

Bevestig dat het logboek is gegenereerd.

cat storage/logs/laravel.log

Supervisor configureren

Om te voorkomen dat de wachtrij handmatig moet worden verwerkt, gebruiken we supervisord. Maak de volgende programmaconfiguratie in /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

Merk op dat het juiste pad om het Supervisor-configuratiebestand te plaatsen, afhangt van uw configuratie. Vergeet ook niet om te vervangen [PROJECT_ROOT]door het volledige pad naar het PROJECT_ROOTop uw systeem.

Hier configureren we Supervisor om automatisch de wachtrij te verwerken en, in het geval dat het script wordt verbroken, om het opnieuw te starten. Merk ook op dat we geen enkele werknemer instantiëren, maar 8 processen. Het staat u vrij om zoveel processen te instantiëren, afhankelijk van uw toepassing.

Om supervisor toe te staan ​​onze werknemer te beheren, dwingt u hem de configuratie opnieuw te lezen.

sudo supervisorctl reread
sudo supervisorctl update

Als de Supervisor-service niet is gestart, moeten velen deze starten.

sudo systemctl start supervisord

Laten we nu kijken of de taken worden verwerkt.

tail -f storage/logs/laravel.log

Navigeer in een webbrowser naar http://[vultr-instance-ip]:8000. U zult zien dat de logs worden gegenereerd op uw console.

Gevolgtrekking

We hebben met succes een Laravel-applicatie geconfigureerd om Beanstalk als werkwachtrij te gebruiken. We hebben ook laten zien hoe u Supervisor kunt gebruiken om werknemers te beheren.



Leave a Comment

Hoe LiteCart Shopping Cart Platform op Ubuntu 16.04 te installeren

Hoe LiteCart Shopping Cart Platform op Ubuntu 16.04 te installeren

LiteCart is een gratis en open source winkelwagenplatform geschreven in PHP, jQuery en HTML 5. Het is een eenvoudige, lichtgewicht en gebruiksvriendelijke e-commerce software

Stel NFS Share op Debian in

Stel NFS Share op Debian in

NFS is een netwerkgebaseerd bestandssysteem waarmee computers toegang hebben tot bestanden via een computernetwerk. Deze gids legt uit hoe u mappen via NF kunt weergeven

Hoe Matomo Analytics op Fedora te installeren 28

Hoe Matomo Analytics op Fedora te installeren 28

Gebruikt u een ander systeem? Matomo (voorheen Piwik) is een open source analyseplatform, een open alternatief voor Google Analytics. Matomo source wordt gehost o

Initiële veilige serverconfiguratie van Ubuntu 18.04

Initiële veilige serverconfiguratie van Ubuntu 18.04

Inleiding In deze tutorial leert u hoe u een basisbeveiligingsniveau configureert op een gloednieuwe Vultr VC2 virtuele machine met Ubunt

McMyAdmin installeren op Ubuntu 14.10

McMyAdmin installeren op Ubuntu 14.10

McMyAdmin is een Minecraft-serverbedieningspaneel dat wordt gebruikt om uw server te beheren. Hoewel McMyAdmin gratis is, zijn er meerdere edities, waarvan sommige pai zijn

Stel een TeamTalk-server in op Linux

Stel een TeamTalk-server in op Linux

TeamTalk is een conferentiesysteem waarmee gebruikers hoogwaardige audio- / videogesprekken kunnen voeren, tekstchatten, bestanden kunnen overdragen en schermen kunnen delen. Het ik

CyberPanel installeren en configureren op uw CentOS 7-server

CyberPanel installeren en configureren op uw CentOS 7-server

Gebruikt u een ander systeem? Introductie CyberPanel is een van de eerste bedieningspanelen op de markt die zowel open source is als OpenLiteSpeed ​​gebruikt. Wat thi

Ruby installeren en configureren met Rbenv, Rails, MariaDB, Nginx, SSL en Passenger op Ubuntu 17.04

Ruby installeren en configureren met Rbenv, Rails, MariaDB, Nginx, SSL en Passenger op Ubuntu 17.04

Ruby on Rails is een populair webraamwerk voor Ruby dat is ontwikkeld om de productiviteit van programmeurs te verhogen. Het verkrijgen van verschillende edelstenen en afhankelijkheden t

Sensu Monitoring installeren en configureren op CentOS 7

Sensu Monitoring installeren en configureren op CentOS 7

Introductie Sensu is een gratis en open source monitoringoplossing die kan worden gebruikt om server, applicatie en verschillende systeemservices te monitoren. Sensu i

Installeer phpBB With Apache op Ubuntu 16.04

Installeer phpBB With Apache op Ubuntu 16.04

PhpBB is een open source prikbordprogramma. Dit artikel laat zien hoe je phpBB bovenop een Apache-webserver op Ubuntu 16.04 installeert. Het was geschreven

Stel een niet-rootgebruiker in met Sudo Access op Ubuntu

Stel een niet-rootgebruiker in met Sudo Access op Ubuntu

Slechts één gebruiker, root, kan gevaarlijk zijn. Dus laten we dat oplossen. Vultr geeft ons de vrijheid om te doen wat we willen met onze gebruikers en onze servers

Toegang krijgen tot uw Vultr VPS

Toegang krijgen tot uw Vultr VPS

Vultr biedt verschillende manieren om toegang te krijgen tot je VPS om te configureren, installeren en gebruiken. Toegangsgegevens De standaard toegangsgegevens voor uw VPS-ar

Fuel CMS installeren op Ubuntu 16.04 LTS

Fuel CMS installeren op Ubuntu 16.04 LTS

Gebruikt u een ander systeem? Fuel CMS is een op CodeIgniter gebaseerd contentmanagementsysteem. De broncode wordt gehost op GitHub. Deze gids laat zien hoe t

Remote Servers bewaken met Zabbix op Ubuntu 16.04

Remote Servers bewaken met Zabbix op Ubuntu 16.04

Gebruikt u een ander systeem? Zabbix is ​​een gratis en open source enterprise-ready software die wordt gebruikt om de beschikbaarheid van systemen en netwerkcomponenten te bewaken

Couch CMS 2.0 installeren op een Debian 9 LAMP VPS

Couch CMS 2.0 installeren op een Debian 9 LAMP VPS

Gebruikt u een ander systeem? Couch CMS is een eenvoudig en flexibel, gratis en open source Content Management Systeem (CMS) waarmee webdesigners kunnen ontwerpen

Golang 1.8.3 installeren op CentOS 7, Ubuntu 16.04 en Debian 9

Golang 1.8.3 installeren op CentOS 7, Ubuntu 16.04 en Debian 9

Golang is een door Google ontwikkelde programmeertaal. Dankzij zijn veelzijdigheid, eenvoud en betrouwbaarheid is Golang uitgegroeid tot een van de meest bevolkte

Quassel instellen op Debian 9

Quassel instellen op Debian 9

IRC is populair bij ontwikkelaars en gebruikers van open source software. Een van de nadelen van IRC is dat wanneer u niet online bent, u importan kunt missen

Sudo gebruiken op Debian, CentOS en FreeBSD

Sudo gebruiken op Debian, CentOS en FreeBSD

Het gebruik van een sudo-gebruiker om toegang te krijgen tot een server en opdrachten uit te voeren op rootniveau is een veel voorkomende praktijk onder Linux en Unix-systeembeheerder. Het gebruik van een sud

Hoe DokuWiki op Ubuntu 16.04 LTS te installeren

Hoe DokuWiki op Ubuntu 16.04 LTS te installeren

Gebruikt u een ander systeem? DokuWiki is een open source wiki-programma geschreven in PHP waarvoor geen database nodig is. Het slaat gegevens op in tekstbestanden. DokuWik

Een Chroot opzetten op Debian

Een Chroot opzetten op Debian

Dit artikel leert u hoe u een chroot-gevangenis op Debian instelt. Ik neem aan dat u Debian 7.x gebruikt. Als u Debian 6 of 8 gebruikt, kan dit werken, bu

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Ransomware-aanvallen nemen toe, maar kan AI helpen het nieuwste computervirus het hoofd te bieden? Is AI het antwoord? Lees hier weten is AI boezem of vloek

ReactOS: is dit de toekomst van Windows?

ReactOS: is dit de toekomst van Windows?

ReactOS, een open source en gratis besturingssysteem is hier met de nieuwste versie. Kan het voldoen aan de behoeften van moderne Windows-gebruikers en Microsoft uitschakelen? Laten we meer te weten komen over deze oude stijl, maar een nieuwere OS-ervaring.

Blijf verbonden via WhatsApp Desktop-app 24 * 7

Blijf verbonden via WhatsApp Desktop-app 24 * 7

WhatsApp heeft eindelijk de Desktop-app voor Mac- en Windows-gebruikers gelanceerd. Nu heb je eenvoudig toegang tot WhatsApp vanuit Windows of Mac. Beschikbaar voor Windows 8+ en Mac OS 10.9+

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Lees dit om te weten hoe kunstmatige intelligentie populair wordt onder de kleinschalige bedrijven en hoe het de kansen vergroot om ze te laten groeien en hun concurrenten voorsprong te geven.

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

Onlangs heeft Apple macOS Catalina 10.15.4 uitgebracht, een aanvullende update om problemen op te lossen, maar het lijkt erop dat de update meer problemen veroorzaakt die ertoe leiden dat mac-machines worden gemetseld. Lees dit artikel voor meer informatie

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

Wat is een logboekbestandssysteem en hoe werkt het?

Wat is een logboekbestandssysteem en hoe werkt het?

Onze computer slaat alle gegevens op een georganiseerde manier op, het zogenaamde Journaling-bestandssysteem. Het is een efficiënte methode waarmee de computer bestanden kan zoeken en weergeven zodra u op zoeken drukt.https://wethegeek.com/?p=94116&preview=true

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Naarmate de wetenschap zich snel ontwikkelt en veel van onze inspanningen overneemt, nemen ook de risico's toe om onszelf te onderwerpen aan een onverklaarbare singulariteit. Lees, wat singulariteit voor ons kan betekenen.

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

AI in de zorg heeft de afgelopen decennia grote sprongen gemaakt. De toekomst van AI in de gezondheidszorg groeit dus nog steeds met de dag.