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

    אינדקסים במסד נתונים — Database Indexing

    תוכן עניינים בספר של 10,000 עמודים

    פרק 4 / 20

    אודות הפרק

    למה חיפוש בלי אינדקס הוא כמו לחפש מילה בספר עמוד אחרי עמוד.

    הבעיה: לסרוק מיליון שורות שורה-שורה

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

    הפתרון: תוכן עניינים למסד הנתונים

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

    יש לזה מחיר

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

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

    "מ-3 שניות ל-3 מילישניות — לפעמים כל מה שחסר לאפליקציה האיטית שלכם זה תוכן עניינים."

    כל הפרקים

    מערכת תורים — 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 וטכנולוגיה