Správa pracovných front Laravel s Beanstalk a dozorom na Ubuntu 16.04

Beanstalk je rýchly a jednoduchý pracovný front. Umožňuje vám asynchrónne spúšťať časovo náročné úlohy, ako je odosielanie e-mailov, pripojenie k externým API alebo spracovanie obrázkov. Tým znížite latenciu webovej aplikácie. Laravel poskytuje podporu pre beanstalkd.

V tomto návode nainštalujeme beanstalkd, nastavíme demo aplikáciu Laravel a budeme spravovať pracovníkov vo fronte cez Supervisor . Demo aplikácia získa zoznam dostupných OS z Vultr API a náhodne si jeden vyberie.

Predpokladá sa, že už máte vo svojom systéme nainštalovaného správcu. Ak tak neurobíte, mali by ste si prečítať nasledujúci návod, ako nastaviť správcu: Inštalácia a konfigurácia správcu na Ubuntu 16.04

Tiež sa predpokladá, že máte prístup SSH k svojej inštancii Vultr.

Inštalácia Beanstalk

Prvým krokom je inštalácia beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Spustite službu.

sudo systemctl start beanstalkd

Môžete tiež povoliť spustenie služby po inicializácii systému.

sudo systemctl enable beanstalkd

Skontrolujte stav služby zadaním nasledujúceho príkazu.

sudo systemctl status beanstalkd

V predvolenom nastavení beanstalkdpočúva na porte 11300. Beanstalk používa jednoduchý textový protokol opísaný v jeho úložisku github . Jeho protokol môžete otestovať spustením telnet.

telnet localhost 11300

Napíšte nasledovné a stlačte ENTER.

list-tubes

Mali by ste vidieť zoznam skúmaviek dostupných na serveri:

OK 14
---
- default

Na ukončenie spojenia jednoducho napíšte quita potom stlačte ENTER.

Rúry v Beanstalk predstavujú pracovné fronty. Stonky fazule tvoria v podstate výrobcovia , spotrebitelia , pracovné miesta a rúrky . Výrobcovia vkladajú úlohy do skúmavky, ktorú má spotrebovať (spracovať) ľubovoľný počet spotrebiteľov. Upozorňujeme, že výrobcovia aj spotrebitelia sú jednoducho klientmi servera Beanstalk a sú navzájom úplne nezávislí. V praxi to znamená, že pomocou Beanstalk môžete vytvárať svoje úlohy vo svojej aplikácii PHP a nechať ich spracovať napríklad v aplikácii NodeJS. Našťastie Laravel toto všetko abstrahuje a poskytuje nám veľmi jednoduché API na odosielanie a spracovanie úloh, ako uvidíme ďalej.

Ukážkový projekt

Na zostavenie nášho vzorového projektu musíme najskôr nainštalovať jeho závislosti. Nainštalujeme PHP a Composer.

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

Teraz vytvorte projekt založený na Laravel 5.5.

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

Ďalej cddo nedávno vytvoreného priečinka. Odteraz budeme pracovať v tomto adresári. Tento priečinok môže byť neskôr označený ako PROJECT_ROOT.

cd vultr/

Ak chcete použiť Beanstalk v Laravel, musíme nainštalovať ešte jednu závislosť, klienta PHP Beanstalk.

composer require pda/pheanstalk ~3.0

Musíme tiež vytvoriť zastúpenie Job. V Laravel je to trieda v app/Jobspriečinku. Laravel má príkaz konzoly, ktorý nám pomôže vytvoriť triedu úloh. Poďme vytvoriť našu vzorovú prácu.

php artisan make:job FindFavoriteOS

Aktualizujte app/Jobs/FindFavoriteOS.phpsúbor na nasledujúci.

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

Metóda handle je to, čo sa efektívne vykoná, keď je úloha spotrebovaná. Tu získavame údaje z Vultr API, náhodne vyberieme OS a zapíšeme zvolený OS do súboru denníka. Súbor denníka sa nachádza na adrese storage/logs/laravel.log.

Beanstalk sme už nainštalovali a definovali úlohu, ktorú má vykonať. Teraz je čas povedať Laravelovi, aby použil Beanstalk ako predvolený pracovný front. Skopírujte predvolený .envsúbor poskytnutý inštaláciou Laravel.

cp .env.example .env

Teraz otvorte .envsúbor a aktualizujte riadok, kde je zadaný ovládač frontu.

QUEUE_DRIVER=beanstalkd

Nakoniec vygenerujte aplikačný kľúč.

php artisan key:generate

Teraz sme pripravení odoslať úlohy do pracovného radu Beanstalk.

Dispečing a prevádzka úloh

Odoslanie práce v Laravel je celkom jednoduché. Aktualizujte routes/web.phpsúbor.

<?php

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

    return '50 Jobs dispatched!';
});

Napriek tomu, že sa neodporúča spúšťať vstavaný poskytnutý server vo výrobe, budeme ho tu používať kvôli stručnosti.

php artisan serve --host 0.0.0.0 --port 8000

Teraz vo webovom prehliadači prejdite na http://[vultr-instance-ip]:8000. Uvidíte nasledujúcu správu.

50 Jobs dispatched!

Otvorte nové pripojenie SSH k vášmu serveru a v koreňovom adresári nášho projektu vykonajte nasledujúce.

php artisan queue:work --once

Toto je očakávaný výstup:

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

Potvrďte, že denník bol vygenerovaný.

cat storage/logs/laravel.log

Konfigurácia supervízora

Aby sme sa vyhli potrebe manuálneho spracovania frontu, použijeme supervisord. Vytvorte nasledujúcu konfiguráciu programu v /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

Všimnite si, že správna cesta na umiestnenie konfiguračného súboru správcu bude závisieť od vášho nastavenia. Nezabudnite tiež nahradiť [PROJECT_ROOT]úplnou cestou k súboru PROJECT_ROOTvo vašom systéme.

Tu konfigurujeme správcu tak, aby automaticky začal spracovávať front a v prípade zlyhania skriptu ho reštartoval. Všimnite si tiež, že nevytvárame inštanciu jedného pracovníka, ale 8 procesov. Môžete si vytvoriť inštanciu bez ohľadu na to, koľko procesov považujete za potrebné v závislosti od vašej aplikácie.

Ak chcete nadriadenému umožniť spravovať nášho pracovníka, prinútiť ho, aby si znova prečítal svoju konfiguráciu.

sudo supervisorctl reread
sudo supervisorctl update

Ak služba Dozorca nebola spustená, mnohí ju musíte spustiť.

sudo systemctl start supervisord

Teraz sa pozrime, či sa úlohy spracovávajú.

tail -f storage/logs/laravel.log

Vo webovom prehliadači prejdite na http://[vultr-instance-ip]:8000. Na vašej konzole uvidíte generované protokoly.

Záver

Úspešne sme nakonfigurovali aplikáciu Laravel na používanie Beanstalk ako pracovného frontu. Tiež sme ukázali, ako používať supervízor na riadenie pracovníkov.


Install Plesk on CentOS 7

Install Plesk on CentOS 7

Using a Different System? Plesk is a proprietary web host control panel that allows users to administer their personal and/or clients websites, databases

Install Lets Encrypt SSL on One-Click WordPress App

Install Lets Encrypt SSL on One-Click WordPress App

Introduction Lets Encrypt is a certificate authority service that offers free TLS/SSL certificates. The process of installation is simplified by Certbot,

Ako nastaviť klasický server Tekkit na Ubuntu 16.10

Ako nastaviť klasický server Tekkit na Ubuntu 16.10

Používate iný systém? Čo je Tekkit Classic? Tekkit Classic je modpack pre hru, ktorú každý pozná a miluje; Minecraft. Obsahuje niektoré z ver

Creating a Jekyll Blog on Ubuntu 16.04

Creating a Jekyll Blog on Ubuntu 16.04

Using a Different System? Jekyll is a great alternative to WordPress for blogging or sharing content. It doesnt require any databases and it is very easy i

Ako nastaviť bezobslužné aktualizácie na Debian 9 (Stretch)

Ako nastaviť bezobslužné aktualizácie na Debian 9 (Stretch)

Používate iný systém? Ak si zakúpite server Debian, mali by ste mať vždy najnovšie bezpečnostné záplaty a aktualizácie, či už spíte alebo nie

Ako nainštalovať a nakonfigurovať PHP 7.0 alebo PHP 7.1 na Ubuntu 16.04

Ako nainštalovať a nakonfigurovať PHP 7.0 alebo PHP 7.1 na Ubuntu 16.04

PHP a súvisiace balíky sú najčastejšie používané komponenty pri nasadzovaní webového servera. V tomto článku sa naučíme, ako nastaviť PHP 7.0 alebo PHP 7.1 o

Ako nainštalovať Squid Proxy na CentOS

Ako nainštalovať Squid Proxy na CentOS

Squid je populárny bezplatný linuxový program, ktorý vám umožňuje vytvoriť webový proxy server na presmerovanie. V tejto príručke uvidíte, ako nainštalovať Squid na CentOS, aby vás zmenil

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Ako nainštalovať Lighttpd (LLMP Stack) na CentOS 6

Úvod Lighttpd je fork Apache, ktorého cieľom je byť oveľa menej náročný na zdroje. Je ľahký, odtiaľ jeho názov, a jeho použitie je celkom jednoduché. Installin

Tri bezplatné ovládacie panely servera (rýchla inštalácia)

Tri bezplatné ovládacie panely servera (rýchla inštalácia)

1. Virtualmin/Webmin Virtualmin je výkonný a flexibilný ovládací panel webhostingu pre systémy Linux a UNIX založený na známej webovej základni Open Source

Nastavenie aplikácie Yii na Ubuntu 14.04

Nastavenie aplikácie Yii na Ubuntu 14.04

Yii je rámec PHP, ktorý vám umožňuje rýchlejšie a jednoduchšie vyvíjať aplikácie. Inštalácia Yii na Ubuntu je jednoduchá, ako sa presne dozviete

Používanie obrazovky na Ubuntu 14.04

Používanie obrazovky na Ubuntu 14.04

Screen je aplikácia, ktorá umožňuje viacnásobné použitie terminálových relácií v rámci jedného okna. To vám umožňuje simulovať viacero okien terminálu, kde je to možné

Nastavte si svoj vlastný DNS server na Debian/Ubuntu

Nastavte si svoj vlastný DNS server na Debian/Ubuntu

Tento tutoriál vysvetľuje, ako nastaviť server DNS pomocou Bind9 na Debiane alebo Ubuntu. V celom článku podľa toho nahraďte názov vašej-domény.com. Pri th

Používanie Logrotate na správu protokolových súborov

Používanie Logrotate na správu protokolových súborov

Úvod Logrotate je nástroj pre Linux, ktorý zjednodušuje správu protokolových súborov. Zvyčajne beží raz denne prostredníctvom úlohy cron a spravuje základňu protokolov

Konfigurácia statickej siete a IPv6 na CentOS 7

Konfigurácia statickej siete a IPv6 na CentOS 7

VULTR nedávno vykonal zmeny na ich konci a všetko by teraz malo fungovať dobre po vybalení so zapnutým NetworkManagerom. Ak chcete deaktivovať

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Úprava Icinga2 na použitie modelu Master/Client na CentOS 6 alebo CentOS 7

Icinga2 je výkonný monitorovací systém a pri použití v modeli master-client môže nahradiť potrebu monitorovacích kontrol založených na NRPE. Hlavný klient

Nastavte Red5 Media Server na Ubuntu 16.04

Nastavte Red5 Media Server na Ubuntu 16.04

Používate iný systém? Red5 je mediálny server s otvoreným zdrojom implementovaný v jazyku Java, ktorý vám umožňuje spúšťať aplikácie Flash pre viacerých používateľov, ako napríklad živé vysielanie

Ako nainštalovať Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Ako nainštalovať Apache Cassandra 3.11.x na Ubuntu 16.04 LTS

Používate iný systém? Apache Cassandra je bezplatný a otvorený systém správy databáz NoSQL, ktorý je navrhnutý tak, aby poskytoval škálovateľnosť, vysokú

Ako nainštalovať Vanilla Forum na Ubuntu 16.04

Ako nainštalovať Vanilla Forum na Ubuntu 16.04

Používate iný systém? Vanilla forum je open source aplikácia fóra napísaná v PHP. Je plne prispôsobiteľný, ľahko použiteľný a podporuje externé

Ako nainštalovať Kanboard na Ubuntu 18.04 LTS

Ako nainštalovať Kanboard na Ubuntu 18.04 LTS

Používate iný systém? Úvod Kanboard je bezplatný a otvorený softvérový program na riadenie projektov, ktorý je navrhnutý tak, aby uľahčil a vizualizoval

Ako nainštalovať Kanboard na Debian 9

Ako nainštalovať Kanboard na Debian 9

Používate iný systém? Úvod Kanboard je bezplatný a otvorený softvérový program na riadenie projektov, ktorý je navrhnutý tak, aby uľahčil a vizualizoval

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.

Útoky DDOS: Stručný prehľad

Útoky DDOS: Stručný prehľad

Ste aj vy obeťou DDOS útokov a máte zmätok ohľadom metód prevencie? Ak chcete vyriešiť svoje otázky, prečítajte si tento článok.

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Zaujímalo vás niekedy, ako hackeri zarábajú peniaze?

Možno ste už počuli, že hackeri zarábajú veľa peňazí, ale premýšľali ste niekedy nad tým, ako môžu zarábať také peniaze? poďme diskutovať.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Revolučné vynálezy od spoločnosti Google, ktoré vám uľahčia život.

Chcete vidieť revolučné vynálezy od Google a ako tieto vynálezy zmenili život každého dnešného človeka? Potom si prečítajte na blogu a pozrite si vynálezy spoločnosti Google.

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Piatok Essential: Čo sa stalo s autami poháňanými AI?

Koncept samoriadených áut vyraziť na cesty s pomocou umelej inteligencie je snom, ktorý máme už nejaký čas. Ale napriek niekoľkým prísľubom ich nikde nevidno. Prečítajte si tento blog a dozviete sa viac…

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Technologická singularita: vzdialená budúcnosť ľudskej civilizácie?

Ako sa veda vyvíja rýchlym tempom a preberá veľa nášho úsilia, zvyšuje sa aj riziko, že sa vystavíme nevysvetliteľnej singularite. Prečítajte si, čo pre nás môže znamenať singularita.

Vývoj ukladania dát – Infografika

Vývoj ukladania dát – Infografika

Spôsoby ukladania údajov sa môžu vyvíjať už od zrodu údajov. Tento blog sa zaoberá vývojom ukladania údajov na základe infografiky.

Funkcionality vrstiev referenčnej architektúry veľkých dát

Funkcionality vrstiev referenčnej architektúry veľkých dát

Prečítajte si blog, aby ste čo najjednoduchším spôsobom spoznali rôzne vrstvy architektúry veľkých dát a ich funkcie.

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

6 úžasných výhod toho, že máme v živote inteligentné domáce zariadenia

V tomto digitálnom svete sa inteligentné domáce zariadenia stali kľúčovou súčasťou života. Tu je niekoľko úžasných výhod inteligentných domácich zariadení o tom, ako robia náš život, ktorý stojí za to žiť, a ktorý zjednodušujú.

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Aktualizácia doplnku macOS Catalina 10.15.4 spôsobuje viac problémov, ako ich rieši

Spoločnosť Apple nedávno vydala doplnkovú aktualizáciu macOS Catalina 10.15.4 na opravu problémov, ale zdá sa, že táto aktualizácia spôsobuje ďalšie problémy, ktoré vedú k blokovaniu počítačov Mac. Prečítajte si tento článok a dozviete sa viac