בדף הזה מופיעות שתי דוגמאות למאזן עומסים קלאסי של אפליקציות (ALB):
כדי להגדיר ניהול תנועה למאזן עומסים גלובלי חיצוני של אפליקציות ולמאזן עומסים אזורי חיצוני של אפליקציות, אפשר לעיין בדפים הבאים:
- הגדרה של ניהול תעבורה עבור מאזן עומסים גלובלי חיצוני של אפליקציות (ALB)
- הגדרת ניהול תעבורה למאזן עומסים אזורי חיצוני של אפליקציות
לפני שמתחילים
הגדרה של ניתוב שמבוסס על פרמטרים של שאילתה
בדוגמה הזו מוצג שימוש בפרמטרים של שאילתה כדי לבצע בדיקות A/B על ידי התאמה למחרוזת השאילתה.
הוספה של שתי קבוצות של שרתים עורפיים
כדי שהניתוב יהיה שימושי, צריך להגדיר כמה בק-אנדים.
כדי להגדיר שני קצוות עורפיים, מכונות ה-VM צריכות להיות בשתי קבוצות של מכונות. במדריך הזה מוסבר איך ליצור קבוצות של מופעי מכונה מנוהלים עם מכונות וירטואליות של Linux שמופעל בהן Apache, ואז להגדיר איזון עומסים.
קבוצות של מופעי מכונה מנוהלים מספקות מכונות וירטואליות שמריצות את שרתי הבק-אנד של מאזן עומסים חיצוני מסוג HTTP. למטרות הדגמה, שרתי קצה עורפיים מציגים את שמות המארחים שלהם.
לצורך פשטות, שרתי הבק-אנד נמצאים באותו אזור. אם רוצים להגדיר מספר אזורים, צריך להגדיר תבנית של הגדרות מכונה עבור האזור השני.
המסוף
יוצרים תבנית של הגדרות מכונה. נכנסים לדף Instance templates במסוף Google Cloud .
- לוחצים על Create instance template.
- בשדה Name (שם), מזינים
lb-backend-template. - מוודאים שדיסק האתחול מוגדר לקובץ אימג' של Debian, כמו Debian GNU/Linux 12 (bookworm). בהוראות האלה נעשה שימוש בפקודות שזמינות רק ב-Debian, כמו
apt-get. - לוחצים על אפשרויות מתקדמות.
- לוחצים על Networking ומגדירים את השדה הבא:
- בשדה Network tags (תגי רשת), מזינים
allow-health-check.
- בשדה Network tags (תגי רשת), מזינים
לוחצים על ניהול. מזינים את הסקריפט הבא בשדה סקריפט לטעינה בזמן ההפעלה.
#! /bin/bash apt-get update apt-get install apache2 -y a2ensite default-ssl a2enmod ssl vm_hostname="$(curl -H "Metadata-Flavor:Google" \ http://metadata.google.internal/computeMetadata/v1/instance/name)" echo "Page served from: $vm_hostname" | \ tee /var/www/html/index.html systemctl restart apache2
לוחצים על יצירה.
יוצרים קבוצה של מופעי מכונה מנוהלים. נכנסים לדף Instance groups במסוף Google Cloud .
- לוחצים על יצירת קבוצת מופעים.
- בוחרים באפשרות New managed instance group (stateless) (קבוצת מופעי מכונה מנוהלים חדשה (בלי שמירת מצב)). מידע נוסף מופיע במאמר קבוצות של מכונות וירטואליות בלי שמירת מצב או עם שמירת מצב.
- בשדה Name (שם), מזינים
first-example-ig. - בקטע מיקום, בוחרים באפשרות אזור יחיד.
- בקטע Region (אזור), בוחרים את האזור המועדף. בדוגמה הזו נשתמש ב-
us-east1. - בשדה Zone, בוחרים באפשרות
us-east1-b. - בקטע תבנית של הגדרות מכונה, בוחרים את תבנית המכונה
lb-backend-template. - בקטע מספר מקסימלי של מופעים, מזינים
2. - בקטע מצב שינוי גודל אוטומטי, בוחרים באפשרות
Off:do not autoscale. - לוחצים על יצירה.
יוצרים עוד קבוצת מופעי מכונה מנוהלים כמו זו. נותנים לשני שם second-example-ig ומגדירים אותו על בסיס התבנית lb-backend-template.
gcloud
יוצרים תבנית של הגדרות מכונה.
gcloud compute instance-templates create lb-backend-template \ --region=us-east1 \ --network=default \ --subnet=default \ --tags=allow-health-check \ --image-family=debian-12 \ --image-project=debian-cloud \ --metadata=startup-script='#! /bin/bash apt-get update apt-get install apache2 -y a2ensite default-ssl a2enmod ssl vm_hostname="$(curl -H "Metadata-Flavor:Google" \ http://metadata.google.internal/computeMetadata/v1/instance/name)" echo "Page served from: $vm_hostname" | \ tee /var/www/html/index.html systemctl restart apache2'יוצרים את קבוצת מופעי המכונה המנוהלים הראשונה על סמך התבנית.
gcloud compute instance-groups managed create first-example-ig \ --template=lb-backend-template --size=2 --zone=us-east1-b
יוצרים את קבוצת מופעי המכונה המנוהלים השנייה על סמך התבנית.
gcloud compute instance-groups managed create second-example-ig \ --template=lb-backend-template --size=2 --zone=us-east1-c
הגדרת כלל לחומת אש
בדוגמה הזו, יוצרים את כלל חומת האש fw-allow-health-check.
זהו כלל כניסה שמאפשר תנועה ממערכות בדיקת תקינות (130.211.0.0/22 ו-35.191.0.0/16). בדוגמה הזו נעשה שימוש בתג היעד allow-health-check כדי לזהות את המכונות הווירטואליות. Google Cloud
המסוף
- נכנסים לדף Firewall policies במסוף Google Cloud .
מעבר אל Firewall policies - לוחצים על יצירת כלל לחומת האש כדי ליצור את הכלל השני לחומת האש:
- מזינים שם של
fw-allow-health-check. - בקטע רשת, בוחרים באפשרות
Default. - בקטע יעדים, בוחרים באפשרות תגי יעד ספציפיים.
- בשדה Target tags [תגי יעד] כותבים
allow-health-check. - מגדירים את Source filter בתור IPv4 ranges.
- מגדירים את Source IPv4 ranges (טווחים של כתובות IPv4 של המקור) ל-
130.211.0.0/22ול-35.191.0.0/16. - בקטע Protocols and ports (פרוטוקולים ויציאות), בוחרים באפשרות Specified protocols and ports (פרוטוקולים ויציאות ספציפיים).
- מסמנים את תיבת הסימון TCP ומזינים
80כמספרי היציאות. - לוחצים על יצירה.
gcloud
gcloud compute firewall-rules create fw-allow-health-check \
--network=default \
--action=allow \
--direction=ingress \
--source-ranges=130.211.0.0/22,35.191.0.0/16 \
--target-tags=allow-health-check \
--rules=tcp
שמירת כתובת IP חיצונית
עכשיו, כשהמופעים פועלים, צריך להגדיר כתובת IP חיצונית סטטית גלובלית שהלקוחות משתמשים בה כדי להגיע למאזן העומסים.
המסוף
- נכנסים לדף כתובות IP חיצוניות במסוף Google Cloud .
עבור לדף כתובות IP חיצוניות - לוחצים על Reserve static address כדי לשריין כתובת IPv4.
- מקצים שם של
lb-ipv4-1. - מגדירים את מסלול הרשת ל-Standard.
- מגדירים את IP version ל-IPv4.
- מגדירים את Type (סוג) בתור Global (גלובלי).
- לוחצים על Reserve.
- מוודאים שהערך של סוג מוגדר לGlobal.
- לוחצים על Reserve.
gcloud
gcloud compute addresses create lb-ipv4-1 \
--ip-version=IPV4 \
--network-tier=PREMIUM \
--global
שימו לב לכתובת ה-IPv4 שהוקצתה:
gcloud compute addresses describe lb-ipv4-1 \
--format="get(address)" \
--global
הגדרת הקצה העורפי של מאזן העומסים
המסוף
בשלב הזה, אין תמיכה בהגדרת ניתוב שמבוסס על כותרות ועל פרמטרים במסוף Google Cloud . במקום זאת, אפשר להשתמש ב-gcloud או ב-API.
gcloud
- יוצרים בדיקת תקינות.
gcloud compute health-checks create http http-basic-check \ --port 80 - יוצרים את שירות לקצה העורפי הראשון.
-
במאזן עומסים גלובלי חיצוני של אפליקציות, משתמשים בפקודת ה-CLI של gcloud עם
load-balancing-scheme=EXTERNAL_MANAGED. ההגדרה הזו מציעה יכולת מתקדמת לניהול תנועה. - במאזן עומסים קלאסי של אפליקציות (ALB), משתמשים ב-
load-balancing-scheme=EXTERNAL.
gcloud compute backend-services create service-a \ --load-balancing-scheme=LOAD_BALANCING_SCHEME \ --global-health-checks \ --protocol HTTP \ --health-checks http-basic-check \ --global -
במאזן עומסים גלובלי חיצוני של אפליקציות, משתמשים בפקודת ה-CLI של gcloud עם
- יוצרים את שירות לקצה העורפי השני.
gcloud compute backend-services create service-b \ --load-balancing-scheme=LOAD_BALANCING_SCHEME \ --global-health-checks \ --protocol HTTP \ --health-checks http-basic-check \ --global - מוסיפים את קבוצת המופעים הראשונה כקצה העורפי לשירות הקצה העורפי הראשון.
gcloud compute backend-services add-backend service-a \ --balancing-mode=UTILIZATION \ --max-utilization=0.8 \ --capacity-scaler=1 \ --instance-group=first-example-ig \ --instance-group-zone=us-east1-b \ --global - מוסיפים את קבוצת המכונות השנייה בתור הקצה העורפי לשירות השני לקצה העורפי.
gcloud compute backend-services add-backend service-b \ --balancing-mode=UTILIZATION \ --max-utilization=0.8 \ --capacity-scaler=1 \ --instance-group=second-example-ig \ --instance-group-zone=us-east1-c \ --global
יצירת מפת URL
המסוף
בשלב הזה, אין תמיכה בהגדרת ניתוב שמבוסס על כותרות ועל פרמטרים במסוף Google Cloud . במקום זאת, אפשר להשתמש ב-gcloud או ב-API.
gcloud
יוצרים קובץ YAML
/tmp/web-map-http.yaml. מחליפים אתPROJECT_IDבמזהה הפרויקט.defaultService: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a hostRules: - hosts: - '*' pathMatcher: path-matcher-1 name: web-map-http pathMatchers: - defaultService: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a name: path-matcher-1 routeRules: - matchRules: - prefixMatch: / queryParameterMatches: - name: ABTest exactMatch: A priority: 0 service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a - matchRules: - prefixMatch: / queryParameterMatches: - name: ABTest exactMatch: B priority: 1 service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-b selfLink: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/urlMaps/web-map-http tests: - description: Test routing for query ABTest with A host: example.com path: /?ABTest=A service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a expectedOutputUrl: http://example.com/?ABTest=A - description: Test routing for query ABTest with B host: example.com path: /?ABTest=B service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-b expectedOutputUrl: http://example.com/?ABTest=Bמאמתים את מפת ה-URL.
gcloud compute url-maps validate --source /tmp/web-map-http.yaml
אם הבדיקות עוברות והפקודה מוציאה הודעת הצלחה, שומרים את השינויים במפת URL.
מעדכנים את מפת ה-URL.
gcloud compute url-maps import web-map-http \ --source /tmp/web-map-http.yaml \ --global
יצירת שרת proxy ליעד וכלל העברה
המסוף
בשלב הזה, אין תמיכה בהגדרת ניתוב שמבוסס על כותרות ועל פרמטרים במסוף Google Cloud . במקום זאת, אפשר להשתמש ב-gcloud או ב-API.
gcloud
- יוצרים HTTP proxy ליעד כדי להפנות בקשות למפת URL.
gcloud compute target-http-proxies create http-lb-proxy \ --url-map web-map-http - יוצרים כלל העברה גלובלי כדי לנתב בקשות נכנסות לשרת ה-Proxy.
-
במאזן עומסים גלובלי חיצוני של אפליקציות, משתמשים בפקודת ה-CLI של gcloud עם
load-balancing-scheme=EXTERNAL_MANAGED. ההגדרה הזו מציעה יכולת מתקדמת לניהול תנועה. - במאזן עומסים קלאסי של אפליקציות (ALB), משתמשים ב-
load-balancing-scheme=EXTERNAL.
gcloud compute forwarding-rules create http-content-rule \ --load-balancing-scheme=LOAD_BALANCING_SCHEME \ --network-tier=PREMIUM \ --address=lb-ipv4-1 \ --global \ --target-http-proxy=http-lb-proxy \ --ports=80 -
במאזן עומסים גלובלי חיצוני של אפליקציות, משתמשים בפקודת ה-CLI של gcloud עם
בדיקה
שימו לב לכתובת ה-IPv4 שהוקצתה:
gcloud compute addresses describe lb-ipv4-1 \
--format="get(address)" \
--global
מריצים את הפקודה הבאה כדי לבדוק את ההגדרה:
curl http://IP_ADDRESS?ABTest=A
curl http://IP_ADDRESS?ABTest=B
פותחים בדפדפן את http://IP_ADDRESS?ABTest=A ואת http://IP_ADDRESS?ABTest=B.
הגדרה של ניתוב שמבוסס על כותרות HTTP
בדוגמה הזו אפשר לראות איך מוסיפים ומסירים כותרות HTTP כדי לבצע ניתוב חכם.
לפני שמתחילים
אפשר להשתמש במאזן עומסים חיצוני של אפליקציות (ALB) או ליצור חדש.
אפשר להשתמש בתכונה הזו עם כל סוגי ה-Backend הנתמכים. בדוגמה הזו ההנחה היא שאתם משתמשים במכונות וירטואליות בקבוצת מופעים.
כדי להגדיר מאזן עומסים פשוט, אפשר לעיין בדוגמה שמבוססת על פרמטר של שאילתה שמופיעה למעלה.
עדכון מפת URL
המסוף
בשלב הזה, אין תמיכה בהגדרת ניתוב שמבוסס על כותרות ועל פרמטרים במסוף Google Cloud . במקום זאת, אפשר להשתמש ב-gcloud או ב-API.
gcloud
בדוגמה הזו מוצג שימוש בכותרות של בקשות HTTP כדי לבצע בדיקות A/B על ידי התאמה לערכים בכותרות ה-HTTP של הבקשה.
יוצרים קובץ YAML
/tmp/web-map-http.yaml. מחליפים אתPROJECT_IDבמזהה הפרויקט.defaultService: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a kind: compute#urlMap name: web-map-http hostRules: - hosts: - '*' pathMatcher: path-matcher-1 pathMatchers: - defaultService: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a name: path-matcher-1 routeRules: - matchRules: - prefixMatch: / headerMatches: - headerName: ABTest exactMatch: A priority: 0 service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a - matchRules: - prefixMatch: / headerMatches: - headerName: ABTest exactMatch: B priority: 1 service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-b tests: - description: Test routing for query ABTest with A host: example.com path: / headers: - name: ABTest value: A service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-a - description: Test routing for query ABTest with B host: example.com path: / headers: - name: ABTest value: B service: https://www.googleapis.com/compute/v1/projects/PROJECT_ID/global/backendServices/service-bמאמתים את מפת ה-URL.
gcloud compute url-maps validate --source /tmp/web-map-http.yaml
אם הבדיקות עוברות והפקודה מוציאה הודעת הצלחה, שומרים את השינויים במפת URL.
מעדכנים את מפת ה-URL.
gcloud compute url-maps import web-map-http \ --source /tmp/web-map-http.yaml \ --global
בדיקה
כדי לבדוק את ההגדרה הזו, מריצים את הפקודה הבאה באמצעות כתובת ה-IPv4 של מאזן העומסים המשויך:
curl http://IP_ADDRESS -H "ABTest: A"
curl http://IP_ADDRESS -H "ABTest: B"