רלוונטי רק למהדורת Cloud Firestore Enterprise. |
בדף הזה מוסבר איך להשתמש במסוף Google Cloud וב-Google Cloud CLI כדי להגדיר מדיניות של זמן חיים (TTL).
סקירה כללית של Time to live
אפשר להשתמש במדיניות TTL כדי להסיר באופן אוטומטי נתונים לא עדכניים ממסדי הנתונים. מדיניות TTL מציינת שדה מסוים כזמן התפוגה של מסמכים באוסף נתון. בעזרת TTL, אפשר להקטין את עלויות האחסון על ידי ניקוי נתונים לא רלוונטיים. הנתונים נמחקים בדרך כלל תוך 24 שעות אחרי תאריך התפוגה.
תמחור
פעולות מחיקה של TTL נכללות בעלויות המחיקה של המסמכים. למידע על התמחור של פעולות מחיקה, אפשר לעיין בCloud Firestoreתמחור של מהדורת Enterprise.
מגבלות ואילוצים
- אפשר לסמן רק שדה אחד בכל אוסף כשדה TTL.
- אפשר להגדיר עד 500 הגדרות של TTL ברמת השדה.
מחיקה של TTL
חשוב לשים לב להתנהגויות העיקריות הבאות של מחיקה שמבוססת על TTL:
מחיקה באמצעות TTL היא לא תהליך מיידי. מסמכים שתוקפם פג ממשיכים להופיע בשאילתות ובבקשות חיפוש עד שתהליך ה-TTL מוחק אותם בפועל. הזמן שחולף עד למחיקת עסקאות (TTL) לטובת צמצום העלות הכוללת של הבעלות על המחיקות. הנתונים נמחקים בדרך כלל תוך 24 שעות אחרי תאריך התפוגה שלהם.
החלת מדיניות TTL על אוסף קיים גורמת למחיקה בכמות גדולה של כל הנתונים שתוקף השימוש בהם פג, בהתאם למדיניות ה-TTL החדשה. הערה: גם מחיקה בכמות גדולה לא מתבצעת באופן מיידי, והיא תלויה בכמות הנתונים שנאספו.
אם למסמך יש זמן תפוגה בעבר ואתם מוסיפים מדיניות חדשה של TTL לאוסף, המסמך יימחק תוך 24 שעות מסיום ההגדרה של מדיניות ה-TTL והפיכתה לפעילה.
המסמכים לא נמחקים בהכרח לפי סדר התפוגה של חותמות הזמן שלהם.
המחיקות לא מתבצעות באופן טרנזקציונלי. מסמכים עם אותו מועד תפוגה לא בהכרח נמחקים באותו זמן. אם אתם רוצים שהמערכת תפעל כך, תצטרכו לבצע את המחיקות באמצעות ספריית לקוח.
ב-Cloud Firestore עם תאימות ל-MongoDB, תמיד יתבצע שימוש בשדה ה-TTL העדכני ביותר כדי לקבוע את תאריך התפוגה. לדוגמה, אם תוקף של מסמך פג אבל הוא עדיין לא נמחק, ואם שדה ה-TTL שלו יעודכן לתאריך מאוחר יותר, התוקף של המסמך לא יפוג והתאריך החדש ישמש כנקודת זמן.
ב-Cloud Firestore עם תאימות ל-MongoDB, מסמך יפוג רק אם השדה TTL מוגדר לסוג
Date and time
אוBSON Date
. כדי להשבית את התפוגה על בסיס כל מסמך בנפרד, משאירים את השדה ריק או מגדירים בו ערך כמוnull
.ה-TTL נועד לצמצם את ההשפעה על פעילויות אחרות במסד הנתונים. מחיקות שמבוססות על TTL מקבלות עדיפות נמוכה יותר. יש גם אסטרטגיות אחרות שמטרתן למתן את העליות החדות בתנועה שנובעות ממחיקות שמבוססות על TTL.
שדות ואינדקסים של TTL
אפשר להוסיף לאינדקס או להסיר מהאינדקס שדה TTL. עם זאת, מכיוון ששדה ה-TTL הוא חותמת זמן, יצירת אינדקס לשדה יכולה להשפיע על הביצועים בשיעורי תנועה גבוהים יותר. יצירת אינדקס לשדה של חותמת זמן עלולה ליצור נקודות חמות, וזה לא מומלץ. נקודות חמות הן אזורים במסמך שמתבצעות בהם פעולות קריאה, כתיבה ומחיקה בקצב גבוה.
הרשאות
לחשבון המשתמש שמגדיר מדיניות TTL נדרשת ההרשאה הבאה בפרויקט:
- כדי לראות את מדיניות ה-TTL צריך את ההרשאות
datastore.indexes.list
ו-datastore.indexes.get
. - כדי לשנות מדיניות TTL צריך את ההרשאה
datastore.indexes.update
. - כדי לבדוק את הסטטוס של פעולות TTL, צריך הרשאות
datastore.operations.list
ו-datastore.operations.get
.
לרשימת התפקידים שכוללים את ההרשאות האלה, ראו Cloud Firestore תפקידים בניהול זהויות והרשאות גישה.
לפני שמתחילים
לפני שמשתמשים בפקודה gcloud CLI כדי לנהל מדיניות TTL, צריך להשתמש בפקודה gcloud components update
כדי לעדכן את הרכיבים לגרסה האחרונה שזמינה:
gcloud components update
יצירת מדיניות TTL
כשיוצרים מדיניות TTL, מציינים שדה מסמך כזמן התפוגה של מסמכים באוסף.
התכונה TTL משתמשת בשדה שצוין כדי לזהות מסמכים שעומדים בדרישות למחיקה.
השדה הזה של TTL חייב להיות מסוג Timestamp
או BSON Date
. אפשר לבחור שדה שכבר קיים או להגדיר שדה שמתכננים להוסיף בהמשך.
לפני שמגדירים את הערך בשדה TTL, כדאי לקחת בחשבון את הנקודות הבאות:
הערך בשדה TTL יכול להיות מועד בעתיד, עכשיו או בעבר. אם הערך הוא זמן בעבר, המסמך עומד בדרישות למחיקה באופן מיידי. לדוגמה, אפשר ליצור מדיניות TTL עם השדה
expireAt
, ואז להוסיף אותה למסמכים קיימים.שימוש בסוג נתונים אחר או אי-הגדרת ערך בשדה TTL ישביתו את ה-TTL של המסמך הספציפי.
כדי ליצור מדיניות TTL, פועלים לפי השלבים הבאים:
Google Cloud Console
נכנסים לדף Databases במסוף Google Cloud.
בוחרים את מסד הנתונים הרצוי מרשימת מסדי הנתונים.
בתפריט הניווט, לוחצים על Time-to-live (זמן החיים).
לוחצים על יצירת מדיניות.
מזינים שם לאוסף ושם של שדה חותמת הזמן.
לוחצים על יצירה.
המסוף חוזר לדף Time-to-live. אם הפעולה מתחילה בהצלחה, נוסף דף לרשומת המדיניות של TTL בטבלה. אם הפעולה נכשלת, מוצגת הודעת שגיאה בדף.
gcloud
משתמשים בפקודה
firestore fields ttls update
כדי להגדיר מדיניות TTL. מוסיפים את הדגל--async
כדי למנוע את ההמתנה של gcloud CLI לסיום הפעולה.gcloud firestore fields ttls update ttl_field --collection-group=collection_name --enable-ttl
משך הזמן שבו מדיניות ה-TTL מופעלת
גם במסד נתונים ריק, הפעלת מדיניות TTL יכולה להימשך עשר דקות או יותר. אחרי שמתחילים פעולה, סגירת הטרמינל לא מבטלת את הפעולה.
צפייה במדיניות בנושא TTL
כדי לראות את מדיניות ה-TTL והסטטוס שלה, פועלים לפי השלבים הבאים:
Google Cloud Console
נכנסים לדף Databases במסוף Google Cloud.
בוחרים את מסד הנתונים הרצוי מרשימת מסדי הנתונים.
בתפריט הניווט, לוחצים על Time-to-live (זמן החיים).
במסוף מופיעות מדיניות ה-TTL של מסד הנתונים, וגם הסטטוס של כל מדיניות.
gcloud
משתמשים בפקודה
firestore fields ttls list
כדי להגדיר מדיניות TTL. הפקודה הבאה מציגה רשימה של כל מדיניות ה-TTL.gcloud firestore fields ttls list
כדי להציג רשימה של מדיניות TTL באוסף ספציפי, משתמשים בפקודה הבאה:
gcloud firestore fields ttls list --collection-group=collection_name
צפייה בפרטי הפעולה
אפשר להשתמש בלחצן gcloud CLI כדי לראות פרטים נוספים על מדיניות TTL שנמצאת במצב CREATING
.
משתמשים בפקודה operations list
כדי לראות את כל הפעולות שפועלות ואת הפעולות שהסתיימו לאחרונה:
gcloud firestore operations list
התשובה כוללת הערכה של התקדמות הפעולה.
השבתת מדיניות בנושא TTL
כדי להשבית מדיניות TTL, מבצעים את השלבים הבאים:
Google Cloud Console
נכנסים לדף Databases במסוף Google Cloud.
בוחרים את מסד הנתונים הרצוי מרשימת מסדי הנתונים.
בתפריט הניווט, לוחצים על Time-to-live (זמן החיים).
בטבלה של מדיניות ה-TTL, מחפשים את השורה של מדיניות ה-TTL. בשורה הזו בטבלה, לוחצים על הלחצן מחיקה (סמל של פח אשפה).
לוחצים על מחיקה כדי לאשר את הפעולה.
המסוף חוזר לדף Time-to-live. אם הפעולה תצליח, Cloud Firestore עם תאימות ל-MongoDB יסיר את מדיניות ה-TTL מהטבלה.
gcloud
משתמשים בפקודה
firestore fields ttls update
כדי להגדיר מדיניות TTL. מוסיפים את הדגל--async
כדי למנוע את ההמתנה של gcloud CLI לסיום הפעולה.gcloud firestore fields ttls update ttl_field --collection-group=collection_name --disable-ttl
מעקב אחרי מחיקות של TTL
אפשר להשתמש ב-Cloud Monitoring כדי לראות מדדים לגבי מחיקות שמבוססות על TTL. Cloud Firestore עם תאימות ל-MongoDB מספק את המדדים הבאים ל-TTL:
סוג מדד | שם המדד | תיאור המדד |
---|---|---|
firestore.googleapis.com/document/ttl_deletion_count | מספר המחיקות של נתונים שמוגדר להם זמן חיים |
המספר הכולל של מסמכים שנמחקו על ידי מדיניות TTL. |
firestore.googleapis.com/document/ttl_expiration_to_deletion_delays | עיכובים במחיקה בגלל תפוגה של זמן החיים |
הזמן שחלף בין מועד התפוגה של מסמך במסגרת מדיניות TTL לבין מועד המחיקה בפועל. |
כדי להגדיר לוח בקרה עם מדדים של Cloud Firestore עם תאימות ל-MongoDB, אפשר לעיין במאמרים בנושא ניהול לוח בקרה בהתאמה אישית והוספת ווידג'טים ללוח בקרה.