یک ابزار ماژولار جدید که امکان جمع آوری خودکار داده های عملکرد از چندین منبع را فراهم می کند.
AutoWebPerf (AWP) چیست؟
AutoWebPerf (AWP) یک ابزار مدولار است که امکان جمع آوری خودکار داده های عملکرد از چندین منبع را فراهم می کند. در حال حاضر ابزارهای زیادی برای اندازهگیری عملکرد وبسایت برای حوزههای مختلف ( آزمایشگاهی و میدانی ) موجود است، مانند گزارش Chrome UX، PageSpeed Insights، یا WebPageTest. AWP یکپارچه سازی با ابزارهای مختلف ممیزی را با یک راه اندازی ساده ارائه می دهد تا بتوانید به طور مداوم عملکرد سایت را در یک مکان نظارت کنید.
انتشار راهنمای Web Vitals به این معنی است که نظارت دقیق و فعال بر صفحات وب اهمیت فزاینده ای پیدا می کند. مهندسان پشت این ابزار سالها ممیزی عملکرد انجام میدهند و AWP را برای خودکارسازی بخشی از فعالیتهای روزانه، تکراری و زمانبر ایجاد کردند. امروزه AWP به سطحی از بلوغ رسیده است و آماده به اشتراک گذاری گسترده است تا هرکسی بتواند از اتوماسیونی که به ارمغان می آورد بهره مند شود.
این ابزار در مخزن عمومی AutoWebPerf در GitHub قابل دسترسی است.
AWP برای چیست؟
اگرچه چندین ابزار و API برای نظارت بر عملکرد صفحات وب در دسترس است، اکثر آنها داده های اندازه گیری شده را در یک زمان خاص در معرض دید قرار می دهند. برای نظارت کافی بر یک وب سایت و حفظ عملکرد خوب صفحات کلیدی، توصیه می شود به طور مداوم Core Web Vitals را در طول زمان اندازه گیری کنید و روندها را مشاهده کنید.
AWP با ارائه موتور و ادغام های API از پیش ساخته شده که می تواند به صورت برنامه نویسی برای خودکارسازی پرس و جوهای مکرر به API های نظارت بر عملکرد مختلف پیکربندی شود، این کار را آسان تر می کند.
به عنوان مثال، با AWP، میتوانید یک آزمایش روزانه در صفحه اصلی خود تنظیم کنید تا دادههای میدانی از CrUX API و دادههای آزمایشگاهی از گزارش Lighthouse از PageSpeed Insights گرفته شود. این دادهها را میتوان در طول زمان نوشت و ذخیره کرد، به عنوان مثال، در Google Sheets و سپس در داشبورد استودیوی داده تجسم کرد. AWP بخش سنگین کردن کل فرآیند را خودکار می کند و آن را به یک راه حل عالی برای پیگیری روندهای آزمایشگاهی و میدانی در طول زمان تبدیل می کند. برای جزئیات بیشتر به تجسم نتایج حسابرسی در Data Studio در زیر مراجعه کنید).
نمای کلی معماری
AWP یک کتابخانه مبتنی بر مدولار با سه نوع مختلف ماژول است:
- موتور
- ماژول های رابط
- ماژول های جمع کننده
موتور فهرستی از آزمایشها را از یک رابط (مثلاً از یک فایل CSV محلی) میگیرد، ممیزیهای عملکرد را از طریق جمعآورندههای انتخاب شده (مانند PageSpeed Insights) اجرا میکند و نتایج را در رابط خروجی مینویسد (مثلاً Google Sheets).
AWP با تعدادی جمع کننده و کانکتور از پیش پیاده سازی شده ارائه می شود:
- جمع کننده های از پیش اجرا شده:
- کانکتورهای از پیش پیاده سازی شده:
- Google Sheets
- JSON
- CSV
ممیزی خودکار با AWP
AWP ممیزی های عملکرد را از طریق پلتفرم های ممیزی ترجیحی شما مانند PageSpeed Insights ، WebPageTest یا CrUX API خودکار می کند. AWP انعطاف پذیری را برای انتخاب مکان بارگیری لیست تست ها و مکان نوشتن نتایج ارائه می دهد.
برای مثال، میتوانید ممیزیها را برای فهرستی از آزمایشهای ذخیرهشده در Google Sheet اجرا کنید و نتایج را با دستور زیر در یک فایل CSV بنویسید:
PSI_APIKEY=<YOUR_KEY> SHEETS_APIKEY=<YOUR_KEY> ./awp run sheets:<SheetID> csv:output.csv
ممیزی های مکرر
می توانید ممیزی های مکرر را به صورت روزانه، هفتگی یا ماهانه اجرا کنید. برای مثال، میتوانید ممیزیهای روزانه را برای فهرستی از آزمایشهای تعریفشده در JSON محلی مانند زیر اجرا کنید:
{
"tests": [
{
"label": "web.dev",
"url": "https://web.dev",
"gatherer": "psi"
}
]
}
دستور زیر لیست تست های ممیزی را از فایل JSON محلی می خواند، ممیزی ها را روی یک ماشین محلی اجرا می کند، سپس نتایج را به یک فایل CSV محلی خروجی می دهد:
PSI_APIKEY=<YOUR_KEY> ./awp run json:tests.json csv:output.csv
برای اجرای ممیزی هر روز به عنوان یک سرویس پس زمینه به طور مداوم، می توانید به جای آن از دستور زیر استفاده کنید:
PSI_APIKEY=<YOUR_KEY> ./awp continue json:tests.json csv:output.csv
از طرف دیگر، میتوانید crontab را در محیطی شبیه به یونیکس راهاندازی کنید تا AWP را بهعنوان یک کار روزانه cron اجرا کنید:
0 0 * * * PSI_APIKEY=<YOUR_KEY> ./awp run json:tests.json csv:output.csv
میتوانید راههای بیشتری برای خودکارسازی ممیزیهای روزانه و جمعآوری نتایج در مخزن AWP GitHub پیدا کنید.
تجسم نتایج حسابرسی در Data Studio
همراه با اندازهگیری مداوم Core Web Vitals، مهم است که بتوانیم روندها را ارزیابی کنیم و رگرسیونهای احتمالی را با معیارهای کاربر واقعی (RUM) یا گزارش Chrome UX (CrUX) جمعآوریشده توسط AWP کشف کنیم. توجه داشته باشید که Chrome UX Report (CrUX) یک مجموعه متحرک 28 روزه است، بنابراین توصیه میشود از دادههای RUM خود همراه با CrUX نیز استفاده کنید تا بتوانید رگرسیونها را زودتر تشخیص دهید.
Data Studio یک ابزار تجسم رایگان است که می توانید به راحتی معیارهای عملکرد را در آن بارگیری کنید و روندها را به عنوان نمودار ترسیم کنید. برای مثال، نمودارهای سری زمانی زیر Core Web Vitals را بر اساس دادههای گزارش Chrome UX نشان میدهند. یکی از نمودارها افزایش تغییر چیدمان تجمعی را در هفتههای اخیر نشان میدهد که به معنای رگرسیون در پایداری چیدمان برای صفحات خاص است. در این سناریو، میخواهید تلاشها برای تجزیه و تحلیل مسائل اساسی این صفحات را در اولویت قرار دهید.
برای سادهسازی فرآیند انتها به انتها از جمعآوری دادهها تا تجسم، میتوانید AWP را با فهرستی از URLها اجرا کنید تا بهطور خودکار نتایج را با دستور زیر به Google Sheets صادر کنید:
PSI_APIKEY=<YOUR_KEY> SHEETS_APIKEY=<YOUR_KEY> ./awp run sheets:<SheetID> csv:output.csv
پس از جمعآوری معیارهای روزانه در یک صفحهگسترده، میتوانید یک داشبورد Data Studio ایجاد کنید که دادهها را مستقیماً از صفحهگسترده بارگیری میکند و روندها را در نمودار سری زمانی ترسیم میکند. برای گامهای دقیق در مورد نحوه راهاندازی AWP با صفحات گسترده بهعنوان منبع داده برای تجسم در Data Studio ، رابط Google Spreadsheets API را بررسی کنید.
بعدش چی؟
AWP یک راه ساده و یکپارچه برای به حداقل رساندن تلاشها برای راهاندازی یک خط لوله نظارت مستمر برای اندازهگیری Core Web Vitals و سایر معیارهای عملکرد ارائه میکند. در حال حاضر، AWP رایجترین موارد استفاده را پوشش میدهد و به ارائه ویژگیهای بیشتری برای رسیدگی به موارد استفاده دیگر در آینده ادامه خواهد داد.
در مخزن AutoWebPerf بیشتر بیاموزید.