פריסה גלובלית באמצעות Compute Engine ו-Spanner

Last reviewed 2025-08-12 UTC

במאמר הזה מוצגת ארכיטקטורת הפניה לאפליקציה מרובת-שכבות שפועלת במכונות וירטואליות של Compute Engine וב-Spanner בטופולוגיה גלובלית ב- Google Cloud. במסמך מופיעות גם הנחיות שיעזרו לכם לבנות ארכיטקטורה שמשתמשת בשירותי תשתית אחרים. Google Cloud במאמר הזה מתוארים גורמי העיצוב שצריך להביא בחשבון כשבונים ארכיטקטורה גלובלית לאפליקציות בענן. קהל היעד של המסמך הזה הוא אדריכלי ענן.

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

ארכיטקטורה

בתרשים הבא מוצגת ארכיטקטורה של אפליקציה שפועלת בתשתית שמפוזרת באופן גלובלי בכמה אזורים של Google Cloud.

ארכיטקטורת פריסה גלובלית באמצעות Compute Engine ו-Spanner.

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

הארכיטקטורה כוללת את המשאבים הבאים Google Cloud :

רכיב מטרה
מאזן עומסים גלובלי חיצוני

מאזן העומסים הגלובלי החיצוני מקבל בקשות ממשתמשים ומפיץ אותן לאפליקציה. מאזן העומסים הגלובלי החיצוני מפרסם כתובת IP אחת של anycast, אבל הוא מיושם כמספר גדול של שרתי proxy ב ממשקי הקצה של Google‏ (GFE). בקשות של לקוחות מנותבות ל-GFE הקרוב ביותר ללקוח.

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

כדי להגן על האפליקציה מפני איומים כמו התקפות מניעת שירות מבוזרות (DDoS) ופרצות אבטחה XSS‏ (cross-site scripting), אתם יכולים להשתמש ב מדיניות האבטחה של Google Cloud Armor.

קבוצות של מופעי מכונה מנוהלים (MIG) ברמה האזורית בשביל רמת האינטרנט

שכבת האינטרנט של האפליקציה נפרסת במכונות וירטואליות של Compute Engine שהן חלק מקבוצות אזוריות של מכונות מנוהלות (MIG). קבוצות ה-MIG האלה הן שרתי הבק-אנד של מאזן העומסים הגלובלי.

כל קבוצת MIG מכילה מכונות וירטואליות של Compute Engine בשלושה אזורים שונים. כל מכונה וירטואלית כזו מארחת מופע עצמאי של רמת האינטרנט של האפליקציה.

שכבת איזון עומסים פנימית חוצה אזורים

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

בהתאם לדרישות שלכם, אתם יכולים להשתמש ב מאזן עומסים פנימי של אפליקציות (ALB) חוצה אזורים או ב מאזן עומסי רשת פנימי לשרת proxy חוצה אזורים. מידע נוסף זמין במאמר בנושא בחירת מאזן עומסים.

קבוצות אזוריות של מכונות מנוהלות (MIG) לשכבת האפליקציה

שכבת האפליקציה נפרסת במכונות וירטואליות של Compute Engine שהן חלק מקבוצות של מופעי מכונה מנוהלים (MIG) באזור. קבוצות ה-MIG האלה הן קצה העורף של שכבת איזון העומסים הפנימית.

כל קבוצת MIG מכילה מכונות וירטואליות של Compute Engine בשלושה אזורים שונים. כל מכונה וירטואלית מארחת מופע עצמאי של רמת האפליקציה.

מכונת Spanner במספר אזורים

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

  • ארבעה עותקים לקריאה ולכתיבה באזורים נפרדים בשני אזורים.
  • רפליקת עֵד באזור שלישי.
רשת של ענן וירטואלי פרטי (VPC) ו רשתות משנה

כל המשאבים בארכיטקטורה משתמשים ברשת VPC אחת. ברשת ה-VPC יש את רשתות המשנה הבאות:

במקום להשתמש ברשת VPC אחת, אפשר ליצור רשת VPC נפרדת בכל אזור ולחבר את הרשתות באמצעות Network Connectivity Center.

המוצרים שהשתמשו בהם

ארכיטקטורת ההפניה הזו כוללת את המוצרים הבאים Google Cloud :

  • Compute Engine: שירות מחשוב מאובטח וניתן להתאמה אישית שמאפשר ליצור מכונות וירטואליות ולהריץ אותן בתשתית של Google.
  • Cloud Load Balancing: חבילה של מאזני עומסים גלובליים ואזוריים, בעלי ביצועים גבוהים וניתנים להתאמה.
  • Spanner: שירות של מסד נתונים רלציוני עם יכולת התאמה רחבה ביותר ועקביות גלובלית.

שיקולים לגבי העיצוב

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

עיצוב המערכת

בקטע הזה מוסבר איך לבחור Google Cloud אזורים לפריסה גלובלית ואיך לבחור Google Cloud שירותים מתאימים. Google Cloud

בחירת אזור

כשבוחרים את Google Cloud האזורים שבהם צריך לפרוס את האפליקציות, חשוב לקחת בחשבון את הגורמים והדרישות הבאים:

יכול להיות שחלק מהגורמים והדרישות האלה יחייבו פשרות. לדוגמה, יכול להיות שאזור שבו העלות היא הכי נמוכה לא יהיה האזור עם טביעת הרגל הפחמנית הכי נמוכה. למידע נוסף, ראו שיטות מומלצות לבחירת אזורים ב-Compute Engine.

תשתית מחשוב

בארכיטקטורת ההפניה שבמסמך הזה נעשה שימוש במכונות וירטואליות של Compute Engine עבור רמות מסוימות של האפליקציה. בהתאם לדרישות של האפליקציה, אפשר לבחור מבין שירותי מחשוב אחרים: Google Cloud

  • קונטיינרים: אתם יכולים להריץ אפליקציות בקונטיינרים באשכולות של Google Kubernetes Engine‏ (GKE). ‫GKE הוא מנוע לתזמור קונטיינרים שמבצע אוטומטית פריסה, התאמה לעומס וניהול של אפליקציות בקונטיינרים.
  • Serverless: אם אתם מעדיפים להתמקד בנתונים ובאפליקציות שלכם במקום בהגדרה ובהפעלה של משאבי תשתית, אתם יכולים להשתמש בשירותי Serverless כמו Cloud Run.

ההחלטה אם להשתמש במכונות וירטואליות, במאגרי מידע או בשירותים ללא שרתים כרוכה בפשרה בין גמישות ההגדרה לבין מאמצי הניהול. מכונות וירטואליות וקונטיינרים מספקים גמישות רבה יותר בהגדרות, אבל אתם אחראים לניהול המשאבים. בארכיטקטורה ללא שרת (serverless), אתם פורסים עומסי עבודה בפלטפורמה שהוגדרה מראש ודורשת מינימום מאמץ ניהולי. מידע נוסף על בחירת שירותי מחשוב מתאימים לעומסי העבודה ב-Google Cloudזמין במאמר אירוח אפליקציות ב- Google Cloud.

שירותי אחסון

בארכיטקטורה שמוצגת במסמך הזה נעשה שימוש בנפחי Persistent Disk אזוריים למכונות הווירטואליות. אמצעי אחסון של Persistent Disk אזורי מספקים שכפול סינכרוני של נתונים בשני אזורים בתוך אזור. הנתונים בנפחי אחסון Persistent Disk לא משוכפלים בין אזורים.

Google Cloud Hyperdisk מספק ביצועים טובים יותר, גמישות ויעילות בהשוואה ל-Persistent Disk. עם Hyperdisk Balanced, אתם יכולים להקצות IOPS וקצב העברת נתונים בנפרד ובאופן דינמי, וכך להתאים את נפח האחסון למגוון רחב של עומסי עבודה.

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

  • הנתונים בקטגוריות אזוריות משוכפלים באופן סינכרוני באזורים.
  • נתונים בקטגוריות של שני אזורים או מספר אזורים מאוחסנים ביתירות בשני מיקומים גיאוגרפיים נפרדים לפחות. מטא-נתונים נכתבים באופן סינכרוני באזורים שונים, והנתונים משוכפלים באופן אסינכרוני. בקטגוריות של שני אזורים, אפשר להשתמש ברפליקציה בקצב טורבו, שמבטיחה שאובייקטים ישוכפלו בין זוגות של אזורים, עם יעד להתאוששות מאסון (RPO) של 15 דקות. מידע נוסף זמין במאמר בנושא זמינות ועמידות של נתונים.

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

אם מסד הנתונים שלכם הוא Microsoft SQL Server, מומלץ להשתמש ב-Cloud SQL ל-SQL Server. בתרחישים שבהם Cloud SQL לא תומך בדרישות ההגדרה שלכם, או אם אתם צריכים גישה למערכת ההפעלה, אתם יכולים לפרוס מכונה של Microsoft SQL Server failover cluster instance (FCI). בתרחיש הזה, אפשר להשתמש ב-Google Cloud NetApp Volumes, שירות מנוהל לחלוטין, כדי לספק אחסון SMB עם זמינות רציפה (CA) למסד הנתונים.

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

שירותי מסדי נתונים

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

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

עיצוב רשת

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

אפשרויות לאיזון עומסים חיצוני

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

אם האפליקציה שלכם דורשת סיום של Transport Layer Security ‏ (TLS) באזור ספציפי, או אם אתם צריכים את האפשרות להציג תוכן מאזורים ספציפיים, אתם יכולים להשתמש במאזני עומסים אזוריים עם Cloud DNS כדי לנתב תעבורה לאזורים שונים. למידע על ההבדלים בין מאזני עומסים אזוריים לבין מאזני עומסים גלובליים, אפשר לעיין במסמכים הבאים:

אבטחה, פרטיות ותאימות

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

הגנה מפני איומים חיצוניים

כדי להגן על האפליקציה מפני איומים כמו התקפות מניעת שירות מבוזרות (DDoS) ופרצות אבטחה XSS‏ (cross-site scripting), אפשר להשתמש במדיניות אבטחה של Google Cloud Armor. כל מדיניות היא קבוצת כללים שמפרטת תנאים מסוימים שצריך לבדוק ופעולות שצריך לבצע כשהתנאים מתקיימים. לדוגמה, כלל יכול לציין שאם כתובת ה-IP של המקור של התנועה הנכנסת תואמת לכתובת IP ספציפית או לטווח CIDR, אז צריך לדחות את התנועה. אפשר גם להחיל כללים מוגדרים מראש של חומת אש לאפליקציות אינטרנט (WAF). מידע נוסף זמין במאמר סקירה כללית של מדיניות האבטחה.

גישה חיצונית למכונות וירטואליות

בארכיטקטורת ההפניה שמתוארת במסמך הזה, המכונות הווירטואליות ב-Compute Engine לא צריכות גישה נכנסת מהאינטרנט. לא מקצים כתובות IP חיצוניות למכונות הווירטואליות. Google Cloud משאבים שיש להם רק כתובת IP פנימית פרטית עדיין יכולים לגשת לשירותים ולממשקי Google API מסוימים באמצעות Private Service Connect או גישה פרטית ל-Google. מידע נוסף זמין במאמר אפשרויות גישה פרטיות לשירותים.

כדי להפעיל חיבורים יוצאים מאובטחים מ Google Cloud משאבים שיש להם רק כתובות IP פרטיות, כמו המכונות הווירטואליות של Compute Engine בארכיטקטורת ההפניה הזו, אפשר להשתמש ב-Secure Web Proxy או ב-Cloud NAT.

הרשאות בחשבון שירות

במקום להשתמש בחשבונות השירות שמוגדרים כברירת מחדל, מומלץ ליצור חשבונות שירות ייעודיים למכונות הווירטואליות של Compute Engine בארכיטקטורה ולציין את המשאבים שלחשבון השירות תהיה גישה אליהם. לחשבון השירות שמוגדר כברירת מחדל יש מגוון רחב של הרשאות, כולל הרשאות שאולי לא נחוצות. אתם יכולים להתאים חשבונות שירות ייעודיים כך שיהיו להם רק ההרשאות החיוניות. מידע נוסף זמין במאמר הגבלת ההרשאות של חשבון שירות.

אבטחת SSH

כדי לשפר את האבטחה של חיבורי SSH למכונות וירטואליות של Compute Engine בארכיטקטורה שלכם, כדאי להטמיע שרת proxy לאימות זהויות (IAP) וממשק API של Cloud OS Login. ‫IAP מאפשר לכם לשלוט בגישה לרשת על סמך זהות המשתמשים ומדיניות ניהול הזהויות והרשאות הגישה (IAM). ‫Cloud OS Login API מאפשר לכם לשלוט בגישת SSH ל-Linux על סמך זהות המשתמש ומדיניות IAM. מידע נוסף על ניהול גישה לרשת זמין במאמר שיטות מומלצות לשליטה בגישה להתחברות באמצעות SSH.

שיקולי אבטחה נוספים

כשמפתחים את הארכיטקטורה של עומס העבודה, כדאי להביא בחשבון את השיטות המומלצות וההמלצות לאבטחה ברמת הפלטפורמה שמפורטות בתוכנית לניהול יסודות האבטחה בארגון ובGoogle Cloud מסגרת Well-Architected: יסודות האבטחה, הפרטיות והתאימות.

אמינות

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

התאמה אוטומטית לעומס (autoscaling) של MIG

כשמריצים את האפליקציה בכמה קבוצות אזוריות של MIG, האפליקציה נשארת זמינה במהלך הפסקות חשמל באזורים מבודדים או באזורים. היכולת של קבוצות MIG בלי שמירת מצב (stateless) להתאמה אוטומטית לעומס מאפשרת לכם לשמור על זמינות וביצועים של האפליקציה ברמות צפויות.

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

מגבלת הגודל של MIG

כשמחליטים על הגודל של קבוצות ה-MIG, צריך לקחת בחשבון את מגבלות ברירת המחדל והמגבלות המקסימליות על מספר המכונות הווירטואליות שאפשר ליצור בקבוצת MIG. מידע נוסף זמין במאמר הוספה והסרה של מכונות וירטואליות מקבוצת מופעי מכונה מנוהלים (MIG).

תיקון אוטומטי של מכונות וירטואליות

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

מיקום ה-VM

בארכיטקטורה שמתוארת במסמך הזה, רמת האפליקציה ורמת האינטרנט פועלות במכונות וירטואליות של Compute Engine שמפוזרות על פני אזורים רבים. ההפצה הזו מבטיחה שהאפליקציה שלכם תהיה עמידה בפני הפסקות חשמל באזורים.

כדי לשפר את החוסן של הארכיטקטורה, אפשר ליצור מדיניות למיקום מרווח ולהחיל אותה על תבנית ה-MIG. כשקבוצת ה-MIG יוצרת מכונות וירטואליות, היא ממקמת אותן בכל אזור בשרתים פיזיים שונים (שנקראים מארחים), כך שהמכונות הווירטואליות עמידות בפני כשלים של מארחים ספציפיים. מידע נוסף זמין במאמר בנושא יצירה והחלה של מדיניות בנושא מיקום מודעות במכונות וירטואליות.

תכנון הקיבולת של מכונות וירטואליות

כדי לוודא שהקיבולת של מכונות וירטואליות ב-Compute Engine תהיה זמינה כשצריך להקצות מכונות וירטואליות, אפשר ליצור שמירת מקום. הזמנה מספקת קיבולת מובטחת באזור ספציפי למספר מסוים של מכונות וירטואליות מסוג מכונה שתבחרו. אפשר להגדיר הזמנה לפרויקט ספציפי, או לשתף אותה בין כמה פרויקטים. מידע נוסף על הזמנות זמין במאמר בנושא בחירת סוג הזמנה.

אחסון עם שמירת מצב

שיטה מומלצת בתכנון אפליקציות היא להימנע מהצורך בדיסקים מקומיים עם שמירת מצב. אבל אם הדרישה קיימת, אפשר להגדיר את הדיסקים המתמידים כך שיהיו בעלי מצב (stateful) כדי להבטיח שהנתונים יישמרו כשמכונות וירטואליות מתוקנות או נוצרות מחדש. עם זאת, מומלץ להשאיר את דיסקי האתחול בלי שמירת מצב, כדי שתוכלו לעדכן אותם לתמונות העדכניות ביותר עם גרסאות חדשות ותיקוני אבטחה. מידע נוסף זמין במאמר בנושא הגדרת דיסקים קשיחים מתמידים עם שמירת מצב בקבוצות של מכונות וירטואליות לניהול מופעים (MIG).

עמידות הנתונים

אתם יכולים להשתמש ב-Backup and DR כדי ליצור גיבויים של מכונות וירטואליות ב-Compute Engine, לאחסן אותם ולנהל אותם. שירות Backup and DR מאחסן נתוני גיבוי בפורמט המקורי שניתן לקריאה על ידי האפליקציה. כשנדרש, אתם יכולים לשחזר את עומסי העבודה שלכם לסביבת הייצור באמצעות נתונים מאחסון גיבוי לטווח ארוך, בלי שתצטרכו להכין או להעביר נתונים.

‫Compute Engine מספק את האפשרויות הבאות כדי לעזור לכם לוודא שהנתונים שמאוחסנים בכרכים של Persistent Disk יהיו עמידים:

מהימנות מסד הנתונים

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

  • ארבעה עותקים לקריאה ולכתיבה באזורים נפרדים בשני אזורים.
  • רפליקת עֵד באזור שלישי.

פעולת כתיבה למופע Spanner של כמה אזורים מקבלת אישור אחרי שלפחות שלוש רפליקות – באזורים נפרדים בשני אזורים – ביצעו את הפעולה. אם מתרחש כשל באזור או בתחום, ל-Spanner יש גישה לכל הנתונים, כולל נתונים מפעולות הכתיבה האחרונות, והוא ממשיך לטפל בבקשות קריאה וכתיבה.

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

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

שיקולים נוספים בנושא מהימנות

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

הוזלת עלויות

בקטע הזה מוסבר איך לבצע אופטימיזציה של העלות של הגדרת טופולוגיה גלובלית של Google Cloud והפעלתה, שאתם בונים באמצעות ארכיטקטורת ההפניה הזו.

סוגי מכונות וירטואליות

כדי לעזור לכם לייעל את השימוש במשאבים של המכונות הווירטואליות, ב-Compute Engine יש המלצות לסוגי מכונות. אפשר להשתמש בהמלצות כדי לבחור סוגי מכונות שתואמים לדרישות החישוב של עומס העבודה. אם אתם יכולים לחזות את הצורך שלכם במשאבים בעומסי העבודה, אתם יכולים להתאים אישית את סוג המכונה לצרכים שלכם ולחסוך כסף באמצעות סוגי מכונות בהתאמה אישית.

מודל הקצאת הרשאות ל-VM

אם האפליקציה שלכם סובלת תקלות, מכונות וירטואליות זמניות יכולות לעזור לכם לצמצם את העלויות של Compute Engine עבור המכונות הווירטואליות בשכבות של האפליקציה והאינטרנט. העלות של מכונות Spot VM נמוכה משמעותית מזו של מכונות וירטואליות רגילות. עם זאת, יכול להיות ש-Compute Engine יפסיק או ימחק מכונות וירטואליות מסוג Spot באופן יזום כדי לפנות קיבולת.

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

ניצול משאבים של מכונות וירטואליות

היכולת של קבוצות MIG ללא מצב (stateless) לבצע התאמה אוטומטית לעומס מאפשרת לאפליקציה לטפל בעלייה בתנועה בצורה חלקה, ועוזרת לצמצם את העלויות כשאין צורך במשאבים. אי אפשר להגדיל או להקטין את הגודל של קבוצות מנוהלות עם שמירת מצב באופן אוטומטי.

עלות מסד הנתונים

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

רישוי צד שלישי

כשמעבירים עומסי עבודה של צד שלישי אל Google Cloud, יכול להיות שאפשר יהיה להוזיל את העלויות באמצעות שימוש ברישיונות משלכם (BYOL). לדוגמה, כדי לפרוס מכונות וירטואליות של Microsoft Windows Server, במקום להשתמש באימג' פרימיום שכולל עלות נוספת לרישיון של צד שלישי, אפשר ליצור ולהשתמש באימג' BYOL מותאם אישית של Windows. לאחר מכן משלמים רק על תשתית המכונה הווירטואלית שבה משתמשים ב- Google Cloud. האסטרטגיה הזו עוזרת לכם להמשיך להפיק ערך מההשקעות הקיימות שלכם ברישיונות של צד שלישי. אם תבחרו להשתמש בגישת BYOL, ההמלצות הבאות עשויות לעזור לכם להקטין את העלויות:

אם אתם פורסים מסד נתונים של צד שלישי כמו Microsoft SQL Server במכונות וירטואליות של Compute Engine, אתם צריכים לקחת בחשבון את עלויות הרישיון של תוכנת הצד השלישי. כשמשתמשים בשירות מסד נתונים מנוהל כמו Cloud SQL, עלויות הרישיון של מסד הנתונים כלולות בחיובים על השירות.

שיקולי עלות נוספים

כשיוצרים את הארכיטקטורה של עומס העבודה, כדאי גם לעיין בשיטות המומלצות ובהמלצות הכלליות שמופיעות במאמר Google Cloud Well-Architected Framework: הוזלת העלויות.

יעילות תפעולית

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

עדכוני הגדרות של מכונות וירטואליות

כדי לעדכן את ההגדרה של ה-VMs בקבוצת MIG (למשל סוג המכונה או אימג' של דיסק האתחול), יוצרים תבנית של הגדרות מכונה חדשה עם ההגדרה הנדרשת ואז מחילים את התבנית החדשה על קבוצת ה-MIG. ה-MIG מעדכן את מכונות ה-VM באמצעות שיטת העדכון שתבחרו: אוטומטית או סלקטיבית. בוחרים שיטה מתאימה על סמך הדרישות שלכם לגבי זמינות ויעילות תפעולית. מידע נוסף על שיטות העדכון האלה של MIG זמין במאמר החלת הגדרות חדשות של מכונות וירטואליות ב-MIG.

תמונות VM

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

תבניות של הגדרות מכונה דטרמיניסטיות

אם תבניות המופעים שבהן אתם משתמשים ב-MIG כוללות סקריפטים להפעלה כדי להתקין תוכנה של צד שלישי, ודאו שהסקריפטים מציינים במפורש פרמטרים של התקנת תוכנה, כמו גרסת התוכנה. אחרת, כשה-MIG יוצר את המכונות הווירטואליות, יכול להיות שהתוכנה שמותקנת במכונות הווירטואליות לא תהיה עקבית. לדוגמה, אם תבנית של הגדרות מכונה שלכם כוללת סקריפט לטעינה בזמן ההפעלה להתקנת Apache HTTP Server 2.0 (החבילה apache2), צריך לוודא שהסקריפט מציין את הגרסה המדויקת של apache2 שצריך להתקין, כמו גרסה 2.4.53. מידע נוסף זמין במאמר תבניות דטרמיניסטיות של מכונות וירטואליות.

העברה ל-Spanner

אפשר להעביר נתונים ל-Spanner ממסדי נתונים אחרים כמו MySQL,‏ SQL Server ו-Oracle Database. תהליך ההעברה תלוי בגורמים כמו מסד הנתונים של המקור, גודל הנתונים, מגבלות לגבי זמן ההשבתה ומורכבות קוד האפליקציה. כדי לעזור לכם לתכנן ולבצע את המעבר ל-Spanner בצורה יעילה, אנחנו מספקים מגוון של Google Cloud וכלים של צד שלישי. מידע נוסף זמין במאמר בנושא סקירה כללית על העברת נתונים.

ניהול מסדי נתונים

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

שיקולים תפעוליים נוספים

כשיוצרים את הארכיטקטורה של עומס העבודה, כדאי לקחת בחשבון את השיטות המומלצות הכלליות ואת ההמלצות ליעילות תפעולית שמתוארות במאמר Google Cloud Well-Architected Framework: Operational excellence.

אופטימיזציה של הביצועים

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

ביצועי הרשת

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

ב-Compute Engine יש מגבלה לכל מכונה וירטואלית על רוחב הפס ברשת של תעבורת נתונים יוצאת. המגבלה הזו תלויה בסוג המכונה של המכונה הווירטואלית ובשאלה אם התנועה מנותבת דרך אותה רשת VPC כמו המכונה הווירטואלית של המקור. כדי לשפר את ביצועי הרשת של מכונות וירטואליות עם סוגי מכונות מסוימים, אפשר להגדיל את רוחב הפס המקסימלי של תעבורת הנתונים היוצאת (egress) על ידי הפעלת רשת Tier_1.

ביצועי מחשוב

‫Compute Engine מציע מגוון רחב של סוגי מכונות מוגדרים מראש וניתנים להתאמה אישית לעומסי העבודה שאתם מריצים במכונות וירטואליות. בוחרים סוג מכונה מתאים בהתאם לדרישות הביצועים. מידע נוסף זמין במאמר השוואה בין משפחות של מכונות ומשאבים.

ריבוי שרשורים ב-VM

כל מעבד וירטואלי (vCPU) שמוקצה למכונה וירטואלית ב-Compute Engine מיושם כריבוי נימים (multithreading) של חומרה יחידה. כברירת מחדל, שתי ליבות וירטואליות של מעבד (vCPU) חולקות ליבה פיזית של מעבד. באפליקציות שכוללות פעולות מקבילות מאוד או שמבצעות חישובים של נקודות צפות (כמו ניתוח רצפים גנטיים ומודלים של סיכונים פיננסיים), אפשר לשפר את הביצועים על ידי הקטנת מספר השרשורים שפועלים בכל ליבת CPU פיזית. מידע נוסף זמין במאמר בנושא הגדרת מספר השרשורים לכל ליבה.

לריבוי הליכי משנה במכונה וירטואלית עשויות להיות השלכות על הרישוי של תוכנות מסוימות של צד שלישי, כמו מסדי נתונים. מידע נוסף זמין במסמרי העזרה בנושא רישוי של תוכנות צד שלישי.

Network Service Tiers

מסלולי שירות הרשת מאפשרים לכם לבצע אופטימיזציה של העלות והביצועים של עומסי העבודה ברשת. אתם יכולים לבחור במסלול פרימיום או במסלול רגיל. במסלול הפרימיום, תעבורת הנתונים עוברת דרך תשתית הפרימיום הגלובלית של Google כדי להשיג איבוד מינימלי של מנות וזמן אחזור נמוך. במסלול הרגיל, תעבורת הנתונים מועברת באמצעות קישור בין רשתות שכנות (peering), ספקי אינטרנט (ISP) או רשתות העברה בנקודת קצה PoP שהכי קרובה לאזור שבו פועלת עומס העבודה שלכם Google Cloud . כדי לבצע אופטימיזציה של הביצועים, מומלץ להשתמש במסלול פרימיום. כדי לבצע אופטימיזציה של העלות, מומלץ להשתמש במסלול הרגיל.

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

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

ביצועים ב-Spanner

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

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

המלצות לאופטימיזציה של הביצועים של מופע Spanner ומסדי נתונים מופיעות במסמכים הבאים:

שמירה במטמון

אם האפליקציה שלכם מציגה נכסים של אתר סטטי והארכיטקטורה שלכם כוללת מאזן עומסים חיצוני גלובלי של אפליקציות (ALB), אתם יכולים להשתמש ב-Cloud CDN כדי לשמור במטמון תוכן סטטי שמתבצעת אליו גישה באופן קבוע, במיקום קרוב יותר למשתמשים. ‫Cloud CDN יכול לעזור לשפר את הביצועים עבור המשתמשים, להפחית את השימוש במשאבי התשתית בקצה העורפי ולהפחית את עלויות המסירה ברשת. מידע נוסף זמין במאמר בנושא שיפור הביצועים של אתרים והגנה משופרת על אתרים לצורך איזון עומסים.

שיקולי ביצועים נוספים

כשיוצרים את הארכיטקטורה של עומס העבודה, כדאי לפעול לפי השיטות המומלצות וההמלצות הכלליות שמופיעות במאמר Google Cloud Well-Architected Framework: Performance optimization.

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

שותפים ביצירת התוכן

מחברים:

תורמי תוכן אחרים: