הסבר על רוחב פס נמוך וזמן אחזור גבוה

חשוב להבין איך משתמשים באפליקציה או באתר כשהחיבור גרוע או לא מהימן, ולפתח בהתאם. יש מגוון כלים שיעזרו לכם.

הערך של היחס של אנשים שמשתמשים באינטרנט במכשירים ניידים הולך וגדל. גם בבית, אנשים רבים מוותרים על חיבור פס רחב קבוע ומעדיפים חיבור נייד.

בהקשר הזה, חשוב להבין איך נראה השימוש באפליקציה או באתר כשהקישוריות חלשה או לא מהימנה. יש מגוון כלים תוכנתיים שיכולים לעזור לכם להדמיה ולסימולציה של רוחב פס נמוך וזמן אחזור ארוך.

כשאתם יוצרים או מעדכנים אתר, אתם צריכים לוודא שהוא יספק ביצועים טובים במגוון תנאי קישוריות. יש כמה כלים שיכולים לעזור.

כלים בדפדפן

כלים למפתחים ב-Chrome מאפשרים לבדוק את האתר במגוון מהירויות העלאה/הורדה וזמני נסיעה הלוך ושוב, באמצעות הגדרות מוגדרות מראש או הגדרות בהתאמה אישית בחלונית 'רשת'. במאמר תחילת העבודה עם ניתוח ביצועי הרשת מוסבר על העקרונות הבסיסיים.

ויסות נתונים (throttle) בכלי הפיתוח ל-Chrome

כלי מערכת

Network Link Conditioner הוא חלונית העדפות שזמינה ב-Mac אם מתקינים את Hardware IO Tools ל-Xcode:

לוח הבקרה של Network Link Conditioner ב-Mac

ההגדרות של Network Link Conditioner ב-Mac

הגדרות מותאמות אישית של Mac Network Link Conditioner

אמולציה של מכשיר

Android Emulator מאפשר לכם לדמות תנאי רשת שונים בזמן הפעלת אפליקציות (כולל דפדפני אינטרנט ואפליקציות אינטרנט היברידיות) ב-Android:

אמולטור Android

הגדרות של Android Emulator

ב-iPhone, אפשר להשתמש ב-Network Link Conditioner כדי לדמות תנאי רשת פגומים (ראו למעלה).

בדיקה ממיקומים ורשתות שונים

ביצועי הקישוריות תלויים במיקום השרת ובסוג הרשת.

WebPagetest הוא שירות אונליין שמאפשר להריץ קבוצה של בדיקות ביצועים באתר באמצעות מגוון רשתות ומיקומי אירוח. לדוגמה, אפשר לנסות את האתר משרת בהודו ברשת 2G, או דרך חיבור קווי מעיר בארה"ב.

הגדרות WebPagetest

בוחרים מיקום ובוחרים סוג חיבור מההגדרות המתקדמות. אפשר גם לבצע אוטומציה של הבדיקות באמצעות סקריפטים (לדוגמה, כדי להתחבר לאתר) או באמצעות ממשקי ה-API מסוג RESTful שלהם. כך תוכלו לכלול בדיקות קישוריות בתהליכי build או ברישום ביומן ביצועים.

Fiddler תומך בשרת proxy גלובלי דרך GeoEdge, וניתן להשתמש בכללים המותאמים אישית שלו כדי לדמות מהירויות של מודם:

שרת proxy של Fiddler

בדיקה ברשת עם בעיות

שרתים proxy של תוכנה וחומרה מאפשרים לדמות תנאים בעייתיים ברשתות סלולריות, כמו הגבלת רוחב פס, עיכוב בחבילות ואובדן מנות אקראי. שרת proxy משותף או רשת עם פגיעה יכולים לאפשר לצוות מפתחים לשלב בדיקות רשת בעולם האמיתי בתהליך העבודה שלהם.

Augmented Traffic Control (ATC) של Facebook היא קבוצה של אפליקציות ברישיון BSD שאפשר להשתמש בהן כדי לעצב את תעבורת הנתונים ולדמות תנאי רשת פגומים:

בקרת התנועה המשופרת של Facebook

Facebook אפילו הגדירה ימי שלישי 2G כדי לעזור להבין איך אנשים עם חיבור 2G משתמשים במוצר שלה. בימי שלישי, העובדים מקבלים חלון קופץ עם אפשרות לדמות חיבור 2G.

אפשר להשתמש בשרת ה-proxy מסוג HTTP/HTTPS של Charles כדי לשנות את רוחב הפס ואת זמן האחזור. Charles היא תוכנה מסחרית, אבל יש לה תקופת ניסיון בחינם.

הגדרות רוחב הפס וזמן האחזור של שרת ה-proxy של Charles

מידע נוסף על Charles זמין בכתובת codewithchris.com.

טיפול בחיבור לא מהימן וב-'lie-fi'

מהו lie-fi?

המונח lie-fi מתייחס לקישוריות שלא כפי שהיא נראית. המונח הזה נמצא בשימוש לפחות משנת 2008 (כשטלפונים נראו ככה). הדפדפן פועל כאילו יש לו קישוריות, אבל למעשה אין לו קישוריות מסיבה כלשהי.

פרשנות שגויה של קישוריות עלולה לגרום לחוויית משתמש גרועה, כי הדפדפן (או JavaScript) ימשיך לנסות לאחזר משאבים במקום לוותר ולבחור חלופה סבירה. חיבור Lie-fi יכול להיות אפילו גרוע יותר מחיבור אופליין. לפחות אם המכשיר נמצא ב-offline, אפשר לבצע פעולות מתאימות כדי להימנע משימוש ב-JavaScript.

סביר להניח ש-lie-fi יהפוך לבעיה גדולה יותר ככל שיותר אנשים יעבור לרשתות סלולריות ויפסיקו להשתמש בחיבור פס רחב קבוע. נתוני מפקד האוכלוסין האחרון בארה"ב מראים מעבר מאינטרנט פס רחב קבוע. בתרשים הבא מוצג השימוש באינטרנט בנייד בבית בשנת 2015 בהשוואה לשנת 2013:

תרשים מנתוני מפקד האוכלוסין בארה"ב שמראה את המעבר לשימוש בניידים במקום באינטרנט פס רחב קבוע, במיוחד במשקי בית עם הכנסה נמוכה יותר

שימוש בזמני תפוגה לטיפול בקישוריות לסירוגין

בעבר, שיטות 'פרימיטיביות' באמצעות XHR שימשו לבדיקת קישוריות לסירוגין, אבל קובץ שירות מאפשר להשתמש בשיטות מהימנות יותר להגדרת זמן קצוב לתפוגה של התחברות לרשת. אפשר לעשות זאת באמצעות Workbox עם כמה שורות קוד בלבד:

workboxSW.router.registerRoute(
 
'/path/to/image',
  workboxSW
.strategies.networkFirst({networkTimeoutSeconds: 3}),
);

מידע נוסף על Workbox זמין בהרצאה של Jeff Posnick בכנס Chrome Dev Summit,‏ Workbox: Flexible PWA Libraries.

אנחנו גם מפתחים פונקציונליות של זמן קצוב ל-Fetch API, ו-Streams API אמור לעזור לכם לבצע אופטימיזציה של העברת התוכן ולהימנע מבקשות מונוליטיות. בפוסט שיפור טעינת הדפים, ג'ייק ארקיבל (Jake Archibald) מספק פרטים נוספים על טיפול בבעיות של חיבור לאינטרנט איטי.

משוב