محمدتقی نقیبی
محمدتقی نقیبی
خواندن ۳ دقیقه·۲ سال پیش

مدیریت خطا در زمان ارسال کار به صف در لاراول

مقدمه

ارسال کار به صف‌، یک امکان قدرتمند در لاراول برای اجرای فرآیندهای طولانی و زمان‌بر در پس‌زمینه است. با استفاده از صف‌ها، می‌توانیم وظایفی که زمان زیادی برای اجرا نیاز دارند را به صورت غیرهمزمان در پس زمینه پردازش کنیم. با این حال، ممکن است در برخی مواقع، اتصال به زیرساخت صف با مشکل مواجه شود و منجر به عدم توانایی در پردازش و اجرای کارها شود.در این مقاله، به بررسی مسئله مدیریت خطاهای ارسال کار به صف‌های لاراول می‌پردازیم و راهکاری را برای مدیریت این نوع خطاها ارائه می‌کنیم.

مسئله

هنگامی که لاراول یک کار را به صف ارسال می‌کند، از اجزای زیرساختی مانند بروکر، پایگاه داده یا ردیس برای مدیریت و اجرای صف استفاده می‌کند. این اجزا ممکن است با مشکلاتی مانند عدم فعالیت، ناموجودی یا خطا در اتصال روبرو شوند. در چنین مواردی، ضروری است که خطاها به شکل موثری مدیریت شوند تا از از دست رفتن کارها جلوگیری شود و سازگاری سیستم حفظ شود.

انتشار خطا و تأثیر بر کاربر

به طور پیش‌فرض، لاراول خطاهایی که در هنگام ارسال کار به صف به‌وجود می‌آیند را به کاربر ارجاع می‌دهد و این می‌تواند منجر به نقض‌ها و تأثیراتی بر تجربه کاربری شود. به عنوان مثال فرض کنید کاربر در سیستم ثبت نام کرده و برای فعال شدن حساب کاربری اش باید بر روی لینک فعال سازی ارسالی به ایمیلش کلیک کند. سیستم ما ارسال ایمیل که یک کار زمانبر است را از طریق صف ردیس مدیریت می کند ولی متاسفانه در زمان ارسال کار به صف اتصال ردیس برقرار نشده و خطایی رخ داده است که موجب قطع شدن جریان برنامه می‌شود. برای کنترل این موضوع، می توان خطا را catch کرد ولی کاری که باید انجام می شد یعنی ارسال ایمیل فعال سازی از دست می رود. در این شرایط، برخی سیستم‌ها وظیفه را به کاربر واگذار می‌کنند و با ارائه امکان ارسال مجدد لینک فعال‌سازی، به این مشکل پاسخ می‌دهند. با این حال، آیا بهتر نیست که سیستم خود، از انعطاف و پویایی برخوردار باشد و کاربر را درگیر نکند؟

ثبت کارهای ناموفق

لاراول یک مکانیزم داخلی برای مدیریت و ثبت کارهای ناموفق در جدولی به نام "failed_jobs" فراهم کرده است. هنگامی که اجرای یک کار با خطا روبرو می‌شود، رفتار پیش‌فرض لاراول این است که خطا را لاگ کرده و payload کار را در جدول "failed_jobs" ذخیره می‌کند. این عملکرد به ما این امکان را می‌دهد که در آینده، کارهای ناموفق را بررسی، اشکال‌زدایی و مجدداً پردازش کنیم. این ویژگی بسیار مفید است، اما فقط برای کارهایی که در صف قرار دارند و با خطا مواجه می‌شوند مورد استفاده قرار می‌گیرد. اگر می‌توانستیم کارهایی که در زمان ارسال به صف با خطا مواجه می‌شوند را هم در این صف ذخیره کنیم، به هدف مهمی که پیگیری می‌کنیم می‌رسیدیم.

راه حل

در قطعه کد زیر می بینیم که خطای رخ داده در زمان dispatch شدن کار به همراه payload و یکسری جزئیات در جدول "failed_jobs" ذخیره می شود و در آینده می توانیم با دستور queue:retry مجدد آن را اجرا کنیم.


مدیریت خطا  در زمان ارسال جاب به صف
مدیریت خطا در زمان ارسال جاب به صف


برای سهولت در اعمال این موضوع، می‌توانید این قطعه کد را در یک trait همانند Dispatchable قرار داده و استفاده کنید. همچنین، پکیجی که در این زمینه آماده شده رو هم می توانید استفاده کنید.

نتیجه گیری

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


امیدوارم براتون مفید بوده باشه

پیروز باشید...



لاراولصفlaraveljob
بدون تلاش هیچی به دست نمیاد و همیشه خاطرم میمونه برای بدست آوردن چیزی که نیاز به زمان داره باید صبر کنم.
شاید از این پست‌ها خوشتان بیاید