زمانبندی وظایف در لاراول (Laravel) – راهنمای مقدماتی


در این مقاله به توضیح یکی از خصوصیات فریمورک وب لاراول میپردازیم. یعنی میخواهیم زمانبندی وظایف در لاراول را بررسی کنیم. در طی این راهنما به روش مدیریت وظایف زمانبندیشده در اپلیکیشن از سوی لاراول میپردازیم. به علاوه در انتها وظایف زمانبندیشده خاص خود را برای مقاصد آموزشی ایجاد میکنیم.
فریمورک لاراول به ما اجازه میدهد که وظایف زمانبندیشده را طوری ایجاد کنیم که هیچ نگرانی در مورد راهاندازی آن در سطح سیستمی نداشته باشیم. بدین ترتیب میتوان ساختار cron را برای راهاندازی وظایف زمانبندیشده کنار گذاشت، چون لاراول امکان تعریف کردن آنها به روشی کاربرپسند را فراهم ساخته است.
در ابتدای مقاله به توضیح روش مورد استفاده برای راهاندازی کارهای سنتی cron میپردازیم و سپس روش لاراول را برای رسیدن به این مقصود بررسی میکنیم. در نیمه دوم این مقاله نیز تلاش میکنیم چند وظیفه زمانبندیشده سفارشی ایجاد کنیم که موجب میشود بینشی عملی از این موضوع پیدا کنید.
تنظیمات سنتی برای وظایف زمانبندی شده
در زمان توسعه اپلیکیشن به طور روزمره با موقعیتهایی مواجه میشویم که نیازمند اجرای برخی اسکریپتهای خاص دستورها به صورت دورهای هستیم. اگر با سیستمهای یونیکسی کار میکنید احتمالاً میدانید که job cron این دستورها را میتوانند اجرا کنند. از سوی دیگر این موارد در سیستمهای مبتنی بر ویندوز به نام وظایف زمانبندی شده (scheduled tasks) شناخته میشوند.
در ادامه به بررسی یک مثال ساده از job cron مبتنی بر یونیکس میپردازیم:
*/5 * * * * /web/statistics.sh
این کد کاملاً ساده است. این کد فایل statistics.sh را هر 5 دقیقه یک بار اجرا میکند.
با این که این روش بسیار ساده است؛ اما در اغلب موارد با موقعیتهایی مواجه هستیم که نیازمند پیادهسازی کاربردهای بسیار پیچیدهتری هستیم. از سوی دیگر سیستمهای پیچیده نیازمند تعریف کردن چندین job cron است که در بازههای زمانی متفاوتی اجرا شوند.
در ادامه برخی از وظایف را مشاهده میکنید که یک وب اپلیکیشن پیچیده باید به صوت دورهای در بکاند خود اجرا کند:
- پاکسازی دادههای غیرضروری از پایگاه داده بکاند
- بهروزرسانی اندیسهای کش فراتاند جهت حفظ بهروزرسانی
- محاسبه آمارهای وبسایت
- ارسال ایمیلها
- پشتیبانگیری از اجزای مختلف وبسایت
- تولید گزارشها
- و موارد دیگر
بنابراین چنانکه میبینید کارهای زیادی وجود دارند که باید به صورت دورهای و همچنین در بازههای زمانی متفاوت اجرا شوند. اگر یک «سیستم ادمین» پارهوقت باشید، تعریف job cron برای این وظایف، بسیار ساده خواهد بود؛ اما در پارهای مواد توسعهدهندگان میخواهند که روش آسانتری نیز در اختیار داشته باشند.
خوشبختانه لاراول دارای API داخلی Task Scheduling است که امکان تعریف کردن وظایف زمانبندیشده را به روشی بسیار آسان فراهم میکند. در بخش بعدی در مورد مبانی زمانبندی وظایف در لاراول صحبت خواهیم کرد.
زمانبندی وظایف در لاراول
در بخش قبلی به معرفی روش سنتی راهاندازی cron job پرداختیم. در این بخش به بررسی جزییات API زمانبندی وظایف در لاراول میپردازیم.
پیش از آن که ادامه بدهیم باید این نکته مهم را یادآور شویم که ویژگی زمانبندی ارائه شده از سوی لاراول شبیه به هیچ ویژگی دیگر نیست و به صورت خودکار فراخوانی نخواهد شد. بنابراین اگر فکر میکنید که نیازی به هیچ چیز دیگر در سطح سیستم ندارید در این صورت باید در تفکرات خود تجدید نظر کنید.
در واقع نخستین چیزی که در صورت تمایل به استفاده از زمانبندی وظایف در لاراول باید انجام دهید این است که یک cron job راهاندازی کنید که هر دقیقه اجرا شود و دستور artisan نمایش یافته در قطعه کد زیر را اجرا کند:
* * * * * php /path-to-your-project/artisan schedule:run >> /dev/null 2>&1
دستور artisan فوق به فراخوانی ابزار زمانبندی لاراول میپردازد و آن نیز به نوبه خود همه cron job-های در انتظار که در اپلیکیشن تعریفشدهاند را اجرا میکند. البته ما هنوز باید به بررسی روش تعریف کردن وظایف زمانبندیشده در لاراول بپردازیم و این بحث بعدی است که مطرح میشود. با استفاده از متد schedule در کلاس App\Console\Kernel اقدام به تعریف کردن وظایف زمانبندیشده خاص اپلیکیشن میکند. بنابراین پیشتر رفته و محتوای فایل app/Console/Kernel.php را مورد بررسی قرار میدهیم:
همان طور که میبینید کد اصلی خودش یک مثال مفید است. در مثال فوق لاراول دستور artisan با نام inspire را به صورت ساعتی اجرا میکند. آیا فکر نمیکنید ساختار آن در وهله نخست کاملاً گویا است؟
در واقع روشهای مختلفی وجود دارد که به لاراول اجازه میدهد تا به تعریف وظایف زمانبندیشده بپردازد. به علاوه موارد فراوانی از نمونههای زمانبندی داخلی وجود دارد که میتوان از میان آنها انتخاب کرد:
- هر دقیقه/ هر پنج دقیقه
- ساعتی/ روزانه/ هفتگی/ فصلی/ سالانه
- در زمان خاصی از روز
- و موارد دیگر
در حقیقت میتوان گفت لاراول چنان مجموعه کاملی از رویهها را طراحی کرده که حتی نیاز به دست زدن به Shell برای ایجاد cron job-های سفارشی نیز نداریم. مطمئناً شما مشتاق هستید که بدانید چگونه میتوانید وظایف زمانبندیشده سفارشی را پیادهسازی کنید و این همان نکتهای است که در ابتدای مقاله قولش را به شما داده بودیم.
ایجاد وظایف زمانبندی شده در لاراول
همان طور که گفتیم، روشهای مختلفی برای زمانبندی وظایف در لاراول وجود دارد. در ادامه هر یک از آنها را بررسی میکنیم تا با طرز کارشان آشنا شویم.
متد Closure/Callable
API زمانبندی متد call را ارائه کرده است که امکان اجرای تابع callable یا یک تابع closure را میدهد. در ادامه محتوای فایل app/Console/Kernel.php که دارای کد زیر است را میبینید:
همان طور که میبینید ما تابع closure را به عنوان اولین آرگومان متد call ارسال کردهایم. ضمناً فراوانی آن را به صورت هر 30 دقیقه یک بار تنظیم کردهایم، بنابراین تابع closure هر 30 دقیقه یک بار اجرا میشود. در مثال فوق ما تعداد نوشتههای هر کاربر را شمارش کرده و جدول آمار را بر همین اساس بهروزرسانی میکنیم.
دستور Artisan
علاوه بر closure-ها یا callable-ها میتوانید یک دستور artisan را نیز طوری زمانبندی کنید که در بازههای معینی اجرا شود. در واقع این دستور باید رویکرد ترجیحی نسبت به closure-ها باشد، زیرا بهینهسازی کد بیشتری دارد و همزمان به افزایش قابلیت استفاده مجدد از کد نیز منتهی میشود.
بدین ترتیب در ادامه به بررسی محتوای فایل app/Console/Kernel.php با کد زیر میپردازیم:
این همان متد command است که میتوانید به صورت یک دستور artisan چنان که در کد فوق میبینید مورد استفاده قرار دهید. در این مورد باید امضای دستور artisan را به عنوان آرگومان نخست متد command ارسال کنید. البته باید دستور artisan متناظر را نیز در فایل app/Console/Commands/UserStatistics.php تعریف کنید:
دستور Exec
میتوان گفت متدهایی که تا به اینجا برسی کردیم مختص خود اپلیکیشن لاراول بودند. علاوه بر اینها لاراول میتواند دستورهای shell را نیز که در خارج از اپلیکیشن اجرا میشوند زمانبندی کند. در ادامه مثال سادهای از این وضعیت را میبینید که روش پشتیبانگیری از پایگاه داده به صورت روزانه را نمایش میدهد:
از کد فوق مشخص است که باید از متد exec ابزار زمانبندی استفاده کنید و باید دستوری را که میخواهید اجرا شود به عنوان آرگومان نخست ارسال کنید. علاوه بر آن ما باید از متد sendOutputTo نیز استفاده کنیم که امکان گردآوری خروجی دستور را به ما میدهد. از سوی دیگر متدی به نام emailOutputTo نیز وجود دارد که محتوای خروجی را به یک آدرس تعیین شده ایمیل میکند. بدین ترتیب به پایان این مقاله میرسیم. در حقیقت در این نوشته ما تنها گوشه کوچکی از API زمانبندی لاراول را مورد بررسی قرار دادیم و موارد بسیار دیگری هستند که باید مورد بررسی قرار گیرند.
سخن پایانی
در این مقاله به بررسی API زمانبندی فریمورک وب لاراول پرداختیم. مشاهده میزان سادگی مدیریت وظایفی که قرار است به صورت دورهای اجرا شوند بسیار جذاب است. در ابتدای مقاله به بررسی روش سنتی راهاندازی وظایف زمانبندی پرداختیم و در ادامه روش لاراول برای انجام این کار را معرفی کردیم. در نیمه دوم مقاله نیز چندین مثال عملی برای نمایش مفاهیم زمانبندی وظیفه ارائه کردیم. امیدواریم از این نوشته بهره برده باید و اینک اعتمادبهنفس بیشتری در خصوص راهاندازی وظایف زمانبندیشده در لاراول داشته باشید.
اگر این مطلب برای شما مفید بوده است، آموزشهای زیر نیز به شما پیشنهاد میشوند:
- مجموعه آموزش های برنامه نویسی PHP
- آموزش REST API در Laravel (لاراول) با بسته Passport
- مجموعه آموزشهای برنامهنویسی
- آموزش تحلیل یک سیستم فروشگاهی در فریمورک لاراول (Laravel)
- آموزش پیاده سازی سیستم Logging در فریمورک لاراول (Laravel)
- برنامهنویسی PHP و هر آنچه برای شروع باید بدانید — آموزش جامع
- بهینه سازی عملکرد اپلیکیشنهای PHP — به زبان ساده
==