יצירת קבוצת MIG עם פלח Cloud TPU מרובה מארחים
במאמר הזה נסביר איך ליצור קבוצת מופעי מכונה מנוהלים (MIG) עם פלח TPU מרובה מארחים.
דרישות מוקדמות
צריך לוודא שמתקיימות הדרישות המוקדמות הבאות:
- יוצרים פרויקט ל-TPU כמו שמתואר במאמר הגדרת פרויקט ל-TPU.
- קובעים את הדרישות שלכם ל-TPU כמו שמתואר במאמר תכנון המשאבים.
יצירת MIG עם פרוסות TPU מרובות מארחים
- יוצרים תבנית של הגדרות מכונה.
- יוצרים מדיניות של עומס עבודה.
- יוצרים את ה-MIG.
יצירת תבנית של הגדרות מכונה
הפקודה ליצירת תבנית של הגדרות מכונה תלויה באפשרות הצריכה שבה אתם משתמשים: על פי דרישה, Spot, מוגבלת למקום שמור או התחלה גמישה (Flex-start). מידע נוסף על אפשרויות צריכה זמין במאמר תכנון משאבי TPU.
יצירת תבנית של הגדרות מכונה של מכונת TPU וירטואלית לפי דרישה
הפקודה הבאה יוצרת תבנית של הגדרות מכונה באמצעות האפשרות של צריכה על פי דרישה:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \
--machine-type=MACHINE_TYPE \
--maintenance-policy=TERMINATE \
--image-family=IMAGE_FAMILY \
--image-project=IMAGE_PROJECT
מחליפים את ה-placeholders הבאים:
-
INSTANCE_TEMPLATE_NAME: השם של תבנית הגדרות המכונה. -
MACHINE_TYPE: סוג המכונה של מכונת ה-TPU VM, לדוגמה,ct6e-standard-8t. -
IMAGE_FAMILY: משפחת תמונות מערכת ההפעלה של ה-TPU VM. אם רוצים להתקין גרסה ספציפית של מערכת ההפעלה, משתמשים בדגל--image. מידע נוסף על תמונות של מערכת ההפעלה זמין במאמר תמונות של מערכת ההפעלה. -
IMAGE_PROJECT: הפרויקט שמכיל את תמונת מערכת ההפעלה. בתמונות TPU, הערך הואubuntu-os-accelerator-images.
יצירת תבנית של הגדרות מכונה עבור VM במודל Spot של TPU
הפקודה הבאה יוצרת תבנית של הגדרות מכונה באמצעות האפשרות של צריכת Spot:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \
--machine-type=MACHINE_TYPE \
--maintenance-policy=TERMINATE \
--instance-termination-action=STOP \
--provisioning-model=SPOT \
--image-family=IMAGE_FAMILY \
--image-project=IMAGE_PROJECT
מחליפים את ה-placeholders הבאים:
-
INSTANCE_TEMPLATE_NAME: השם של תבנית הגדרות המכונה. -
MACHINE_TYPE: סוג המכונה של מכונת ה-TPU VM, לדוגמה,ct6e-standard-8t. -
IMAGE_FAMILY: משפחת תמונות מערכת ההפעלה של ה-TPU VM. אם רוצים להתקין גרסה ספציפית של מערכת ההפעלה, משתמשים בדגל--image. מידע נוסף על תמונות של מערכת ההפעלה זמין במאמר תמונות של מערכת ההפעלה. -
IMAGE_PROJECT: הפרויקט שמכיל את תמונת מערכת ההפעלה. בתמונות TPU, הערך הואubuntu-os-accelerator-images.
יצירת תבנית של הגדרות מכונה למכונה וירטואלית שמוגבלת למקום שמור של TPU
הפקודה הבאה יוצרת תבנית של הגדרות מכונה באמצעות אפשרות הצריכה שמוגבלת להזמנה:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \
--machine-type=MACHINE_TYPE \
--maintenance-policy=TERMINATE \
--instance-termination-action=DELETE \
--reservation-affinity=specific \
--provisioning-model=reservation-bound \
--reservation=RESERVATION_NAME \
--image-family=IMAGE_FAMILY \
--image-project=IMAGE_PROJECT
מחליפים את ה-placeholders הבאים:
-
INSTANCE_TEMPLATE_NAME: השם של תבנית הגדרות המכונה. -
MACHINE_TYPE: סוג המכונה של מכונת ה-TPU VM, לדוגמה,ct6e-standard-8t. -
RESERVATION_NAME: השם של ההזמנה הספציפית שרוצים להשתמש בה. -
IMAGE_FAMILY: משפחת תמונות מערכת ההפעלה של ה-TPU VM. אם רוצים להתקין גרסה ספציפית של מערכת ההפעלה, משתמשים בדגל--image. מידע נוסף על תמונות של מערכת ההפעלה זמין במאמר תמונות של מערכת ההפעלה. -
IMAGE_PROJECT: הפרויקט שמכיל את תמונת מערכת ההפעלה. בתמונות TPU, הערך הואubuntu-os-accelerator-images.
יצירת תבנית של מכונה וירטואלית עם TPU Flex-start
הפקודה הבאה יוצרת תבנית של הגדרות מכונה באמצעות אפשרות הצריכה flex-start:
gcloud compute instance-templates create INSTANCE_TEMPLATE_NAME \
--machine-type=MACHINE_TYPE \
--maintenance-policy=TERMINATE \
--instance-termination-action=DELETE \
--provisioning-model=FLEX_START \
--max-run-duration=DURATION \
--image-family=IMAGE_FAMILY \
--image-project=IMAGE_PROJECT
מחליפים את ה-placeholders הבאים:
-
INSTANCE_TEMPLATE_NAME: השם של תבנית הגדרות המכונה. -
MACHINE_TYPE: סוג המכונה של מכונת ה-TPU VM, לדוגמה,ct6e-standard-8t. -
DURATION: משך הזמן המקסימלי שבו אפשר להריץ את TPU VM. -
IMAGE_FAMILY: משפחת תמונות מערכת ההפעלה של ה-TPU VM. אם רוצים להתקין גרסה ספציפית של מערכת ההפעלה, משתמשים בדגל--image. מידע נוסף על תמונות של מערכת ההפעלה זמין במאמר תמונות של מערכת ההפעלה. -
IMAGE_PROJECT: הפרויקט שמכיל את תמונת מערכת ההפעלה. בתמונות TPU, הערך הואubuntu-os-accelerator-images.
יצירת מדיניות של עומס עבודה
צריך ליצור מדיניות של כוח עבודה עם הפרמטר accelerator-topology (לדוגמה, 4x4, 8x8 או 4x4x4). טופולוגיית המאיץ מגדירה את ה-MIG כך שהמופעים יטופלו כפלח יחיד ומקושר.
הפקודה הבאה יוצרת מדיניות של עומס עבודה:
gcloud compute resource-policies create workload-policy WORKLOAD_POLICY_NAME \
--type=high-throughput \
--accelerator-topology=TOPOLOGY \
--region=REGION
מחליפים את ה-placeholders הבאים:
-
WORKLOAD_POLICY_NAME: השם של מדיניות עומס העבודה. -
TOPOLOGY: הטופולוגיה של מכונות ה-TPU הווירטואליות, לדוגמה,4x4x8. מידע נוסף על טופולוגיה לכל גרסה של TPU זמין במאמר בנושא ארכיטקטורת מערכת. -
REGION: האזור של מדיניות עומס העבודה.
יצירת קבוצת מופעים מנוהלת (MIG)
יוצרים קבוצת MIG אזורית או אזורית באמצעות הפקודה gcloud compute instance-groups managed create באופן הבא:
כדי ליצור קבוצת MIG אזורית שמכילה פרוסת TPU עם כמה מארחים, משתמשים בפקודה הבאה:
gcloud compute instance-groups managed create MIG_NAME \ --size=MIG_SIZE \ --target-size-policy-mode=bulk \ --template=INSTANCE_TEMPLATE_URL \ --zone=ZONE \ --default-action-on-vm-failure=do-nothing \ --workload-policy=WORKLOAD_POLICY_URLכדי ליצור קבוצת MIG אזורית שמכילה פלח TPU עם כמה מארחים, משתמשים בפקודה הבאה:
gcloud compute instance-groups managed create MIG_NAME \ --size=MIG_SIZE \ --target-size-policy-mode=bulk \ --template=INSTANCE_TEMPLATE_URL \ --region=REGION \ --default-action-on-vm-failure=do-nothing \ --workload-policy=WORKLOAD_POLICY_URL \ --target-distribution-shape=any-single-zone \ --instance-redistribution-type=none
מחליפים את ה-placeholders הבאים:
-
MIG_NAME: השם של קבוצת ה-MIG. -
MIG_SIZE: מספר המכונות הווירטואליות ב-MIG. -
INSTANCE_TEMPLATE_URL: כתובת ה-URL של תבנית של הגדרות מכונה שרוצים להשתמש בה כדי ליצור מכונות ב-MIG. כתובת ה-URL יכולה להכיל את המזהה או את השם של תבנית של הגדרות מכונה. מציינים אחד מהערכים הבאים:- לתבנית של הגדרות מכונה אזורית:
projects/PROJECT_ID/regions/REGION/instanceTemplates/INSTANCE_TEMPLATE_ID - בתבנית של הגדרות מכונה גלובלית:
INSTANCE_TEMPLATE_ID
- לתבנית של הגדרות מכונה אזורית:
-
ZONE: האזור של ה-MIG. -
REGION: האזור של ה-MIG. -
WORKLOAD_POLICY_URL: כתובת ה-URL של מדיניות העומס שרוצים להשתמש בה כדי ליצור מופעים ב-MIG. לדוגמה:projects/PROJECT_ID/regions/WORKLOAD_POLICY_REGION/resourcePolicies/WORKLOAD_POLICY_NAME.
יצירת מכונות וירטואליות עם שמות בהתאמה אישית ב-MIG
אפשר ליצור מכונות וירטואליות ב-MIG על ידי ציון שמות בהתאמה אישית לכל מכונה וירטואלית. האפשרות הזו שימושית לניפוי באגים ולוודא שהמופעים נוצרים בסדר מסוים.
קבוצות MIG שמכילות פלח TPU עם כמה מארחים משתמשות במצב 'כמות גדולה' של מדיניות גודל היעד. כשיוצרים מכונות וירטואליות עם שמות בהתאמה אישית בקבוצת MIG כזו, חלים הכללים הבאים:
קודם צריך לוודא שאין מכונות וירטואליות בקבוצת ה-MIG. אם יש מכונות וירטואליות ב-MIG, צריך לשנות את הגודל של ה-MIG לגודל היעד
0או ליצור עוד MIG עם גודל היעד0.אפשר להשתמש ב-API בארכיטקטורת REST רק כדי ליצור מכונות וירטואליות עם שמות בהתאמה אישית.
כדי ליצור מכונות וירטואליות עם שמות בהתאמה אישית, משתמשים באחת מהשיטות הבאות של API בארכיטקטורת REST:
בשביל MIG אזורי, משתמשים ב-
instanceGroupManagers.createInstances.POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instanceGroupManagers/MIG_NAME/createInstances { "instances": [ { "name": "INSTANCE_NAME_1" }, { "name": "INSTANCE_NAME_2" }, ... ] }ל-MIG אזורי, משתמשים ב-
regionInstanceGroupManagers.createInstances.POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/instanceGroupManagers/MIG_NAME/createInstances { "instances": [ { "name": "INSTANCE_NAME_1" }, { "name": "INSTANCE_NAME_2" }, ... ] }
מחליפים את ה-placeholders הבאים:
-
PROJECT_ID: מזהה הפרויקט שבו קיימת קבוצת ה-MIG. -
ZONE: האזור של ה-MIG. -
REGION: האזור של ה-MIG. -
INSTANCE_NAME_1,2,..: השמות של המכונות הווירטואליות שרוצים להוסיף לקבוצת ה-MIG שצוינה.
המאמרים הבאים
- מידע נוסף על מכונות VM של TPU ועל MIG
- איך יוצרים MIG עם פרוסת Cloud TPU של מארח יחיד
- איך מנהלים מכונות וירטואליות של TPU
- מידע על TPU ב-GKE
- איך מריצים עומסי עבודה של ML ב-TPU, למשל, Serve Qwen2-72B-Instruct with vLLM on TPUs