דלג לתוכן הראשידלג לצור קשר
    פרק 13 מתוך 20 · 19.6
    דברים שוייב קודינג לא ילמד אתכם

    תנאי מירוץ — Race Conditions

    שני אנשים שמתיישבים על אותו כיסא באותו רגע

    פרק 13 / 20

    אודות הפרק

    מה קורה כששני תהליכים נוגעים באותו מידע באותו רגע — ואיך נעילה מצילה אתכם.

    הבעיה: שני קונים, מוצר אחד

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

    למה זה קורה

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

    הפתרון: נעילה

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

    טיפ: אם האפליקציה שלכם מתעסקת במלאי, בכרטיסים, או בכל משאב מוגבל — קחו בחשבון Race Conditions והשתמשו בנעילה לפני שנוגעים בנתון.

    "שני אנשים קנו את המוצר האחרון באותה שנייה. בלי נעילה — שניהם קיבלו אישור על מוצר שכבר לא קיים."

    כל הפרקים

    מערכת תורים — Message Queue
    תור בדואר ישראל
    27.3
    1
    מטמון — Caching
    למה שומרים חלב במקרר ולא הולכים לסופר כל 5 דקות
    3.4
    2
    הגבלת קצב — Rate Limiting
    סדרן בכניסה למועדון
    10.4
    3
    אינדקסים במסד נתונים — Database Indexing
    תוכן עניינים בספר של 10,000 עמודים
    17.4
    4
    ניהול שגיאות וניסיונות חוזרים — Retry Logic
    GPS שמחשב מסלול מחדש
    24.4
    5
    אימות מול הרשאות — Auth vs AuthZ
    תעודת זהות מול כרטיס VIP
    1.5
    6
    משתני סביבה — Environment Variables
    למה לא כותבים את הסיסמה על הדלת
    8.5
    7
    מיגרציות — Database Migrations
    שיפוץ דירה בזמן שגרים בה
    15.5
    8
    איזון עומסים — Load Balancing
    קופות בסופר — למה לא פותחים רק אחת
    22.5
    9
    Webhooks
    ההבדל בין לבדוק כל 5 דקות אם הפיצה הגיעה לבין שהשליח מתקשר
    29.5
    10
    עסקאות — Transactions
    למה לא מעבירים כסף בלי לוודא שהצד השני קיבל
    5.6
    11
    Idempotency
    למה לחיצה כפולה על "שלם" לא צריכה לחייב פעמיים
    12.6
    12
    תנאי מירוץ — Race Conditions
    שני אנשים שמתיישבים על אותו כיסא באותו רגע
    19.6
    13
    לוגים וניטור — Logging & Monitoring
    מצלמות אבטחה לקוד שלכם
    26.6
    14
    CI/CD
    פס ייצור במפעל — לא שולחים מוצר בלי בדיקת איכות
    3.7
    15
    CORS
    למה השכן לא יכול להיכנס לדירה שלכם עם המפתח שלו
    10.7
    16
    SQL Injection
    מה קורה כשכותבים קוד בתוך שדה "שם משתמש"
    17.7
    17
    Background Jobs
    למה המלצר לא מבשל לכם את האוכל בעצמו
    24.7
    18
    מיקרוסרביסים מול מונוליט
    מסעדה ענקית אחת מול פוד קורט
    31.7
    19
    DNS ודומיינים
    ספר הטלפונים של האינטרנט
    7.8
    20

    נהנים מהסדרה?

    עקבו לתכנים נוספים על AI וטכנולוגיה