הקטנת נפח האחסון של מופע

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

לפני שמתחילים

  1. מעיינים במגבלות של התכונה.

  2. אם אתם משתמשים ב-ה-CLI של gcloud, ודאו שאתם משתמשים בגרסה העדכנית של Google Cloud SDK ושל ה-CLI של gcloud.

    • מתקינים את הגרסה העדכנית של ה-CLI של gcloud (גרסה 563.0.0 ואילך של ה-CLI של gcloud).
    • כדי לקבל את הגרסה הנוכחית של ה-CLI של gcloud, מריצים את הפקודה gcloud --version.
    • כדי לעדכן את גרסת ה-CLI של gcloud, מריצים את הפקודה gcloud components update.
  3. מקבלים את הרשאות ה-IAM הבאות:

    • cloudsql.instances.getDiskShrinkConfig
    • cloudsql.instances.performDiskShrink

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

    • Cloud SQL Admin ‏ (roles/cloudsql.admin)
    • עריכה ב-Cloud SQL (roles/cloudsql.editor)

    מידע נוסף זמין במקורות המידע הבאים:

הכנת המופע

לפני שמתחילים, צריך לעמוד בדרישות הבאות.

השלבים האלה זהים גם למופעים ראשיים וגם למופעים משוכפלים לקריאה.

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

  1. מאתרים את מזהה הפרויקט שמכיל את המופע שרוצים לנהל.

  2. בודקים את המצב הנוכחי של המכונה כדי לוודא שהיא פועלת. אחת הדרכים לבדוק היא להשתמש בפקודה describe:

      gcloud sql instances describe
    

    הפונקציה מחזירה את הסטטוס הבא:

      RUNNABLE
    

    אם לא, מפעילים את המופע.

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

  4. משביתים את כל התוספים או התכונות שמאפשרים חיבורים יוצאים (או שדורשים העברת נתונים יוצאת).

הקטנת נפח האחסון של מופע

השלבים הבאים זהים למופעים ראשיים ולרפליקות לקריאה.

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

    gcloud

    מריצים את הפקודה gcloud sql instances get-storage-shrink-config:

    gcloud sql instances get-storage-shrink-config INSTANCE_NAME
    

    מחליפים את מה שכתוב בשדות הבאים:

    • INSTANCE_NAME: השם של המכונה הראשית.

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

    התגובה כוללת גם הודעה עם זמן פעולה משוער, כמו בדוגמה הבאה:

    ...
    "The estimated operation time is 20 minutes".
    

    REST v1

    אפשר להשתמש בשיטה GET כדי לראות את נפח האחסון המינימלי של יעד המופע.

    לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

    • PROJECT_ID: השם של הפרויקט שבו נמצאת המכונה הראשית.
    • INSTANCE_ID: מזהה המכונה של המכונה הראשית.

    ה-method של ה-HTTP וכתובת ה-URL:

    GET https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_ID/getDiskShrinkConfig

    כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

    אתם אמורים לקבל תגובת JSON שדומה לזו:

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

    התגובה כוללת גם הודעה עם זמן פעולה משוער, כמו בדוגמה הבאה:

    ...
    "The estimated operation time is 20 minutes".
    

    REST v1beta4

    אפשר להשתמש בשיטה GET כדי לראות את נפח האחסון המינימלי של יעד המופע.

    לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

    • PROJECT_ID: השם של הפרויקט שבו נמצאת המכונה הראשית.
    • INSTANCE_ID: מזהה המכונה של המכונה הראשית.

    ה-method של ה-HTTP וכתובת ה-URL:

    GET https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_ID/getDiskShrinkConfig

    כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

    אתם אמורים לקבל תגובת JSON שדומה לזו:

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

    התגובה כוללת גם הודעה עם זמן פעולה משוער, כמו בדוגמה הבאה:

    ...
    "The estimated operation time is 20 minutes".
    
  2. הקטנת נפח האחסון של המכונה.

    gcloud

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

    gcloud sql instances perform-storage-shrink INSTANCE_NAME \
      --storage-size=TARGET_STORAGE_SIZE
    

    מחליפים את מה שכתוב בשדות הבאים:

    • INSTANCE_NAME: השם של המכונה.
    • TARGET_STORAGE_SIZE: נפח האחסון הרצוי ב-GB. לדוגמה, ‎100 GB.

    REST v1

    לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

    • PROJECT_ID: מזהה הפרויקט שבו נמצאת המכונה.
    • INSTANCE_ID: מזהה המכונה.
    • TARGET_STORAGE_SIZE: גודל האחסון הרצוי ב-GB.

    ה-method של ה-HTTP וכתובת ה-URL:

    POST https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_ID/performDiskShrink

    תוכן בקשת JSON:

    {
      "targetSizeGb": TARGET_STORAGE_SIZE
    }
    

    כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

    אתם אמורים לקבל תגובת JSON שדומה לזו:

    REST v1beta4

    לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

    • PROJECT_ID: מזהה הפרויקט שבו נמצאת המכונה.
    • INSTANCE_ID: מזהה המכונה.
    • TARGET_STORAGE_SIZE: גודל האחסון של המכונה.

    ה-method של ה-HTTP וכתובת ה-URL:

    POST https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_ID/performDiskShrink

    תוכן בקשת JSON:

    {
      "targetSizeGb": TARGET_STORAGE_SIZE
    }
    

    כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

    אתם אמורים לקבל תגובת JSON שדומה לזו:

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

ביטול פעולה של הקטנת נפח האחסון

  1. מקבלים את מזהה הפעולה של הקטנת נפח האחסון.

    כדי לאחזר את מזהה הפעולה, מריצים את פקודת list הבאה:

    gcloud sql operations list
    
  2. שליחת בקשת ביטול.

    gcloud

    מריצים את הפקודה הבאה כדי לבטל את הבקשה:

    gcloud sql operations cancel OPERATION_ID
    

    מחליפים את מה שכתוב בשדות הבאים:

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

    REST v1

    לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

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

    ה-method של ה-HTTP וכתובת ה-URL:

    POST https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/operations/OPERATION_ID/cancel

    כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

    אמורים לקבל קוד סטטוס של הצלחה (2xx) ותגובה ריקה.

    REST v1beta4

    לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

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

    ה-method של ה-HTTP וכתובת ה-URL:

    POST https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/operations/OPERATION_ID/cancel

    כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

    אמורים לקבל קוד סטטוס של הצלחה (2xx) ותגובה ריקה.

בדיקת הסטטוס של בקשה לביטול או של פעולה אחרת

כדי לבדוק את הסטטוס של בקשה, מריצים את הפקודות הבאות:

gcloud

  1. מאחזרים את מזהה הפעולה של בקשת הביטול:

    gcloud sql operations list
    
  2. בודקים את סטטוס הפעולה:

    gcloud sql operations describe OPERATION_ID
    

    מחליפים את מה שכתוב בשדות הבאים:

    OPERATION_ID: המזהה של הפעולה שרוצים לבדוק.

REST v1

לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

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

ה-method של ה-HTTP וכתובת ה-URL:

GET https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/operations/OPERATION_ID

כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

אתם אמורים לקבל תגובת JSON שדומה לזו:

REST v1beta4

לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:

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

ה-method של ה-HTTP וכתובת ה-URL:

GET https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/operations/OPERATION_ID

כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:

אתם אמורים לקבל תגובת JSON שדומה לזו:

פתרון בעיות

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

המאמרים הבאים