Instalacija Beanstalka
Uzorak projekta
Raspoređivanje i izvođenje poslova
Konfiguriranje nadzornika
Zaključak
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.