مانیتورینگ اپلیکیشن لاراول با Scout APM
ﺯﻣﺎﻥ ﻣﻄﺎﻟﻌﻪ: 9 دقیقه

مانیتورینگ اپلیکیشن لاراول با Scout APM

در این مقاله از راکت به معرفی یک ابزار مانیتورینگ برای اپلیکیشن ‌های لاراول شما می‌پردازیم.خوشحالیم که در Scout APM پیشتیبانی خود را از برنامه‌های لاراول آغاز می‌کنیم. ما سالهاست که به مانیتورینگ هزاران اپ روبی و پایتون و الکسیر پرداخته‌ایم و از آوردن ابزارهای جدید در جامعه توسعه‌دهندگان بسیار هیجان‌زده هستیم. در اینجا یک نمای کلی از نصب و اجرای  Scout برای شما آورده‌ایم:

نصب

قبل از هر چیز ، برای شروع مانیتورینگ اپلیکیشن لاراول خود نیاز به یک حساب کاربری Scout دارید. اگر از قبل اکانت ندارید می‌توانید برای یک دوره ۱۴ روزه آزمایشی به صورت رایگان( و بدون نیاز به کارت اعتباری) در اینجا ثبت نام کنید.

مورد بعدی اینکه باید یک عامل نظارتی مانیتورینگ را به dependency های پروژه خود اضافه کنید، که این کار را می‌توان با یک دستور در shell انجام داد.

composer require scoutapp/scout-apm-laravel

این دستور دو پکیج را نصب می‌کند: scout-apm-laravel و scout-apm-php.

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

SCOUT_MONITOR=true
SCOUT_KEY=”enter your Agent Key here”
SCOUT_NAME=”enter the name of you application here”

می‌توانید Agent Key حساب خود را در صفحه تنظیمات Scout پیدا کنید.

و همین! تقریباً پس از ۵ دقیقه داده‌های شما در Scout ظاهر می‌شوند. برای کسب اطلاعات بیشتر درباره نصب Heroku یا عیب‌یابی مشکلات نصب، یا نگاهی به داکیومنت بیندازید و یا از طریق ایمیل [email protected] با ما تماس بگیرید، خوشحال می‌شویم که به شما کمک کنیم.

از کجا شروع کنیم؟

خب شما یک حساب Scout ایجاد کرده‌اید و عامل نظارت را هم درست کرده‌اید، اما از کجا تشخیص مشکلات عمل‌کرد برنامه‌خود را شروع می‌کنید؟ بیایید نگاهی به ویژگی‌های اصلی Scout بیندازیم که به درک سریع مشکلات پرفرمانس شما کمک خواهد کرد.

صفحه مرور اصلی

اولین صفحه‌ای که هنگام ورود به Scout مشاهده خواهید کرد، صفحه نمای کلی ( عکس زیر) است که با یک نگاه سریع و بدون سر و صدا می‌توانید از سلامت عمل‌کرد برنامه خود مطمئن شوید.

مانیتورینگ اپلیکیشن لاراول با Scout APM

نمودار بسیار قابل تنظیم است و به شما امکان تغییر دورهای زمانی و همچنین معیارهایی که می‌خواهید ببینید را خواهد داد. همچنین این برنامه به یک ابزار درگ-اند-دراپ ( که در زیر نشان داده شده) مجهز است که به شما ازادای بیشتری خواهد داد. یک پنجره pop-up که به صورت داینامیک بارگیری می‌شود و تمام نقاط انتهایی که در این بازه زمانی به آن‌ها دسترسی داشته‌اید را نشان می‌دهد. این ویژگی می‌تواند زمانی مفید باشد که میزان عمل‌کرد خود را در نمودار مشاهده کنید و بخواهید ببینید چه چیزی باعث ایجاد آن شده است.

 مانیتورینگ اپلیکیشن لاراول با Scout APM 

تب‌های Insights

اگر برای اولین بار است که Scout را امتحان می‌کنید، تب‌های insights مکانی عالی برای شروع است. در این‌جا ما از مجموعه‌ای از الگوریتم‌ها را داریم که پروژه شما را برای کوئری‌های n+1 و کوئری‌هایی که سرعت پایین دارند، ‌تجزیه و تحلیل می‌کند. همچنین “low-hanging fruit” را برای اصلاح عمل‌کرد به شما ارائه می‌دهد که اغلب می‌توانند بلافاصله عمل‌کرد برنامه شما را بهبود ببخشند.

 مانیتورینگ اپلیکیشن لاراول با Scout APM 

Endpoint ها و Traceها

Scout اصولاً معیارهای عمل‌کرد برنامه‌ را در دو سطح ارائه می‌دهد. اول از همه از دیدگاه یک Endpoint. به عنوان مثال، این Endpoint چقدر طول می‌کشد تا دسترسی پیدا کند و تفکیک اینکه در کجا این زمان استفاده شده.

اگر به تصویر زیر نگاهی بیندازید، به وضوح می‌بینید که در ۳ موردی که ForgetPasswordController endpoint به ۷۸٪ از ۲۳۷۱ میلی ثانیه دسترسی پیدا کرده و به این معنی است که زمان ریکوئست در این لایه کنترلر صرف شده که نشان می‌دهد اگر می‌خواهیم برای بهبود این endpoint کند تلاش کنیم، اینجا اولین جایی است که باید بررسی شود.

مانیتورینگ اپلیکیشن لاراول با Scout APM

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

این مورد ۹۸ ٪ از زمان را در لایه SQL گذرانده و بیشتر این زمان را در همان ۲ call به کوئری در خط بالا صرف کرده است. اگر روی دکمه SQL کلیک کنیم، می‌توانیم یک backtrace ببینیم و ببینیم که آیا می‌توانی این کوئری را بهبود ببخشیم یا نه.

مانیتورینگ اپلیکیشن لاراول با Scout APM

این صفحات جایی هستند که شما بیشترین وقت خود را روی آن خواهید گذاشت و به شما دیدی را خواهد داد که در هنگام تلاش برای درک مسائل پرفرمانس و عمل‌کرد ضروری است. همچین می‌توانید مستقیماً از صفحه‌ی نمای اصلی و insights tab ها و یا با کیلیک روی لینک Web Endpoints که در بالای صفحه است، ‌به صفحات Endpoint و Trace دسترسی پیدا کنید. ( در زیر نشان داده شده است).

مانیتورینگ اپلیکیشن لاراول با Scout APM

فراتر از اصول اولیه

اکنون که اصول Scout را بیان کردیم و زمینه‌های اصلی سیستمی را که معمولاً هر روز استفاده می‌کنید را به شما نشان دادیم، اکنون توجه شما را به برخی از ویژگی‌های پیشرفته‌تر که Scout را در بالای فضای AMP و جلوتر از همه قرار می‌دهد،‌ جلب می‌کنم.

مانیتورینگ خطا (نظارت بر خطا)

اینکه آیا از Sentry،Honeybadger، Bugsnag یا Rollbar برای مانیتورینگ خطای خود استفاده می‌کنید مهم نیست چرا که ما شما را تحت پوشش خود قرار می‌دهیم!

Scout به طور پکپارچه با سرویس‌های محبوب ادغام می‌شود و به شما این اماکن را می‌دهد که تمام مانیتورینگ خود را در یک مکان، در صفحه نمای اصلی داشته باشید.

مانیتورینگ اپلیکیشن لاراول با Scout APM

فرایند نصب بدون توجه به اینکه از کدام یک از این سرویس‌ها استفاده می‌کنید، مشابه است و تمام آن مستلزم وارد کردن رمز API در صفحه تنظیمات Scout  است.

Custom Context و Trace Explorer

چرا این مسأله مشکل پرفرمانسی فقط در ساعت ۲ بامداد از طریق IP برزیل اتفاق می‌افتد؟ این نوع مشکلات دشوار ( اما معمول) عمل‌کردی را می‌توان با یکی از قدرتمندترین ویژگی‌های Scout بررسی کرد: trace explorer در conjunction با تعریف custom context توسط کاربر استفاده می‌شود.

 custom context تعریف شده به شما اجازه می‌دهد که آنچه را نیاز دارید ببینید را به ما بگویید. و ارزش آن را دارد که مدت زمان نسبتاً کمی را برای راه‌اندازی آن بگذارید و یک مانیتورینگ فوق‌العاده قدرتمند داشته باشید! به طور پیش‌فرض، تنها فیلدهای context ای که شما مشاهده می‌کنید URL و Hostname هستند همانطور که در زیر می‌بینید؛ اما این موارد را می‌توان برای هر چیزی که شما می‌خواهید تنظیم کرد.

مانیتورینگ اپلیکیشن لاراول با Scout APM

فیلترهای چندگانه trace explorer (دربالا نشان داده شده) به شما این امکان را می‌دهد که endpoint هایی متناسب با معیارهایی که تعریف کرده‌اید را بررسی کنید و سپس می‌توانید تمام trace هایی را که با این فیلترها مطابقت دارند در قسمت Transaction Traces مشاهده کنید. به عنوان مثال، ‌شاید بخواهید درخواستهای یه کاربر خاص یا همه‌ی کاربران را در یک قسمت خاص جهان مشاهده کنید. انجام این نوع کارها با trace explorer به راحتی در custom context انجام می‌شود و به شما کمک می‌کند تا به زیر و بم مشکلاب پرفرمانسی زمان‌بر برسید.

Deploy tracking

تا به حال شده ناگهان یک مشکل پرفرمانسی بعد از آخرین Deploy برایتان پیش آمده باشد؟ در حال Deploy چطور؟ این حال سؤالاتی هستند که با ویژگی deploy tracking ما پاسخ داده می‌شوند، که یک نماد مشکل را در نمودار نمای اصلی قرار می‌دهد تا زمان توسعه یا deployment را نشان دهد.

مانیتورینگ اپلیکیشن لاراول با Scout APM

Deploy tracking همچنین این اجازه را به شما می‌دهد تا جزئیاتی از قبیل تعداد commit هایی که در deploy ما درگیر شدند. ما می‌توانیم همه‌ی این اطلاعات را زمان اضافه کردن SHA یا در دیپلوی در  environmental variable در SCOUT_REVISON_SHA جمع‌آوری کنیم.

هشدار

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

مانیتورینگ اپلیکیشن لاراول با Scout APM

به طور پیش فرض، سیستم هشدار، نوتیفیکیشن‌ها را از طریق ایمیل برای کاربران ارسال می‌کند، اما می‌تواند برای کار با سرویس‌های third-party همچون Slack،VictorOps،PagerDuty و … با ویژگیwebhook ما پیکربندی شود.

ابزارهای سفارشی

آیا شما از کتابخانه‌هایی خارج از لاراول استفاده می‌کنید که ما درحال حاضر از آن‌ها استفاده نمی کنیم؟ کافیست به تیم پشتیبانی ما اطلاع دهید و ما سعی می‌کنیم که آن را برای شما اضافه کنیم.

و در نهایت …

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

امیدورام این مقاله برای شما مفید بوده باشد. از وقتی که گذاشتید سپاس‌گذارم.

منبع

چه امتیازی برای این مقاله میدهید؟

خیلی بد
بد
متوسط
خوب
عالی
3 از 1 رای

/@Fatemeh.shirzadfar
فاطمه شیرزادفر
برنامه نویس

تجربه کلمه‌ای هست که همه برای توصیف اشتباهاتشون ازش استفاده میکنن، و من همیشه دنبال اشتباهات جدیدم! برنامه‌نویس هستم و لینوکس‌ دوست

دیدگاه و پرسش

برای ارسال دیدگاه لازم است وارد شده یا ثبت‌نام کنید ورود یا ثبت‌نام

در حال دریافت نظرات از سرور، لطفا منتظر بمانید

در حال دریافت نظرات از سرور، لطفا منتظر بمانید