مدیریت صف های کاری 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 قرار دهید

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

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

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

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

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

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

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

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

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

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

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

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

تنظیم RethinkDB Cluster On CentOS 7

تنظیم RethinkDB Cluster On CentOS 7

مقدمه RethinkDB یک پایگاه داده NoSQL است که داده ها را به عنوان اسناد JSON ذخیره می کند. این یک زبان پرس و جو بسیار بصری است و از ویژگی های آن معمولا در دسترس است

نحوه ساخت Brotli از Source on Ubuntu 18.04 LTS

نحوه ساخت Brotli از Source on Ubuntu 18.04 LTS

با استفاده از یک سیستم متفاوت؟ Brotli یک روش فشرده سازی جدید با نسبت فشرده سازی بهتر از GZIP است. کد منبع آن در این Githu به صورت عمومی میزبانی می شود

با استفاده از نمایش های MySQL در Debian 7

با استفاده از نمایش های MySQL در Debian 7

مقدمه MySQL دارای یک ویژگی عالی است که به عنوان بازدید شناخته می شود. نمایش نمایش داده شد. برای یک سؤال طولانی مدت از آنها فکر کنید. در این راهنما ،

غیرفعال یا محدود کردن ورود ریشه از طریق SSH در لینوکس

غیرفعال یا محدود کردن ورود ریشه از طریق SSH در لینوکس

اجازه ورود به سیستم ریشه در SSH معمولاً یک روش امنیتی ضعیف در کل صنعت فناوری تلقی می شود. درعوض ، می توانید اداری حساس را انجام دهید

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

نحوه نصب نسخه باز Vtiger CRM در CentOS 7

Vtiger CRM یک نرم افزار محبوب مدیریت ارتباط با مشتری است که می تواند به بنگاهها در رشد فروش ، ارائه خدمات به مشتری و افزایش سود کمک کند. من

نحوه نصب DokuWiki در اوبونتو 16.04 LTS

نحوه نصب DokuWiki در اوبونتو 16.04 LTS

با استفاده از یک سیستم متفاوت؟ DokuWiki یک برنامه ویکی منبع باز است که به زبان پی اچ پی نوشته شده است و به پایگاه داده نیاز ندارد. این داده ها را در پرونده های متنی ذخیره می کند. DokuWik

راه اندازی یک Chroot در دبیان

راه اندازی یک Chroot در دبیان

در این مقاله به شما می آموزد که چگونه زندان دزدگیر را در دبیان تنظیم کنید. تصور می کنم از Debian 7.x استفاده می کنید. اگر دبیان 6 یا 8 را اجرا کردید ، ممکن است این کار کند

نحوه نصب PiVPN در Debian

نحوه نصب PiVPN در Debian

مقدمه یک راه آسان برای راه اندازی سرور VPN در دبیان با PiVPN است. PiVPN نصب و بسته بندی OpenVPN است. این دستورات ساده را برای شما ایجاد می کند

Nginx ، Wordpress را نصب کنید و رمزگذاری را در چند دقیقه با EasyEngine روی Debian 8 یا Ubuntu 16.04 نصب کنید

Nginx ، Wordpress را نصب کنید و رمزگذاری را در چند دقیقه با EasyEngine روی Debian 8 یا Ubuntu 16.04 نصب کنید

EasyEngine (ee) ابزاری پایتون است که به شما امکان می دهد سایت های وردپرس خود را به راحتی و به صورت خودکار مدیریت کنید. با استفاده از EasyEngine ، شما مجبور به dea نیستید

نحوه نصب و پیکربندی CyberPanel در Ubuntu 18.04 LTS

نحوه نصب و پیکربندی CyberPanel در Ubuntu 18.04 LTS

با استفاده از یک سیستم متفاوت؟ مقدمه CyberPanel یکی از اولین صفحه کنترل در بازار است که هم منبع باز است و هم از OpenLiteSpeed ​​استفاده می کند. چی

نحوه ساخت Brotli از Source on Debian 9

نحوه ساخت Brotli از Source on Debian 9

با استفاده از یک سیستم متفاوت؟ Brotli یک روش فشرده سازی جدید با نسبت فشرده سازی بهتر از Gzip است. کد منبع آن در Github به صورت عمومی میزبانی می شود. تی

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

نحوه نصب کاناپه CMS 2.0 بر روی یک VPS CentOS 7 LAMP

با استفاده از یک سیستم متفاوت؟ Couch CMS یک سیستم مدیریت محتوای منبع ساده و انعطاف پذیر ، آزاد و منبع باز (CMS) است که به طراحان وب اجازه می دهد تا طراحی کنند.

ایجاد یک سرور Teamspeak 3 در اوبونتو 14 64 بیتی

ایجاد یک سرور Teamspeak 3 در اوبونتو 14 64 بیتی

بررسی اجمالی که آیا شما در حال همکاری در یک پروژه همکاری بزرگ با تیم توسعه خود هستید و یا در جدیدترین بازی نقش آفرینی رئیس را می کشید ، می خواهید

نحوه نصب بستر سبد خرید 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 است. این برنامه یک رابط لعنتی مینیمالیستی و زیبا با نمای سلسله مراتب فهرست ارائه می دهد