إدارة طوابير عمل Laravel مع Beanstalk والمشرف على Ubuntu 16.04

Beanstalk هو طابور عمل سريع وبسيط. يسمح لك بتشغيل المهام التي تستغرق وقتًا طويلاً بشكل غير متزامن ، مثل إرسال رسائل البريد الإلكتروني أو الاتصال بواجهات برمجة التطبيقات الخارجية أو معالجة الصور. من خلال القيام بذلك ، سوف تقلل زمن الوصول إلى تطبيق الويب. يوفر Laravel الدعم من خارج منطقة الجزاء beanstalkd.

في هذا البرنامج التعليمي سنقوم بتثبيت beanstalkdوإعداد تطبيق Laravel التجريبي وإدارة عمال الطابور من خلال المشرف . سيحصل التطبيق التجريبي على قائمة بأنظمة التشغيل المتاحة من Vultr API واختيار عشوائيًا.

من المفترض أن لديك مشرفًا مثبتًا بالفعل على نظامك. إذا لم تقم بذلك ، يجب عليك قراءة البرنامج التعليمي التالي حول كيفية إعداد المشرف: تثبيت وتكوين المشرف على Ubuntu 16.04

من المفترض أيضًا أن لديك وصول SSH إلى مثيل 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 كل هذا ويوفر لنا واجهة برمجة تطبيقات بسيطة جدًا لإرسال المهام ومعالجتها ، كما سنرى لاحقًا.

مشروع عينة

لبناء مشروع عينة لدينا ، نحتاج أولاً إلى تثبيت تبعياته. سنقوم بتثبيت 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 ، ونختار نظام تشغيل بشكل عشوائي ونكتب نظام التشغيل المختار إلى ملف السجل. يقع ملف السجل في storage/logs/laravel.log.

لقد قمنا بالفعل بتثبيت Beanstalk وحدد المهمة ليتم تنفيذها من قبله. حان الوقت الآن لإخبار Laravel باستخدام Beanstalk كقائمة انتظار العمل الافتراضية. انسخ .envالملف الافتراضي المقدم من تثبيت Laravel.

cp .env.example .env

الآن افتح .envالملف وقم بتحديث الخط حيث تم تحديد برنامج تشغيل قائمة الانتظار.

QUEUE_DRIVER=beanstalkd

أخيرًا ، أنشئ مفتاح تطبيق.

php artisan key:generate

نحن الآن على استعداد لإرسال وظائف إلى قائمة انتظار عمل Beanstalk.

إيفاد وتشغيل الوظائف

يعد إرسال وظيفة في Laravel أمرًا بسيطًا للغاية. قم بتحديث 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

لاحظ أن المسار الصحيح لوضع ملف تكوين المشرف سيعتمد على الإعداد الخاص بك. تذكر أيضًا أن تستبدل [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. سترى السجلات التي يتم إنشاؤها على وحدة التحكم الخاصة بك.

استنتاج

لقد نجحنا في تكوين تطبيق Laravel لاستخدام Beanstalk كقائمة انتظار عمل. أيضا ، أظهرنا كيفية استخدام المشرف لإدارة العمال.



Leave a Comment

كيفية تثبيت منصة عربة التسوق LiteCart على أوبونتو 16.04

كيفية تثبيت منصة عربة التسوق LiteCart على أوبونتو 16.04

LiteCart عبارة عن منصة سلة تسوق مجانية ومفتوحة المصدر مكتوبة بلغة PHP و jQuery و HTML 5. وهي عبارة عن برنامج بسيط وخفيف الوزن وسهل الاستخدام للتجارة الإلكترونية

قم بإعداد NFS Share على دبيان

قم بإعداد NFS Share على دبيان

NFS هو نظام ملفات قائم على الشبكة يسمح لأجهزة الكمبيوتر بالوصول إلى الملفات عبر شبكة الكمبيوتر. يوضح هذا الدليل كيف يمكنك فضح المجلدات عبر NF

كيفية تثبيت Matomo Analytics على Fedora 28

كيفية تثبيت Matomo Analytics على Fedora 28

استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف

قم بإعداد خادم TeamTalk على Linux

قم بإعداد خادم TeamTalk على Linux

TeamTalk هو نظام مؤتمرات يتيح للمستخدمين إجراء محادثات صوتية / مرئية عالية الجودة ، والدردشة النصية ، ونقل الملفات ، ومشاركة الشاشات. أنا

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا

كيفية تثبيت وتكوين روبي مع Rbenv و Rails و MariaDB و Nginx و SSL و Passenger على Ubuntu 17.04

كيفية تثبيت وتكوين روبي مع Rbenv و Rails و MariaDB و Nginx و SSL و Passenger على Ubuntu 17.04

Ruby on Rails هو إطار عمل شهير لـ Ruby تم تطويره لزيادة إنتاجية المبرمجين. ومع ذلك ، الحصول على الجواهر والتبعيات المختلفة ر

كيفية الوصول إلى Vultr VPS الخاص بك

كيفية الوصول إلى Vultr VPS الخاص بك

يوفر Vultr عدة طرق مختلفة للوصول إلى VPS لتكوين وتثبيت واستخدام. بيانات اعتماد الوصول بيانات اعتماد الوصول الافتراضية لـ VPS الخاص بك

كيفية بناء Brotli من المصدر على Ubuntu 18.04 LTS

كيفية بناء Brotli من المصدر على Ubuntu 18.04 LTS

استخدام نظام مختلف؟ Brotli هو طريقة ضغط جديدة مع نسبة ضغط أفضل من GZIP. تتم استضافة رمز المصدر الخاص به علنًا على Githu هذا

كيفية تثبيت OpenNMS على Ubuntu 16.04 LTS

كيفية تثبيت OpenNMS على Ubuntu 16.04 LTS

استخدام نظام مختلف؟ OpenNMS عبارة عن منصة إدارة شبكة مفتوحة المصدر على مستوى المؤسسات يمكن استخدامها لمراقبة وإدارة العديد من الأجهزة

نشر WebDAV على دبيان 10 باستخدام WsgiDAV

نشر WebDAV على دبيان 10 باستخدام WsgiDAV

مقدمة: التأليف والإصدار الموزع على الويب (WebDAV) هو امتداد HTTP يوفر إطار عمل لإنشاء الملفات وتعديلها عن بُعد على

استخدام طرق عرض MySQL على دبيان 7

استخدام طرق عرض MySQL على دبيان 7

مقدمة يتميز MySQL بميزة رائعة تعرف باسم طرق العرض. المشاهدات هي استعلامات مخزنة. اعتبرها اسمًا مستعارًا لاستعلام طويل. في هذا الدليل ،

كيفية تثبيت Omeka Classic 2.4 CMS على Fedora 26 LAMP VPS

كيفية تثبيت Omeka Classic 2.4 CMS على Fedora 26 LAMP VPS

استخدام نظام مختلف؟ Omeka Classic 2.4 CMS هو نظام نشر رقمي مجاني ومفتوح المصدر ونظام إدارة المحتوى (CMS) لمشاركة الصور الرقمية

كيفية تثبيت DokuWiki على Ubuntu 16.04 LTS

كيفية تثبيت DokuWiki على Ubuntu 16.04 LTS

استخدام نظام مختلف؟ DokuWiki هو برنامج ويكي مفتوح المصدر مكتوب بلغة PHP ولا يتطلب قاعدة بيانات. يقوم بتخزين البيانات في ملفات نصية. DokuWik

إنشاء Chroot على دبيان

إنشاء Chroot على دبيان

ستعلمك هذه المقالة كيفية إعداد سجن سريع على دبيان. أفترض أنك تستخدم Debian 7.x. إذا كنت تقوم بتشغيل دبيان 6 أو 8 ، فقد يعمل هذا ، ولكن

كيفية تثبيت PiVPN على دبيان

كيفية تثبيت PiVPN على دبيان

مقدمة طريقة سهلة لإعداد خادم VPN على دبيان هي PiVPN. PiVPN هو أداة تثبيت وغلاف لـ OpenVPN. يخلق أوامر بسيطة لك

كيفية تثبيت CyberPanel وتكوينه على Ubuntu 18.04 LTS

كيفية تثبيت CyberPanel وتكوينه على Ubuntu 18.04 LTS

استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا

كيفية نشر Ghost v0.11 LTS على Fedora 25

كيفية نشر Ghost v0.11 LTS على Fedora 25

استخدام نظام مختلف؟ Ghost هي منصة تدوين مفتوحة المصدر اكتسبت شعبية بين المطورين والمستخدمين العاديين منذ عام 201

قم بتثبيت RockMongo على CentOS 7

قم بتثبيت RockMongo على CentOS 7

RockMongo هي أداة إدارة MongoDB على الويب تشبه أداة إدارة MySQL: phpMyAdmin. سيغطي هذا البرنامج التعليمي عملية التثبيت

كيفية نشر Lets Chat Server على CentOS 7

كيفية نشر Lets Chat Server على CentOS 7

Lets Chat هو تطبيق دردشة مفتوح المصدر مصمم لتوفير خدمة الرسائل ذاتية الاستضافة للفرق الصغيرة. يعتمد Lets Chat على NodeJS و MongoDB

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

استخدام نظام مختلف؟ Taiga هو تطبيق مجاني ومفتوح المصدر لإدارة المشاريع. على عكس أدوات إدارة المشاريع الأخرى ، يستخدم Taiga زيادة

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

6 أشياء شديدة الجنون حول نينتندو سويتش

6 أشياء شديدة الجنون حول نينتندو سويتش

يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.

وظائف طبقات معمارية مرجعية للبيانات الضخمة

وظائف طبقات معمارية مرجعية للبيانات الضخمة

اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد