יכולת סריאליזציה ובידוד של עסקאות

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

טרנזקציות ועימות נתונים

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

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

Cloud Firestore resolves data contention by delaying or failing one of the operations. Cloud Firestore ספריות הלקוח מנסות באופן אוטומטי לבצע מחדש טרנזקציות שנכשלות בגלל התנגשות נתונים. אחרי מספר סופי של ניסיונות חוזרים, פעולת העסקה נכשלת ומוחזרת הודעת שגיאה:

ABORTED: Too much contention on these documents. Please try again.

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

אמצעי בקרה לבו-זמניות

מצב הבו-זמניות הוא אפשרות להגדרה במסד הנתונים. ‫Cloud Firestore תומך במצבי הבו-זמניות הבאים:

  • PESSIMISTIC: אמצעי בקרה אופטימיים של גישה בו-זמנית מניחים שסביר להניח שתהיה תחרות על הנתונים. בטרנזקציות פסימיות נעשה שימוש בנעילות של מסדי נתונים כדי למנוע מפעולות אחרות לשנות את הנתונים.

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

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

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

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

הגדרות ברירת המחדל של מצב בו-זמניות

ערך ברירת המחדל במהדורת Standard הוא PESSIMISTIC. ערך ברירת המחדל במהדורת Enterprise הוא OPTIMISTIC. עם זאת, ההתנהגות תלויה גם בסוג של ספריית הלקוח:

  • מערכות ה-SDK לנייד ול-Web משתמשות באמצעי בקרה של concurrency אופטימי. התנהגות ה-SDK לנייד ול-SDK לאינטרנט לא מושפעת מההגדרה הזו, כי הם תמיד מדמים אופטימיזציה של מקביליות.

  • ספריות הלקוח של השרת משתמשות באמצעי בקרה של מקביליות בהגדרת מסד הנתונים.

בקרות אופטימיות או פסימיות של פעולות בו-זמניות.

התנגשות נתונים בערכות ה-SDK לניידים ולאתרים

ערכות SDK לנייד ולאינטרנט מדמות טרנזקציות של בו-זמניות אופטימית באמצעות תנאים מוקדמים לכתיבה בגרסאות של מסמכים. האמולציה הזו מתרחשת ללא קשר להגדרת מצב הגישה בו-זמנית של מסד הנתונים. ערכות ה-SDK לאפליקציות לנייד ולאתרי אינטרנט לא משתמשות בתכונה built-in transactions, ולכן גם אם מצב הבו-זמניות של מסד הנתונים מוגדר ל-PESSIMISTIC, לקוחות לנייד עדיין מתנהגים בצורה אופטימית.

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

התנגשות נתונים בספריות הלקוח של השרת

ספריות לקוח של שרתים (C#‎,‏ Go, ‏ Java, ‏ Node.js, ‏ PHP, ‏ Python, ‏ Ruby) משתמשות בתכונה מוכללת של טרנזקציות. העסקאות האלה משתמשות בהגדרה של מצב מקביליות ברמת מסד הנתונים, וערך ברירת המחדל תלוי במהדורה:

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

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

בידוד סריאלי

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

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

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

בידוד ניתן לסדרות מגדיר את רמת הבידוד הגבוהה ביותר. בידוד מסוג Serializable אומר:

  • אפשר להניח שמסד הנתונים מבצע עסקאות בסדרה.
  • עסקאות לא מושפעות משינויים שלא בוצעו בפעולות מקבילות.

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

Cloud Firestore מבטיח בידוד של טרנזקציות שניתן לסדר אותן בסדר מסוים. העסקאות ב-Cloud Firestore עוברות סריאליזציה ומבודדות לפי זמן ביצוע השינויים.

בידוד ניתן לסריאליזציה לפי זמן ביצוע

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

ביצוע בפועל של עסקה דורש פרק זמן מסוים. ההרצה של טרנזקציה מתחילה לפני זמן השמירה, וההרצה של כמה פעולות עשויה לחפוף. ‫Cloud Firestore תומך בבידוד שניתן לסדר בסדרות ומבטיח את הדברים הבאים:

  • Cloud Firestore מבצע עסקאות לפי סדר הזמן של ביצוע השינויים.
  • Cloud Firestore מבודד עסקאות מפעולות מקבילות עם זמן אישור מאוחר יותר.

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

בידוד בתוך טרנזקציה

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

בעיות שקשורות להתנגשות נתונים

מידע נוסף על התנגשות נתונים ועל פתרון בעיות מופיע בדף לפתרון בעיות.