Upravljanje Laravel radnim redovima s Beanstalkom i supervizorom na Ubuntu 16.04

Beanstalk je brz i jednostavan radni red. Omogućuje vam asinkrono pokretanje zadataka koji oduzimaju vrijeme, kao što je slanje e-pošte, povezivanje s vanjskim API-jima ili obrada slika. Time ćete smanjiti kašnjenje web aplikacije. Laravel pruža gotovu podršku za beanstalkd.

U ovom vodiču ćemo instalirati beanstalkd, postaviti demo Laravel aplikaciju i upravljati radnicima u redu čekanja putem Supervisora . Demo aplikacija će dobiti popis dostupnih OS-ova od Vultr API-ja i nasumično odabrati jedan.

Pretpostavlja se da već imate instaliran Supervizor na vašem sustavu. Ako to ne učinite, trebali biste pročitati sljedeći vodič o tome kako postaviti Supervisor: Instaliranje i konfiguriranje Supervisora ​​na Ubuntu 16.04

Također se pretpostavlja da imate SSH pristup svojoj Vultr instanci.

Instalacija Beanstalka

Prvi korak koji treba poduzeti je instalacija beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Pokrenite uslugu.

sudo systemctl start beanstalkd

Također možete omogućiti pokretanje usluge nakon inicijalizacije sustava.

sudo systemctl enable beanstalkd

Provjerite status usluge izdavanjem sljedeće naredbe.

sudo systemctl status beanstalkd

Prema zadanim postavkama, beanstalkdsluša na portu 11300. Beanstalk koristi jednostavan tekstualni protokol opisan u svom github repozitoriju . Možete testirati njegov protokol pokretanjem telnet.

telnet localhost 11300

Napišite sljedeće i pritisnite ENTER.

list-tubes

Trebali biste vidjeti popis cijevi dostupnih na poslužitelju:

OK 14
---
- default

Za zatvaranje veze jednostavno upišite quiti zatim pritisnite ENTER.

Cijevi u Beanstalku predstavljaju radne redove. Beanstalk se sastoji uglavnom od proizvođača , potrošača , radnih mjesta i cijevi . Proizvođači stavljaju poslove u cijev da ih konzumira (obradi) bilo koji broj potrošača. Imajte na umu da su i proizvođači i potrošači jednostavno klijenti Beanstalk poslužitelja i potpuno su neovisni jedan o drugom. U praktičnom smislu to znači da korištenjem Beanstalk-a možete proizvesti svoje poslove u svojoj PHP aplikaciji i obraditi ih na primjer u NodeJS aplikaciji. Srećom, Laravel apstrahira sve ovo i pruža nam vrlo jednostavan API za slanje i rukovanje poslovima, kao što ćemo vidjeti sljedeće.

Uzorak projekta

Da bismo izgradili naš ogledni projekt, prvo moramo instalirati njegove ovisnosti. Instalirat ćemo PHP i Composer.

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

Sada kreirajte projekt na temelju Laravel 5.5.

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

Zatim cdu nedavno kreiranu mapu. Od sada ćemo raditi u ovom imeniku. Ova se mapa kasnije može referencirati kao PROJECT_ROOT.

cd vultr/

Da bismo koristili Beanstalk u Laravelu, moramo instalirati još jednu ovisnost, PHP Beanstalk klijent.

composer require pda/pheanstalk ~3.0

Također moramo kreirati predstavništvo posla. U Laravelu, ovo je klasa unutar app/Jobsmape. Laravel ima naredbu konzole koja nam pomaže stvoriti klasu Job. Kreirajmo naš ogledni posao.

php artisan make:job FindFavoriteOS

Ažurirajte app/Jobs/FindFavoriteOS.phpdatoteku na sljedeće.

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

Metoda ručke je ono što će se učinkovito izvršiti kada se posao potroši. Ovdje dohvaćamo podatke iz Vultr API-ja, nasumično biramo OS i upisujemo odabrani OS u datoteku dnevnika. Dnevnik se nalazi na adresi storage/logs/laravel.log.

Već smo instalirali Beanstalk i definirali posao koji će on izvršiti. Sada je vrijeme da kažete Laravelu da koristi Beanstalk kao zadani radni red. Kopirajte zadanu .envdatoteku koju ste dobili od Laravel instalacije.

cp .env.example .env

Sada otvorite .envdatoteku i ažurirajte redak u kojem je naveden upravljački program čekanja.

QUEUE_DRIVER=beanstalkd

Konačno, generirajte ključ aplikacije.

php artisan key:generate

Sada smo spremni za slanje poslova u radni red Beanstalk.

Raspoređivanje i izvođenje poslova

Slanje posla u Laravelu prilično je jednostavno. Ažurirajte routes/web.phpdatoteku.

<?php

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

    return '50 Jobs dispatched!';
});

Unatoč tome što se ne preporučuje pokretanje ugrađenog poslužitelja u produkciji, ovdje ćemo ga koristiti radi sažetosti.

php artisan serve --host 0.0.0.0 --port 8000

Sada u web-pregledniku idite na http://[vultr-instance-ip]:8000. Vidjet ćete sljedeću poruku.

50 Jobs dispatched!

Otvorite novu SSH vezu sa svojim poslužiteljem i unutar korijena našeg projekta izvršite sljedeće.

php artisan queue:work --once

Ovo je očekivani izlaz:

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

Potvrdite da je zapisnik generiran.

cat storage/logs/laravel.log

Konfiguriranje nadzornika

Kako bismo izbjegli potrebu za ručnom obradom reda čekanja, koristit ćemo supervisord. Napravite sljedeću konfiguraciju programa u /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

Primijetite da će pravi put za postavljanje konfiguracijske datoteke Supervisora ​​ovisiti o vašim postavkama. Također, ne zaboravite zamijeniti [PROJECT_ROOT]punim putem do PROJECT_ROOTna vašem sustavu.

Ovdje konfiguriramo Supervisor da automatski počne obraditi red čekanja i, u slučaju da skripta pokvari, da je ponovno pokrene. Također imajte na umu da ne instanciramo jednog radnika, već 8 procesa. Slobodni ste instancirati koliko god procesa smatrate potrebnima ovisno o vašoj aplikaciji.

Kako biste dopustili Supervizoru da upravlja našim radnikom, prisilite ga da ponovno pročita svoju konfiguraciju.

sudo supervisorctl reread
sudo supervisorctl update

Ako usluga Supervisor nije pokrenuta, mnogi je trebate pokrenuti.

sudo systemctl start supervisord

Sada da vidimo jesu li poslovi u obradi.

tail -f storage/logs/laravel.log

U web-pregledniku idite na http://[vultr-instance-ip]:8000. Vidjet ćete da se zapisnici generiraju na vašoj konzoli.

Zaključak

Uspješno smo konfigurirali Laravel aplikaciju da koristi Beanstalk kao radni red. Također, demonstrirali smo kako koristiti Supervisor za upravljanje radnicima.


Instalirajte Plesk na CentOS 7

Instalirajte Plesk na CentOS 7

Korištenje drugog sustava? Plesk je vlasnička upravljačka ploča web hosta koja omogućuje korisnicima da administriraju svoje osobne i/ili klijentske web stranice, baze podataka

Postavite Cacti na Debian Jessie

Postavite Cacti na Debian Jessie

Uvod Cacti je alat otvorenog koda za praćenje i crtanje koji se u potpunosti temelji na RRD podacima. Putem Cactusa možete pratiti gotovo sve vrste uređaja

Instalirajte Lets Encrypt SSL na WordPress aplikaciju jednim klikom

Instalirajte Lets Encrypt SSL na WordPress aplikaciju jednim klikom

Uvod Lets Encrypt je usluga za izdavanje certifikata koja nudi besplatne TLS/SSL certifikate. Certbot pojednostavljuje proces instalacije,

Kako postaviti Tekkit Classic Server na Ubuntu 16.10

Kako postaviti Tekkit Classic Server na Ubuntu 16.10

Korištenje drugog sustava? Što je Tekkit Classic? Tekkit Classic je modpack za igru ​​koju svi znaju i vole; Minecraft. Sadrži neke od ver

Postavite iRedMail na Debian Wheezy

Postavite iRedMail na Debian Wheezy

Korištenje drugog sustava? Ovaj vodič će vam pokazati kako instalirati grupni softver iRedMail na novu instalaciju Debian Wheezyja. Trebali biste koristiti servis

Izrada Jekyll bloga na Ubuntu 16.04

Izrada Jekyll bloga na Ubuntu 16.04

Korištenje drugog sustava? Jekyll je izvrsna alternativa WordPressu za bloganje ili dijeljenje sadržaja. Ne zahtijeva nikakve baze podataka i vrlo je jednostavan i

Kako postaviti nenadzirane nadogradnje na Debianu 9 (protežu)

Kako postaviti nenadzirane nadogradnje na Debianu 9 (protežu)

Korištenje drugog sustava? Ako kupite Debian poslužitelj, uvijek biste trebali imati najnovije sigurnosne zakrpe i ažuriranja, bez obzira spavate li ili ne

Kako instalirati i konfigurirati PHP 7.0 ili PHP 7.1 na Ubuntu 16.04

Kako instalirati i konfigurirati PHP 7.0 ili PHP 7.1 na Ubuntu 16.04

PHP i povezani paketi najčešće su korištene komponente prilikom postavljanja web poslužitelja. U ovom članku ćemo naučiti kako postaviti PHP 7.0 ili PHP 7.1 o

Kako instalirati Squid proxy na CentOS

Kako instalirati Squid proxy na CentOS

Squid je popularan besplatni program za Linux koji vam omogućuje stvaranje web proxyja za prosljeđivanje. U ovom vodiču vidjet ćete kako instalirati Squid na CentOS da vas preokrene

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je fork Apachea koji ima za cilj da bude puno manje intenzivan prema resursima. Lagan je, otuda mu i naziv, i prilično je jednostavan za korištenje. Instaliraj

Korištenje zaslona na Ubuntu 14.04

Korištenje zaslona na Ubuntu 14.04

Screen je aplikacija koja omogućuje višestruko korištenje terminalskih sesija unutar jednog prozora. To vam omogućuje da simulirate više prozora terminala gdje je ma

Postavite svoj vlastiti DNS poslužitelj na Debian/Ubuntu

Postavite svoj vlastiti DNS poslužitelj na Debian/Ubuntu

Ovaj vodič objašnjava kako postaviti DNS poslužitelj pomoću Bind9 na Debianu ili Ubuntu. U cijelom članku u skladu s tim zamijenite your-domain-name.com. Na th

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

VULTR je nedavno napravio promjene na svojoj strani i sada bi sve trebalo raditi dobro iz kutije s omogućenim NetworkManagerom. Želite li onemogućiti

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Icinga2 je moćan sustav nadzora, a kada se koristi u modelu master-client, može zamijeniti potrebu za provjerama praćenja na temelju NRPE. Glavni klijent

Postavite Red5 Media Server na Ubuntu 16.04

Postavite Red5 Media Server na Ubuntu 16.04

Korištenje drugog sustava? Red5 je medijski poslužitelj otvorenog koda implementiran u Javi koji vam omogućuje pokretanje Flash višekorisničkih aplikacija kao što je live streamin

Prevedite i instalirajte Nginx s modulom PageSpeed ​​na Debian 8

Prevedite i instalirajte Nginx s modulom PageSpeed ​​na Debian 8

U ovom članku ćemo vidjeti kako sastaviti i instalirati Nginx mainline iz službenih izvora Nginxa s modulom PageSpeed, koji vam omogućuje da

Kako instalirati Vanilla Forum na Ubuntu 16.04

Kako instalirati Vanilla Forum na Ubuntu 16.04

Korištenje drugog sustava? Vanilla forum je aplikacija otvorenog koda napisana u PHP-u. Potpuno je prilagodljiv, jednostavan za korištenje i podržava eksterne

Kako instalirati Kanboard na Ubuntu 18.04 LTS

Kako instalirati Kanboard na Ubuntu 18.04 LTS

Korištenje drugog sustava? Uvod Kanboard je besplatni softver za upravljanje projektima otvorenog koda koji je dizajniran za olakšavanje i vizualizaciju

Kako instalirati Kanboard na Debian 9

Kako instalirati Kanboard na Debian 9

Korištenje drugog sustava? Uvod Kanboard je besplatni softver za upravljanje projektima otvorenog koda koji je dizajniran za olakšavanje i vizualizaciju

Kako instalirati Giteu na Debian 9

Kako instalirati Giteu na Debian 9

Korištenje drugog sustava? Gitea je alternativni sustav za kontrolu verzija otvorenog koda s vlastitim hostom koji pokreće Git. Gitea je napisana na Golangu i jest

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više