Управљање Ларавел радним редовима помоћу Беансталк-а и супервизора на Убунту 16.04

Беансталк је брз и једноставан радни ред. Омогућава вам да асинхроно извршавате задатке који одузимају време, као што је слање е-поште, повезивање са спољним АПИ-јима или обрада слика. На тај начин ћете смањити кашњење веб апликације. Ларавел обезбеђује готову подршку за beanstalkd.

У овом beanstalkdводичу ћемо инсталирати , подесити демо Ларавел апликацију и управљати радницима у реду преко Супервизора . Демо апликација ће добити листу доступних ОС-а од Вултр АПИ-ја и насумично изабрати један.

Претпоставља се да већ имате инсталиран Супервизор на вашем систему. Ако то не учините, требало би да прочитате следећи водич о томе како да подесите Супервисор: Инсталирање и конфигурисање Супервизора на Убунту 16.04

Такође се претпоставља да имате ССХ приступ вашој Вултр инстанци.

Инсталирање Беансталк-а

Први корак који треба предузети је инсталирање beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Покрените услугу.

sudo systemctl start beanstalkd

Такође можете омогућити да се услуга покрене након иницијализације система.

sudo systemctl enable beanstalkd

Проверите статус услуге издавањем следеће команде.

sudo systemctl status beanstalkd

Подразумевано, beanstalkdслуша на порту 11300. Беансталк користи једноставан протокол заснован на тексту описан у свом гитхуб репозиторијуму . Можете тестирати његов протокол тако што ћете покренути telnet.

telnet localhost 11300

Напишите следеће и притисните ENTER.

list-tubes

Требало би да видите листу цеви доступних на серверу:

OK 14
---
- default

Да бисте затворили везу, једноставно откуцајте, quitа затим притисните ENTER.

Цеви у Беансталк-у представљају радне редове. Стабљика пасуља се састоји углавном од произвођача , потрошача , послова и цеви . Произвођачи стављају послове у цев да их конзумира (обради) било који број потрошача. Имајте на уму да су и произвођачи и потрошачи једноставно клијенти Беансталк сервера и потпуно су независни један од другог. У практичном смислу, ово значи да коришћењем Беансталк-а можете да креирате своје послове у својој ПХП апликацији и да их обрађујете у НодеЈС апликацији, на пример. Срећом, Ларавел апстрахује све ово и пружа нам врло једноставан АПИ за слање и руковање пословима, као што ћемо видети следеће.

Пример пројекта

Да бисмо направили наш пример пројекта, прво морамо да инсталирамо његове зависности. Инсталираћемо ПХП и Цомпосер.

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

Сада креирајте пројекат заснован на Ларавел 5.5.

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

Затим cdу недавно креирану фасциклу. Од сада ћемо радити у овом директоријуму. Ова фасцикла се касније може референцирати као PROJECT_ROOT.

cd vultr/

Да бисмо користили Беансталк у Ларавел-у, потребно је да инсталирамо још једну зависност, ПХП Беансталк клијент.

composer require pda/pheanstalk ~3.0

Такође треба да направимо представништво посла. У Ларавел-у, ово је класа унутар app/Jobsфасцикле. Ларавел има команду на конзоли која нам помаже да креирамо класу Јоб. Хајде да направимо наш пример посла.

php artisan make:job FindFavoriteOS

Ажурирајте app/Jobs/FindFavoriteOS.phpдатотеку на следеће.

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

Метода ручке је оно што ће се ефикасно извршити када се посао потроши. Овде преузимамо податке из Вултр АПИ-ја, насумично бирамо ОС и уписујемо изабрани ОС у датотеку евиденције. Датотека евиденције се налази на storage/logs/laravel.log.

Већ смо инсталирали Беансталк и дефинисали посао који ће он извршити. Сада је време да се каже Ларавел-у да користи Беансталк као подразумевани радни ред. Копирајте подразумевану .envдатотеку коју сте добили од Ларавел инсталације.

cp .env.example .env

Сада отворите .envдатотеку и ажурирајте ред у којем је наведен драјвер реда.

QUEUE_DRIVER=beanstalkd

На крају, генеришите кључ апликације.

php artisan key:generate

Сада смо спремни да пошаљемо послове у радни ред Беансталк-а.

Распоређивање и вођење послова

Слање посла у Ларавел-у је прилично једноставно. Ажурирајте routes/web.phpдатотеку.

<?php

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

    return '50 Jobs dispatched!';
});

Иако се не препоручује покретање уграђеног сервера у производњи, ми ћемо га овде користити ради краткоће.

php artisan serve --host 0.0.0.0 --port 8000

Сада у веб претраживачу идите на http://[vultr-instance-ip]:8000. Видећете следећу поруку.

50 Jobs dispatched!

Отворите нову ССХ везу са својим сервером и унутар корена нашег пројекта извршите следеће.

php artisan queue:work --once

Ово је очекивани излаз:

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

Потврдите да је дневник генерисан.

cat storage/logs/laravel.log

Конфигурисање Супервизора

Да бисмо избегли потребу за ручном обрадом реда, користићемо supervisord. Креирајте следећу конфигурацију програма у /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

Имајте на уму да ће права путања за постављање конфигурационе датотеке Супервизора зависити од вашег подешавања. Такође, не заборавите да замените [PROJECT_ROOT]пуном путањом до PROJECT_ROOTна вашем систему.

Овде конфигуришемо Супервизор да аутоматски почне да обрађује ред и, у случају да се скрипта поквари, да је поново покрене. Такође имајте на уму да не инстанцирамо једног радника, већ 8 процеса. Слободни сте да инстанцирате колико год процеса сматрате потребним у зависности од ваше апликације.

Да бисте дозволили Супервизору да управља нашим радником, натерајте га да поново прочита своју конфигурацију.

sudo supervisorctl reread
sudo supervisorctl update

Ако услуга Супервизор није покренута, многи морате да је покренете.

sudo systemctl start supervisord

Сада да видимо да ли се послови обрађују.

tail -f storage/logs/laravel.log

У веб прегледачу идите на http://[vultr-instance-ip]:8000. Видећете да се евиденције генеришу на вашој конзоли.

Закључак

Успешно смо конфигурисали Ларавел апликацију да користи Беансталк као радни ред. Такође, демонстрирали смо како се Супервизор користи за управљање радницима.


Инсталирајте Плеск на ЦентОС 7

Инсталирајте Плеск на ЦентОС 7

Користите другачији систем? Плеск је власничка контролна табла веб хоста која омогућава корисницима да управљају својим личним и/или клијентским веб локацијама, базама података

Подесите Цацти на Дебиан Јессие

Подесите Цацти на Дебиан Јессие

Увод Цацти је алатка отвореног кода за праћење и графику која је у потпуности заснована на РРД подацима. Преко Цацтуса можете надгледати скоро сваку врсту уређаја

Инсталирајте Летс Енцрипт ССЛ на ВордПресс апликацију једним кликом

Инсталирајте Летс Енцрипт ССЛ на ВордПресс апликацију једним кликом

Увод Летс Енцрипт је услуга ауторитета за сертификате која нуди бесплатне ТЛС/ССЛ сертификате. Цертбот поједностављује процес инсталације,

Подесите иРедМаил на Дебиан Вхеези

Подесите иРедМаил на Дебиан Вхеези

Користите другачији систем? Овај водич ће вам показати како да инсталирате групни софтвер иРедМаил на нову инсталацију Дебиан Вхеези-а. Требало би да користите сервис

Креирање Јекилл блога на Убунту 16.04

Креирање Јекилл блога на Убунту 16.04

Користите другачији систем? Јекилл је одлична алтернатива ВордПресс-у за блоговање или дељење садржаја. Не захтева никакве базе података и веома је лако и

Како подесити надоградње без надзора на Дебиан 9 (протежу)

Како подесити надоградње без надзора на Дебиан 9 (протежу)

Користите другачији систем? Ако купите Дебиан сервер, увек би требало да имате најновије безбедносне закрпе и ажурирања, без обзира да ли спавате или не

Како инсталирати и конфигурисати ПХП 7.0 или ПХП 7.1 на Убунту 16.04

Како инсталирати и конфигурисати ПХП 7.0 или ПХП 7.1 на Убунту 16.04

ПХП и повезани пакети су најчешће коришћене компоненте приликом постављања веб сервера. У овом чланку ћемо научити како да подесите ПХП 7.0 или ПХП 7.1 о

Како инсталирати Скуид проки на ЦентОС

Како инсталирати Скуид проки на ЦентОС

Скуид је популаран, бесплатни Линук програм који вам омогућава да креирате веб проки за прослеђивање. У овом водичу ћете видети како да инсталирате Скуид на ЦентОС да вас преокрене

Како инсталирати Лигхттпд (ЛЛМП Стацк) на ЦентОС 6

Како инсталирати Лигхттпд (ЛЛМП Стацк) на ЦентОС 6

Увод Лигхттпд је форк Апацхе-а који има за циљ да буде много мање интензиван према ресурсима. Лаган је, отуда и његово име, и прилично је једноставан за употребу. Инсталлин

Три бесплатна контролна панела сервера (брза инсталација)

Три бесплатна контролна панела сервера (брза инсталација)

1. Виртуалмин/Вебмин Виртуалмин је моћна и флексибилна контролна табла за веб хостинг за Линук и УНИКС системе заснована на добро познатој веб бази отвореног кода

Подешавање Иии апликације на Убунту 14.04

Подешавање Иии апликације на Убунту 14.04

Иии је ПХП оквир који вам омогућава да брже и лакше развијате апликације. Инсталирање Иии-а на Убунту је једноставно, као што ћете тачно научити

Коришћење екрана на Убунту 14.04

Коришћење екрана на Убунту 14.04

Сцреен је апликација која омогућава вишеструку употребу терминалских сесија унутар једног прозора. Ово вам омогућава да симулирате више прозора терминала где је ма

Подесите сопствени ДНС сервер на Дебиан/Убунту

Подесите сопствени ДНС сервер на Дебиан/Убунту

Овај водич објашњава како да подесите ДНС сервер користећи Бинд9 на Дебиан-у или Убунту-у. У целом чланку замените иоур-домаин-наме.цом у складу са тим. Ат тх

Коришћење Логротате за управљање датотекама евиденције

Коришћење Логротате за управљање датотекама евиденције

Увод Логротате је Линук услужни програм који поједностављује администрацију датотека евиденције. Обично се покреће једном дневно преко црон посла и управља базом евиденције

Конфигурисање статичког умрежавања и ИПв6 на ЦентОС 7

Конфигурисање статичког умрежавања и ИПв6 на ЦентОС 7

ВУЛТР је недавно направио измене на њиховој страни, и сада би све требало да ради добро из кутије са омогућеним НетворкМанагер-ом. Ако желите да онемогућите

Модификовање Ицинга2 да користи модел Мастер/Цлиент на ЦентОС 6 или ЦентОС 7

Модификовање Ицинга2 да користи модел Мастер/Цлиент на ЦентОС 6 или ЦентОС 7

Ицинга2 је моћан систем за праћење, и када се користи у моделу мастер-цлиент, може да замени потребу за провером праћења заснованом на НРПЕ. Главни клијент

Подесите Ред5 Медиа Сервер на Убунту 16.04

Подесите Ред5 Медиа Сервер на Убунту 16.04

Користите другачији систем? Ред5 је медијски сервер отвореног кода имплементиран у Јави који вам омогућава да покренете Фласх вишекорисничке апликације као што је ливе стреамин

Компајлирајте и инсталирајте Нгинк са модулом ПагеСпеед на Дебиан 8

Компајлирајте и инсталирајте Нгинк са модулом ПагеСпеед на Дебиан 8

У овом чланку ћемо видети како да компајлирате и инсталирате Нгинк маинлине из званичних извора Нгинк-а помоћу модула ПагеСпеед, који вам омогућава да

Како инсталирати Апацхе Цассандра 3.11.к на Убунту 16.04 ЛТС

Како инсталирати Апацхе Цассандра 3.11.к на Убунту 16.04 ЛТС

Користите другачији систем? Апацхе Цассандра је бесплатан систем за управљање НоСКЛ базом података отвореног кода који је дизајниран да обезбеди скалабилност, високу

Како инсталирати Ванилла Форум на Убунту 16.04

Како инсталирати Ванилла Форум на Убунту 16.04

Користите другачији систем? Ванилла форум је апликација отвореног кода написана у ПХП-у. Потпуно је прилагодљив, једноставан за коришћење и подржава екстерне

Успон машина: Примене вештачке интелигенције у стварном свету

Успон машина: Примене вештачке интелигенције у стварном свету

Вештачка интелигенција није у будућности, она је овде управо у садашњости. У овом блогу Прочитајте како су апликације вештачке интелигенције утицале на различите секторе.

ДДОС напади: кратак преглед

ДДОС напади: кратак преглед

Да ли сте и ви жртва ДДОС напада и збуњени сте методама превенције? Прочитајте овај чланак да бисте решили своја питања.

Да ли сте се икада запитали како хакери зарађују новац?

Да ли сте се икада запитали како хакери зарађују новац?

Можда сте чули да хакери зарађују много новца, али да ли сте се икада запитали како зарађују толики новац? Хајде да причамо.

Гоогле-ови револуционарни изуми који ће вам олакшати живот.

Гоогле-ови револуционарни изуми који ће вам олакшати живот.

Да ли желите да видите револуционарне изуме Гугла и како су ти изуми променили живот сваког људског бића данас? Затим читајте на блогу да бисте видели Гооглеове изуме.

Фридаи Ессентиал: Шта се десило са аутомобилима које покреће вештачка интелигенција?

Фридаи Ессентиал: Шта се десило са аутомобилима које покреће вештачка интелигенција?

Концепт самовозећих аутомобила који путују на путеве уз помоћ вештачке интелигенције је сан који већ неко време имамо. Али упркос неколико обећања, њих нема нигде. Прочитајте овај блог да сазнате више…

Технолошка сингуларност: далека будућност људске цивилизације?

Технолошка сингуларност: далека будућност људске цивилизације?

Како се наука развија великом брзином, преузимајући многе наше напоре, расте и ризик да се подвргнемо необјашњивој сингуларности. Прочитајте шта би сингуларност могла да значи за нас.

Еволуција складиштења података – Инфографика

Еволуција складиштења података – Инфографика

Методе складиштења података су се развијале можда од рођења података. Овај блог покрива еволуцију складиштења података на основу инфографике.

Функционалности слојева референтне архитектуре великих података

Функционалности слојева референтне архитектуре великих података

Прочитајте блог да бисте на најједноставнији начин упознали различите слојеве у архитектури великих података и њихове функционалности.

6 невероватних предности поседовања паметних кућних уређаја у нашим животима

6 невероватних предности поседовања паметних кућних уређаја у нашим животима

У овом дигиталном свету, паметни кућни уређаји постали су кључни део живота. Ево неколико невероватних предности паметних кућних уређаја о томе како они чине наш живот вредним живљења и једноставнијим.

Ажурирање додатка за мацОС Цаталина 10.15.4 изазива више проблема него што их решава

Ажурирање додатка за мацОС Цаталина 10.15.4 изазива више проблема него што их решава

Недавно је Аппле издао мацОС Цаталина 10.15.4 додатак за исправку проблема, али изгледа да ажурирање изазива више проблема који доводе до квара Мац машина. Прочитајте овај чланак да бисте сазнали више