مدیریت صف های کاری Laravel With Beanstalk و Supervisor on Ubuntu 16.04

Beanstalk یک صف کار سریع و ساده است. این امکان را به شما می دهد تا کارهای غیر وقت گیر را بصورت غیر همزمان ، مانند ارسال ایمیل ، اتصال به API های خارجی یا پردازش تصاویر انجام دهید. با این کار ، تأخیر برنامه وب خود را کاهش می دهید. Laravel پشتیبانی خارج از جعبه را برای شما فراهم می کند beanstalkd.

در این آموزش نصب خواهیم کرد beanstalkd، یک نسخه آزمایشی Laravel را نصب کرده و صف کارگران را از طریق Supervisor مدیریت خواهیم کرد. برنامه نسخه ی نمایشی لیستی از سیستم عامل های موجود را از Vultr API دریافت می کند و بطور تصادفی یکی را انتخاب می کند.

فرض بر این است که شما از قبل Supervisor را روی سیستم خود نصب کرده اید. اگر این کار را نکردید ، باید آموزش زیر را در مورد نحوه راه اندازی Supervisor مطالعه کنید: نصب و پیکربندی سرپرست در اوبونتو 16.04

همچنین فرض بر این است که شما به Sult نمونه Vultr خود دسترسی دارید.

نصب Beanstalk

اولین قدم برای نصب ، نصب است beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

خدمات را شروع کنید.

sudo systemctl start beanstalkd

همچنین می توانید این سرویس را با آغاز به کار سیستم فعال کنید.

sudo systemctl enable beanstalkd

وضعیت خدمات را با صدور دستور زیر بررسی کنید.

sudo systemctl status beanstalkd

به طور پیش فرض ، beanstalkdدرگاه را گوش می دهد 11300. Beanstalk از یک پروتکل مبتنی بر متن ساده که در مخزن آن github استفاده می شود ، استفاده می کند . با اجرای آن می توانید پروتکل آن را تست کنید telnet.

telnet localhost 11300

موارد زیر را بنویسید و بزنید ENTER.

list-tubes

شما باید لیستی از لوله های موجود در سرور را مشاهده کنید:

OK 14
---
- default

برای بستن اتصال به سادگی تایپ کنید quitو سپس را فشار دهید ENTER.

لوله های Beanstalk صف های کاری را نشان می دهند. لوبیای سحرآمیز است که اساسا توسط تشکیل شده تولید ، مصرف کنندگان ، شغل و لوله . تولیدکنندگان مشاغل را در یک لوله قرار می دهند تا توسط هر تعداد مصرف کننده مصرف و پردازش شود. توجه داشته باشید که هم تولید کنندگان و هم مصرف کنندگان صرفاً مشتری های سرور Beanstalk هستند و کاملاً مستقل از یکدیگر هستند. از نظر عملی این بدان معنی است که با استفاده از Beanstalk می توانید شغل خود را در برنامه PHP خود ایجاد کنید و به عنوان مثال در یک برنامه NodeJS پردازش کنید. خوشبختانه ، Laravel همه این موارد را خلاصه می کند و یک API بسیار ساده برای اعزام و رسیدگی به مشاغل به ما ارائه می دهد ، همانطور که در ادامه خواهیم دید.

پروژه نمونه

برای ساخت پروژه نمونه ، ابتدا باید وابستگی های آن را نصب کنیم. ما قصد داریم PHP و Composer را نصب کنیم.

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

اکنون این پروژه را بر اساس Laravel 5.5 ایجاد کنید.

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

بعد cdبه پوشه اخیراً ایجاد شده. ما از این پس کار خواهیم کرد. این پوشه ممکن است بعداً به عنوان ارجاع داده شود PROJECT_ROOT.

cd vultr/

برای استفاده از Beanstalk در Laravel ، باید یک وابستگی دیگر ، مشتری PHP Beanstalk نصب کنیم.

composer require pda/pheanstalk ~3.0

ما همچنین نیاز به ایجاد یک نمایندگی شغل داریم. در Laravel ، این یک کلاس در داخل app/Jobsپوشه است. Laravel یک دستور کنسول برای کمک به ما در ایجاد کلاس شغلی دارد. بیایید نمونه کار خود را ایجاد کنیم.

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

روش دسته همان چیزی است که هنگام کار شغل به طور مؤثر اجرا خواهد شد. در اینجا ، ما از داده های Vultr API واکشی می کنیم ، به طور تصادفی یک سیستم عامل را انتخاب می کنیم و سیستم عامل انتخاب شده را روی پرونده log می نویسیم. پرونده log در واقع است storage/logs/laravel.log.

ما قبلاً Beanstalk را نصب کرده ایم و کار را برای اجرای آن تعریف کرده ایم. اکنون زمان آن رسیده است که به لاراول بگوییم از Beanstalk به عنوان صف کار پیش فرض استفاده کند. .envپرونده پیش فرض تهیه شده توسط نصب Laravel را کپی کنید .

cp .env.example .env

اکنون .envپرونده را باز کرده و خطی را که درایور صف مشخص شده است به روز کنید.

QUEUE_DRIVER=beanstalkd

در آخر ، یک کلید برنامه ایجاد کنید.

php artisan key:generate

اکنون ما آماده اعزام مشاغل به صف کار Beanstalk هستیم.

اعزام و اجرای شغل

اعزام به کار در لاراول بسیار ساده است. 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!

یک اتصال جدید SSH به سرور خود و در داخل ریشه پروژه ما باز کنید ، موارد زیر را اجرا کنید.

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

توجه کنید که مسیر درست برای قرار دادن پرونده پیکربندی Supervisor به تنظیم شما بستگی دارد. همچنین ، به یاد داشته باشید که جایگزین [PROJECT_ROOT]مسیر کامل PROJECT_ROOTسیستم روی سیستم شوید.

در اینجا ما در حال پیکربندی Supervisor هستیم تا به طور خودکار پردازش صف را شروع کرده و در صورت شکستن اسکریپت ، مجدداً آن را راه اندازی کند. همچنین توجه داشته باشید که ما یک کارگر تنها را فوری نمی کنیم بلکه 8 فرآیند را انجام می دهیم. شما می توانید بسته به برنامه خود ، بلافاصله بسیاری از فرآیندهای لازم را فوری کنید.

برای اینکه سرپرست بتواند کارگر ما را مدیریت کند ، مجبور می شویم پیکربندی خود را دوباره بخواند.

sudo supervisorctl reread
sudo supervisorctl update

اگر سرویس Supervisor شروع نشده است ، بسیاری از افراد نیاز به راه اندازی آن دارند.

sudo systemctl start supervisord

حال بیایید ببینیم که آیا مشاغل در حال پردازش هستند یا خیر.

tail -f storage/logs/laravel.log

در یک مرورگر وب ، به حرکت کنید http://[vultr-instance-ip]:8000. گزارش های موجود در کنسول خود را مشاهده خواهید کرد.

نتیجه

ما با موفقیت برنامه Laravel پیکربندی کرده ایم تا از Beanstalk به عنوان یک صف کار استفاده کند. همچنین ، ما نحوه استفاده از ناظر را برای مدیریت کارگران نشان دادیم.



Leave a Comment

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

نحوه نصب بستر سبد خرید LiteCart در اوبونتو 16.04

LiteCart یک بستر سبد خرید آزاد و منبع باز است که به زبان های PHP ، jQuery و HTML 5 نوشته شده است. این نرم افزار ساده ، سبک و با کاربرد آسان است.

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

نحوه نصب Anchor CMS بر روی یک VPS Fedora 26 LAMP

با استفاده از یک سیستم متفاوت؟ Anchor CMS یک سیستم مدیریت محتوا (CMS) بسیار ساده و بسیار سبک ، بسیار آزاد و آزاد است.

اشتراک NFS را در Debian تنظیم کنید

اشتراک NFS را در Debian تنظیم کنید

NFS یک سیستم فایل مبتنی بر شبکه است که به رایانه ها اجازه می دهد تا از طریق شبکه رایانه ای به فایلها دسترسی پیدا کنند. این راهنما توضیح می دهد که چگونه می توانید پوشه ها را روی NF قرار دهید

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

نحوه بروزرسانی CentOS 7 ، Ubuntu 16.04 و Debian 8

هنگام راه اندازی سرور جدید لینوکس ، به روزرسانی سیستم های هسته و سایر بسته ها تا آخرین نسخه پایدار یک روش توصیه شده است. در این مقاله

نحوه نصب Matomo Analytics در Fedora 28

نحوه نصب Matomo Analytics در Fedora 28

با استفاده از یک سیستم متفاوت؟ Matomo (سابقا پیویک) یک بستر تحلیلی منبع باز است ، یک جایگزین باز برای Google Analytics. منبع Matomo میزبان o

یک سرور TeamTalk را در لینوکس تنظیم کنید

یک سرور TeamTalk را در لینوکس تنظیم کنید

TeamTalk یک سیستم کنفرانس است که به کاربران امکان می دهد مکالمات صوتی / تصویری با کیفیت بالا ، چت متنی ، انتقال فایل ها و صفحه های به اشتراک بگذارند. من

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

با استفاده از کلید SSH خود برای ورود به کاربران غیر ریشه استفاده کنید

Vultr یک ویژگی را فراهم می کند که به شما امکان می دهد با ایجاد یک نمونه جدید ، کلیدهای SSH را از قبل نصب کنید. این اجازه می دهد تا به کاربر root دسترسی داشته باشید ، با این حال ، th

نحوه نصب انجمن NodeBB در FreeBSD 12

نحوه نصب انجمن NodeBB در FreeBSD 12

با استفاده از یک سیستم متفاوت؟ NodeBB یک نرم افزار انجمن مبتنی بر Node.js است. از سوکت های وب برای تعامل فوری و اعلامیه های زمان واقعی استفاده می کند. NodeB

نصب و راه اندازی ZNC در اوبونتو

نصب و راه اندازی ZNC در اوبونتو

ZNC یک پیشرانه پیشرفته شبکه IRC است که تمام وقت بهم متصل می شود تا مشتری IRC بتواند بدون از دست دادن جلسه گپ قطع یا وصل شود.

نحوه نصب Ranger Terminal File Manager در لینوکس

نحوه نصب Ranger Terminal File Manager در لینوکس

رنجر یک مدیر فایل مبتنی بر خط فرمان است که دارای کلیدهای اتصال VI است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد