ב-Firebase מחייבים על הנתונים שאתם מאחסנים במסד הנתונים ועל כל תעבורת הנתונים היוצאת ברשת בשכבת הסשן (שכבה 5) של מודל OSI. החיוב על האחסון הוא 5$ לכל GB לחודש, והוא מחושב מדי יום. המיקום של מסד הנתונים לא משפיע על החיוב. תעבורת נתונים יוצאת כוללת את התקורה של ההתחברות וההצפנה מכל פעולות מסד הנתונים והנתונים שהורדתם באמצעות קריאות למסד הנתונים. גם קריאות וגם כתוביות של מסדי נתונים יכולות להוביל לעלויות חיבור בחשבונית. כל התנועה אל מסד הנתונים וממנו, כולל פעולות שנדחו על ידי כללי האבטחה, גורמת לעלויות לחיוב.
דוגמאות נפוצות לתנועה שעבורה מתבצעת חיוב:
- נתונים שהורדתם: כשלקוחות מקבלים נתונים ממסד הנתונים שלכם, Firebase מחייבת על הנתונים שהורדתם. בדרך כלל, הנתונים האלה מהווים את עיקר העלויות של רוחב הפס, אבל הם לא הגורם היחיד בחשבונית.
- עומס יתר של פרוטוקול: כדי ליצור סשן ולתחזק אותו, נדרשת תנועה נוספת מסוימת בין השרת ללקוחות. בהתאם לפרוטוקול הבסיסי, התנועה הזו עשויה לכלול: תקורה של פרוטוקול בזמן אמת של Firebase Realtime Database, תקורה של WebSocket ותקורה של כותרת HTTP. בכל פעם שנוצר חיבור, העלויות האלה, בשילוב עם עלויות הצפנת ה-SSL, מוסיפות לעלות החיבור. זהו רוחב פס לא גדול לבקשה אחת, אבל הוא יכול להוות חלק משמעותי מהחשבון אם עומסי התעבורה קטנים או אם אתם יוצרים חיבורים קצרים ותדירים.
- העלות הנוספת של הצפנת SSL: יש עלות שקשורה להעלות הנוספת של הצפנת SSL שנדרשת לחיבורים מאובטחים. העלות הממוצעת היא כ-3.5KB לחיצת היד הראשונית וכעשרות בייטים לכותרות של רשומות TLS בכל הודעה יוצאת. ברוב האפליקציות, זהו אחוז קטן מהחשבון. עם זאת, אם במקרה הספציפי שלכם נדרשים הרבה לחיצות יד של SSL, הזמן הזה יכול לגדול. לדוגמה, במכשירים שלא תומכים בכרטיסי סשן של TLS יכול להיות שיהיה צורך במספר גדול של לחיצות יד לחיבור SSL.
- נתוני מסוף Firebase: בדרך כלל, הנתונים האלה לא מהווים חלק משמעותי מהעלויות של Realtime Database, אבל Firebase מחייבת על נתונים שאתם קוראים ומזינים במסוף Firebase.
אומדן השימוש לחיוב
כדי לראות את החיבורים הנוכחיים ל-Realtime Database ואת השימוש בנתונים, אפשר לעיין בכרטיסייה Usage במסוף Firebase. אפשר לבדוק את השימוש בתקופה הנוכחית לחיוב, ב-30 הימים האחרונים או ב-24 השעות האחרונות.
ב-Firebase מוצגים נתונים סטטיסטיים לגבי השימוש במדדים הבאים:
- חיבורים: מספר החיבורים בו-זמנית שנפתחים בזמן אמת למסד הנתונים. הנתונים האלה כוללים את החיבורים הבאים בזמן אמת: WebSocket, Long Polling ואירועים שנשלחים מהשרת ב-HTML. הוא לא כולל בקשות RESTful.
- אחסון: כמות הנתונים שמאוחסנים במסד הנתונים. הנתונים האלה לא כוללים אירוח ב-Firebase או נתונים שמאוחסנים דרך מוצרים אחרים של Firebase.
- הורדות: כל הבייטים שהורדתם ממסד הנתונים, כולל תקורה של פרוטוקול והצפנה.
- עומס: בתרשים הזה מוצגת כמות הנתונים שנעשה בהם שימוש במסגרת עיבוד הבקשות במסגרת מרווח זמן של דקה אחת. יכול להיות שתבחינו בבעיות בביצועים כשהנתונים במסד הנתונים יתקרבו ל-100%.
אופטימיזציה של השימוש
יש כמה שיטות מומלצות שאפשר להשתמש בהן כדי לבצע אופטימיזציה של השימוש במסדי נתונים ושל עלויות רוחב הפס.
- שימוש ב-SDKs מקומיים: כשהדבר אפשרי, כדאי להשתמש ב-SDKs שתואמים לפלטפורמה של האפליקציה במקום ב-API ל-REST. ערכות ה-SDK שומרות על חיבורים פתוחים, וכך מפחיתות את עלויות ההצפנה של SSL שמצטברות בדרך כלל עם ממשק ה-API ל-REST.
- בדיקת באגים: אם עלויות רוחב הפס גבוהות באופן בלתי צפוי, צריך לוודא שהאפליקציה לא מסנכרנת יותר נתונים או מסתנכרנת בתדירות גבוהה יותר ממה שהתכוונתם. כדי לאתר בעיות, אפשר להשתמש בכלי לניתוחי פרופיל כדי למדוד את פעולות הקריאה ולהפעיל את הרישום ביומן לניפוי באגים ב-SDK ל-Android, ב-Objective-C וב-SDK ל-אינטרנט. כדאי לבדוק את תהליכי הסנכרון והרקע באפליקציה כדי לוודא שהכול פועל כצפוי.
- צמצום החיבורים: אם אפשר, כדאי לנסות לבצע אופטימיזציה של רוחב הפס של החיבור. בקשות REST קטנות ותכופות יכולות להיות יקרות יותר מחיבור יחיד ומתמשך באמצעות ה-SDK המקורי. אם אתם משתמשים ב-API ל-REST, כדאי לכם להשתמש ב-HTTP keep-alive או באירועים שנשלחים מהשרת, כדי לצמצם את העלויות של לחיצות היד ב-SSL.
- שימוש בכרטיסי סשן של TLS: כדי לצמצם את עלויות העלויות הנוספות של הצפנת SSL בחיבורים שהומשכו, אפשר להנפיק כרטיסי סשן של TLS. האפשרות הזו שימושית במיוחד אם אתם צריכים חיבורים מאובטחים ותדירים למסד הנתונים.
- הוספת שאילתות לאינדקס: הוספת הנתונים לאינדקס מפחיתה את רוחב הפס הכולל שבו אתם משתמשים לשאילתות, וכך אתם נהנים משני יתרונות: הפחתת העלויות ושיפור הביצועים של מסד הנתונים. אפשר להשתמש בכלי לניתוח פרופיל כדי למצוא שאילתות שלא נוספו לאינדקס במסד הנתונים.
- אופטימיזציה של המאזינים: מוסיפים שאילתות כדי להגביל את הנתונים שמוחזרים על ידי פעולות ההאזנה, ומשתמשים במאזינים שמורידים רק עדכונים לנתונים – לדוגמה,
on()
במקוםonce()
. בנוסף, כדאי למקם את המאזינים כמה שיותר קרוב לסוף הנתיב כדי להגביל את כמות הנתונים שהם מסנכרנים. - צמצום עלויות האחסון: הרצת משימות ניקוי תקופתיות וצמצום נתונים כפולים במסד הנתונים.
- שימוש בכללים: מניעת פעולות לא מורשות שעלולות להיות יקרות במסד הנתונים. לדוגמה, שימוש ב-Firebase Realtime Database Security Rules יכול למנוע תרחיש שבו משתמש זדוני מוריד שוב ושוב את כל מסד הנתונים. מידע נוסף על שימוש בכללים של Firebase Realtime Database
תוכנית האופטימיזציה הטובה ביותר לאפליקציה שלכם תלויה בתרחיש לדוגמה הספציפי. זוהי רשימה חלקית של שיטות מומלצות, אבל תוכלו למצוא עוד טיפים ועצות ממומחים של Firebase בערוץ Slack שלנו או ב-Stack Overflow.