בדף הזה מוסבר איך לפרוס שירות LoadBalancer חיצוני שיוצר מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות backend. לפני שקוראים את הדף הזה, חשוב לוודא שאתם מכירים את הנושאים הבאים:
מידע נוסף על מאזני עומסי רשת חיצוניים להעברת סיגנל ללא שינוי זמין במאמר מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות לקצה העורפי.
לפני שמתחילים
לפני שמתחילים, חשוב לוודא שביצעתם את הפעולות הבאות:
- מפעילים את ממשק ה-API של Google Kubernetes Engine. הפעלת Google Kubernetes Engine API
- אם רוצים להשתמש ב-CLI של Google Cloud למשימה הזו, צריך להתקין ואז להפעיל את ה-CLI של gcloud. אם התקנתם בעבר את ה-CLI של gcloud, מריצים את הפקודה
gcloud components updateכדי לקבל את הגרסה העדכנית. יכול להיות שגרסאות קודמות של ה-CLI של gcloud לא יתמכו בהרצת הפקודות שמופיעות במסמך הזה.
דרישות
צריך להפעיל את התוסף
HttpLoadBalancingבאשכול. התוסף הזה מופעל כברירת מחדל. היא מאפשרת לאשכול לנהל מאזני עומסים שמשתמשים בשירותי קצה עורפי.כדי ליצור שירות LoadBalancer חיצוני שמשתמש במאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות קצה עורפי, אשכול GKE צריך להשתמש בגרסה 1.25.5 ואילך.
כדי ליצור שירות LoadBalancer חיצוני שמשתמש באיזון עומסים משוקלל, אשכול GKE צריך להשתמש בגרסה 1.31.0-gke.1506000 ואילך.
כדי ליצור שירות LoadBalancer חיצוני שמשתמש בקצה עורפי של
GCE_VM_IPקבוצת נקודות קצה ברשת (NEG), אשכול GKE צריך להשתמש בגרסה 1.32.2-gke.1652000 ואילך.
בחירת אשכול
אתם יכולים ליצור אשכול חדש או לבחור אשכול קיים שעומד בדרישות.
יצירת אשכול חדש
Autopilot
כדי ליצור אשכול חדש של Autopilot:
gcloud container clusters create-auto CLUSTER_NAME \
--release-channel=RELEASE_CHANNEL \
--cluster-version=VERSION \
--location=COMPUTE_LOCATION
מחליפים את מה שכתוב בשדות הבאים:
-
CLUSTER_NAME: השם של האשכול החדש. -
RELEASE_CHANNEL: השם של ערוץ ההפצה של GKE לאשכול. -
VERSION: גרסת GKE של האשכול. -
COMPUTE_LOCATION: האזור של Compute Engine של האשכול.
כדי להשבית את היצירה האוטומטית של כללי חומת אש של VPC עבור שירותי LoadBalancer, צריך לכלול את הדגל --disable-l4-lb-firewall-reconciliation. מידע נוסף זמין במאמר כללים של חומת אש בניהול המשתמשים בשירותי איזון עומסים של GKE.
רגילה
כדי ליצור אשכול רגיל חדש:
gcloud container clusters create CLUSTER_NAME \
--release-channel=RELEASE_CHANNEL \
--cluster-version=VERSION \
--location=COMPUTE_LOCATION
מחליפים את מה שכתוב בשדות הבאים:
-
CLUSTER_NAME: השם של האשכול החדש. -
RELEASE_CHANNEL: השם של ערוץ ההפצה של GKE לאשכול. -
VERSION: גרסת GKE של האשכול. -
COMPUTE_LOCATION: האזור של Compute Engine של האשכול.
כדי להשבית את היצירה האוטומטית של כללי חומת אש של VPC עבור שירותי LoadBalancer, צריך לכלול את הדגל --disable-l4-lb-firewall-reconciliation. מידע נוסף זמין במאמר כללים של חומת אש בניהול המשתמשים בשירותי איזון עומסים של GKE.
שדרוג של אשכול קיים
משתמשים ב-CLI של gcloud כדי לעדכן אשכול קיים:
gcloud container clusters upgrade CLUSTER_NAME \
--cluster-version=VERSION \
--master \
--location=COMPUTE_LOCATION
מחליפים את מה שכתוב בשדות הבאים:
-
CLUSTER_NAME: השם של האשכול הקיים. -
VERSION: גרסת GKE הספציפית שאליה רוצים לשדרג את האשכול. מידע נוסף זמין במאמר בנושא שדרוג ידני של מישור הבקרה. -
COMPUTE_LOCATION: האזור של Compute Engine שבו נמצא האשכול.
כדי להשבית את היצירה האוטומטית של כללי חומת אש של VPC עבור שירותי LoadBalancer, צריך לכלול את הדגל --disable-l4-lb-firewall-reconciliation. מידע נוסף זמין במאמר כללים של חומת אש בניהול המשתמשים בשירותי איזון עומסים של GKE.
פריסת עומס עבודה לדוגמה
פורסים את עומס העבודה לדוגמה הבא, שמספק את ה-Pods של השרתים עבור שירות LoadBalancer חיצוני.
שומרים את דוגמת הפריסה הבאה כ-
store-deployment.yaml:apiVersion: apps/v1 kind: Deployment metadata: name: store spec: replicas: 20 selector: matchLabels: app: store template: metadata: labels: app: store spec: containers: - image: registry.k8s.io/echoserver:1.10 imagePullPolicy: Always name: echoserver ports: - name: http containerPort: 8080 readinessProbe: httpGet: path: /healthz port: 8080 scheme: HTTPמחילים את המניפסט על האשכול:
kubectl apply -f store-deployment.yamlמוודאים שיש 20 פודים של שרתים לפריסה:
kubectl get podsהפלט אמור להיראות כך:
NAME READY STATUS RESTARTS AGE store-cdb9bb4d6-s25vw 1/1 Running 0 10s store-cdb9bb4d6-vck6s 1/1 Running 0 10s ....
יצירת שירות LoadBalancer חיצוני
חשיפת עומס העבודה לדוגמה על ידי יצירת שירות LoadBalancer חיצוני.
שומרים את מניפסט השירות הבא בשם
store-v1-lb-svc.yaml:apiVersion: v1 kind: Service metadata: name: store-v1-lb-svc annotations: cloud.google.com/l4-rbs: "enabled" spec: type: LoadBalancer selector: app: store ports: - name: tcp-port protocol: TCP port: 8080 targetPort: 8080מחילים את המניפסט על האשכול:
kubectl apply -f store-v1-lb-svc.yaml
חשוב לשים לב לנקודות הבאות לגבי קובץ המניפסט לדוגמה:
מניפסט השירות חייב לכלול את ההערה
cloud.google.com/l4-rbs: "enabled"בזמן שהמניפסט מוחל על האשכול בפעם הראשונה. הפקודה הזו מורה ל-GKE ליצור מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות לקצה העורפי. חובה להשתמש במאזני עומסים חיצוניים של רשתות להעברת סיגנל ללא שינוי שמבוססים על שירות בק-אנד כדי לתמוך בתכונות כמו IPv6 ואיזון עומסים משוקלל.ב-GKE נעשה שימוש ב-
GCE_VM_IPbackends של NEG או ב-backends של קבוצות מופעים לא מנוהלות, בהתאם לגרסת האשכול. באשכולות בגרסה 1.32.2-gke.1652000, מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות קצה עורפי משתמש ב-GCE_VM_IPNEGs. בגרסאות קודמות, מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות קצה עורפי משתמש בקבוצות של מכונות וירטואליות לא מנוהלות.אם מוסיפים את ההערה
cloud.google.com/l4-rbs: "enabled"למניפסט של קיים LoadBalancer Service חיצוני (כלומר, אחרי שמאזן העומסים נוצר), GKE מתעלם מההערה. שירותים חיצוניים של LoadBalancer שנוצרו בלי ההערה הזו במניפסטים שלהם משתמשים במאזני עומסים חיצוניים של רשת להעברת סיגנל ללא שינוי שמבוססים על מאגר יעד. לא מומלץ להשתמש במאזני עומסי רשת חיצוניים להעברת סיגנל ללא שינוי שמבוססים על מאגר כתובות יעד.
הפעלת איזון עומסים משוקלל
כדי להפיץ חיבורים חדשים באופן יחסי לצמתים על סמך מספר ה-Pods שמוכנים להצגה, מוצגים ולא מסיימים את הפעולה בכל צומת, צריך להפעיל איזון עומסים משוקלל על ידי הוספת ההערה networking.gke.io/weighted-load-balancing:
"pods-per-node" למניפסט של השירות.
מוסיפים את ההערה
networking.gke.io/weighted-load-balancing: "pods-per-node"למניפסט של שירותstore-v1-lb-svc.yaml, ומוודאים שגם הגדרתם אתexternalTrafficPolicy: Localכך שזה ייראה כך:apiVersion: v1 kind: Service metadata: name: store-v1-lb-svc annotations: cloud.google.com/l4-rbs: "enabled" networking.gke.io/weighted-load-balancing: "pods-per-node" spec: type: LoadBalancer externalTrafficPolicy: Local selector: app: store ports: - name: tcp-port protocol: TCP port: 8080 targetPort: 8080מחילים את המניפסט על האשכול:
kubectl apply -f store-v1-lb-svc.yaml
שימו לב לנקודות הבאות לגבי הדוגמה הזו של איזון עומסים משוקלל:
מניפסט השירות משתמש ב-
externalTrafficPolicy: Local. אם לא צריך להפעיל איזון עומסים משוקלל, אפשר גם להשתמש ב-externalTrafficPolicy: Cluster. לפרטים על האופן שבוexternalTrafficPolicyמגדיר קיבוץ צמתים, אילו צמתים עוברים את בדיקות התקינות של מאזן העומסים ואיך מעובדים חבילות נתונים, אפשר לעיין במאמר מושגים בנושא LoadBalancer Service.אם מפעילים איזון עומסים משוקלל, GKE לא מונע שימוש ב-
externalTrafficPolicy: Cluster, אבלexternalTrafficPolicy: Clusterמשבית למעשה את איזון העומסים המשוקלל כי יכול להיות שהמנות ינותבו, אחרי מאזן העומסים, לצומת אחר.
אפשר גם להפעיל איזון עומסים משוקלל בשירות LoadBalancer חיצוני קיים באמצעות kubectl edit svc service-name. הפקודה kubectl edit פותחת את מניפסט השירות של איזון העומסים הקיים בעורך הטקסט שהגדרתם, שבו תוכלו לשנות את המניפסט ולשמור את השינויים.
כשעורכים שירות LoadBalancer חיצוני קיים, חשוב לשים לב לנקודות הבאות:
שירות LoadBalancer חיצוני קיים חייב להוביל ליצירה של מאזני עומסים חיצוניים של רשת להעברת סיגנל ללא שינוי שמבוססים על שירות לקצה העורפי. כלומר, בשירות הקיים של איזון העומסים החיצוני חייבת להיות כלולה ההערה
cloud.google.com/l4-rbs: "enabled"כשמחילים את המניפסט על האשכול בפעם הראשונה.הוספת ההערה
networking.gke.io/weighted-load-balancing: "pods-per-node"לשירות LoadBalancer חיצוני קיים שמשתמש במאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על מאגר יעדים לא משפיעה על השירות.כשמעדכנים את המניפסט הקיים של שירות LoadBalancer חיצוני, חשוב להגדיר את
externalTrafficPolicy: Local. השימוש ב-externalTrafficPolicy: Clusterמשבית למעשה את איזון העומסים המשוקלל, כי יכול להיות שהמנות ינותבו, אחרי מאזן העומסים, לצומת אחר.
השבתה של איזון עומסים משוקלל
כדי להפיץ חיבורים חדשים לצמתים בלי קשר למספר ה-Pods של שרתים שקיימים בכל צומת, צריך להשבית את איזון העומסים המשוקלל על ידי הסרת ההערה networking.gke.io/weighted-load-balancing: "pods-per-node" ממניפסט השירות.
אימות של שירות LoadBalancer חיצוני והרכיבים שלו
מוודאים שהשירות פועל:
kubectl get svc store-v1-lb-svcהפלט אמור להיראות כך:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE store-v1-lb-svc LoadBalancer 10.44.196.160 35.193.28.231 8080:32466/TCP 11mמערכת GKE הקצתה
EXTERNAL_IPלמאזן עומסי הרשת החיצוני להעברת סיגנל ללא שינוי.בודקים את החיבור למאזן העומסים:
curl EXTERNAL_IP:PORTמחליפים את מה שכתוב בשדות הבאים:
-
EXTERNAL_IP: כתובת ה-IP שהוקצתה למאזן עומסי הרשת החיצוני להעברת סיגנל ללא שינוי. -
PORT: מספר היציאה שהוקצה למאזן עומסי הרשת החיצוני להעברת סיגנל ללא שינוי.
הפלט אמור להיראות כך:
Hostname: store-v1-lb-svc-cdb9bb4d6-hflxd Pod Information: -no pod information available- Server values: server_version=nginx: 1.13.3 - lua: 10008 Request Information: client_address=10.128.0.50 method=GET real path=/ query= request_version=1.1 request_scheme=http request_uri=EXTERNAL_IP Request Headers: accept=*/* host=EXTERNAL_IP user-agent=curl/7.81.0 Request Body: -no body in request--
בודקים את שירות LoadBalancer ואת קבוצת ההערות שלו שמתארות אתGoogle Cloud המשאבים שלו:
kubectl describe svc store-v1-lb-svcהפלט אמור להיראות כך:
Name: my-service-external Namespace: default Labels: <none> Annotations: cloud.google.com/l4-rbs: enabled cloud.google.com/neg-status: {"network_endpoint_groups":{"0":"k8s2-qvveq1d8-default-my-service-ext-5s55db85"},"zones":["us-central1-c"]} #This annotation appears in the output only if the service uses NEG backends. networking.gke.io/weighted-load-balancing: pods-per-node #This annotation appears in the output only if weighted load balancing is enabled. service.kubernetes.io/backend-service: k8s2-qvveq1d8-default-my-service-ext-5s55db85 service.kubernetes.io/firewall-rule: k8s2-qvveq1d8-default-my-service-ext-5s55db85 service.kubernetes.io/firewall-rule-for-hc: k8s2-qvveq1d8-default-my-service-ext-5s55db85-fw service.kubernetes.io/healthcheck: k8s2-qvveq1d8-default-my-service-ext-5s55db85 service.kubernetes.io/tcp-forwarding-rule: a808124abf8ce406ca51ab3d4e7d0b7d Selector: app=my-app Type: LoadBalancer IP Family Policy: SingleStack IP Families: IPv4 IP: 10.18.102.23 IPs: 10.18.102.23 LoadBalancer Ingress: 35.184.160.229 Port: tcp-port 8080/TCP TargetPort: 8080/TCP NodePort: tcp-port 31864/TCP Endpoints: 10.20.1.28:8080,10.20.1.29:8080 Session Affinity: None External Traffic Policy: Local HealthCheck NodePort: 30394 Events: Type Reason Age From Message ---- ------ ---- ---- ------- Normal ADD 4m55s loadbalancer-controller default/my-service-extיש כמה שדות שמציינים שמאזן עומסי רשת חיצוני להעברת סיגנל שמבוסס על שירות לקצה העורפי והמשאבים שלו נוצרו בהצלחה: Google Cloud
Events. השדה הזה ריק אם שירות LoadBalancer והמשאבים שלו נוצרו בהצלחה. אם אירעה שגיאה, היא מופיעה כאן.רשימה של
Annotationsמופעל: GKE מוסיף את רשימת ההערות הבאה לקריאה בלבד למניפסט של השירות. כל הערה שהשם שלה מתחיל ב-service.kubernetes.io/משמשת לציון השם שלGoogle Cloud משאב שנוצר כחלק ממאזן העומסים או כדי לתמוך בו.- ההערה
networking.gke.io/weighted-load-balancing: pods-per-nodeמציינת שהופעל איזון עומסים משוקלל, ומאזן העומסים מחלק את התנועה בין ה-Pods בקצה העורפי על סמך מספר ה-Pods שפועלים בכל צומת. - ההערה
service.kubernetes.io/backend-serviceמציינת את השם של השירות לקצה העורפי של מאזן העומסים. - ההערה
service.kubernetes.io/healthcheckמציינת את השם של בדיקת תקינות מאזן העומסים שבה נעשה שימוש בשירות הקצה העורפי. - ההערה
service.kubernetes.io/tcp-forwarding-ruleאוservice.kubernetes.io/udp-forwarding-ruleמציינת את השם של כלל ההעברה של מאזן העומסים. - ההערה
service.kubernetes.io/firewall-ruleמציינת את השם של כלל חומת האש שנוצר כדי לאפשר תנועה לצמתי האשכול. אפשר להתאים אישית את טווחי המקור של כלל חומת האש הזה באמצעותspec.loadBalancerSourceRanges[]. פרטים נוספים על כללי חומת האש לשירותי LoadBalancer זמינים במאמר בנושא כללי חומת אש ורשימת כתובות IP מותרות. - ההערה
service.kubernetes.io/firewall-rule-for-hcמציינת את השם של כלל חומת האש שנדרש לבדיקות התקינות של מאזן העומסים. ההערה
cloud.google.com/neg-statusמציינת את קבוצות ה-NEG שמשמשות את מאזן העומסים ואת האזורים שלהן. ההערה הזו מופיעה רק אם מתקיימים שני התנאים הבאים:- האשכול הפעיל את גרסת GKE 1.32.2-gke.1652000 ואילך כשקובץ המניפסט הוחל על האשכול, ו
- ההערה
cloud.google.com/l4-rbs: "enabled"הייתה קיימת במניפסט של השירות כשהיא הוחלה על האשכול.
- ההערה
מוודאים שמשאבי מאזן העומסים וכללי חומת האש נוצרו עבור שירות LoadBalancer חיצוני:
כדי לראות את כלל ההעברה, מריצים את הפקודה הבאה:
gcloud compute forwarding-rules describe FWD_RULE_NAME \ --region=REGION_NAMEמחליפים את מה שכתוב בשדות הבאים:
-
FWD_RULE_NAME: השם של כלל ההעברה שסופק על ידי ההערות לקריאה בלבדservice.kubernetes.io/tcp-forwarding-ruleאוservice.kubernetes.io/udp-forwarding-rule. כדי לבדוק את ההערות האלה, מריצים את הפקודהkubectl describe svc SERVICE_NAME. -
REGION_NAME: Google Cloud האזור שבו נמצא האשכול. באשכולות אזוריים, האזור מכיל את האזור שבו נעשה שימוש באשכול.
-
כדי לראות את שירות לקצה העורפי, מריצים את הפקודה הבאה:
gcloud compute backend-services describe BACKEND_SERVICE_NAME \ --region=REGION_NAMEמחליפים את מה שכתוב בשדות הבאים:
-
BACKEND_SERVICE_NAME: השם של שירות ה-Backend שמוגדר על ידי ההערהservice.kubernetes.io/backend-serviceלקריאה בלבד. כדי לבדוק את ההערה הזו לקריאה בלבד, מריצים את הפקודהkubectl describe svc SERVICE_NAME. -
REGION_NAME: Google Cloud האזור שבו נמצא האשכול. באשכולות אזוריים, האזור מכיל את התחום שבו נעשה שימוש באשכול.
-
כדי לראות את בדיקת התקינות של מאזן העומסים, מריצים את הפקודה הבאה:
gcloud compute health-checks describe HEALTH_CHECK_NAME \ --region=REGION_NAMEמחליפים את מה שכתוב בשדות הבאים:
-
HEALTH_CHECK_NAME: השם של בדיקת תקינות מאזן העומסים. השם של בדיקת התקינות מופיע בהערה לקריאה בלבדservice.kubernetes.io/healthcheck. כדי לבדוק את ההערה הזו לקריאה בלבד, מריצים את הפקודהkubectl describe svc SERVICE_NAME. -
REGION_NAME: Google Cloud האזור שבו נמצא האשכול. באשכולות אזוריים, האזור מכיל את התחום שבו נעשה שימוש באשכול.
-
כדי לראות את הכללים של חומת האש, מריצים את הפקודות הבאות:
gcloud compute firewall-rules describe FIREWALL_RULE_NAME \ gcloud compute firewall-rules describe HEALTH_CHECK_FIREWALL_RULE_NAMEמחליפים את מה שכתוב בשדות הבאים:
-
FIREWALL_RULE_NAME: השם של כלל חומת האש שמאפשר תנועה למאזן העומסים. השם של כלל חומת האש הזה מסופק על ידי ההערהservice.kubernetes.io/firewall-ruleלקריאה בלבד. כדי לבדוק את ההערה הזו לקריאה בלבד, מריצים את הפקודהkubectl describe svc SERVICE_NAME. -
HEALTH_CHECK_FIREWALL_RULE_NAME: השם של כלל חומת האש שמאפשר בדיקות תקינות של השרתים העורפיים של מאזן העומסים (הצמתים של האשכול). השם של כלל חומת האש הזה מסופק על ידיservice.kubernetes.io/firewall-rule-for-hcההערה לקריאה בלבד. כדי לבדוק את ההערה הזו לקריאה בלבד, מריצים אתkubectl describe svc SERVICE_NAME.
-
כדי לראות את קבוצות ה-NEG של מאזן העומסים, מריצים את הפקודה הבאה:
gcloud compute network-endpoint-groups describe NEG_NAME \ --zone=ZONE_NAMEמחליפים את מה שכתוב בשדות הבאים:
-
NEG_NAME: שם ה-NEG של מאזן העומסים. השם של קבוצת ה-NEG מסופק על ידי ההערהcloud.google.com/neg-statusלקריאה בלבד. כדי לבדוק את ההערה הזו לקריאה בלבד, מריצים את הפקודהkubectl describe svc SERVICE_NAME. ההערה מכילה נתונים מובנים עם מידע על שמות ה-NEG והאזורים שבהם נעשה שימוש במאזן העומסים. עבור אשכולות אזוריים, ההערה הזו מכילה מידע על NEG אחד. במקרה של אשכולות אזוריים, ההערה הזו מכילה מידע על NEG בכל אזור שבו האשכול ממוקם. -
ZONE_NAME: Google Cloud האזור שבו נמצא ה-NEG.
-
מחיקת שירות LoadBalancer חיצוני
כדי למחוק את שירות LoadBalancer החיצוני לדוגמה store-v1-lb-svc, משתמשים בפקודה הבאה:
kubectl delete service store-v1-lb-svc
GKE מסיר באופן אוטומטי את כל משאבי מאזן העומסים שהוא יצר עבור שירות LoadBalancer חיצוני.
מעבר לשרתי קצה של GCE_VM_IP NEG
שירותים מסוג LoadBalancer חיצוני עם ההערה cloud.google.com/l4-rbs: "enabled"
יוצרים מאזני עומסי רשת חיצוניים להעברת סיגנל ללא שינוי שמבוססים על שירותים עורפיים, שמשתמשים בקבוצה של נקודות קצה ברשת GCE_VM_IP או בקבוצות של מופעים עורפיים, בהתאם לגרסת GKE של האשכול:
אם קובץ המניפסט של השירות הוחל על אשכול שפועלת בו גרסה 1.32.2-gke.1652000 של GKE ואילך, מאזן עומסי הרשת החיצוני להעברת סיגנל ללא שינוי שנוצר משתמש בקצה עורפי של
GCE_VM_IPקבוצת נקודות קצה ברשת (NEG).אם קובץ המניפסט של השירות הוחל על אשכול שפועלת בו גרסה מוקדמת יותר של GKE, מאזן עומסי הרשת החיצוני מסוג passthrough שנוצר משתמש בקצה עורפי של קבוצת מופעים לא מנוהלת.
מידע נוסף זמין במאמר קיבוץ צמתים בנושא שירותי LoadBalancer.
אתם יכולים ליצור שירות LoadBalancer חיצוני חדש שמבוסס על מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות קצה עורפי ומשתמש בקצוות עורפיים של GCE_VM_IP NEG, אם השירות הקיים שלכם משתמש באחד ממאזני העומסים הבאים:
- מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות לקצה העורפי עם קצוות עורפיים של קבוצת מופעים
- מאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על מאגר יעד
כדי לעבור למאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות לקצה העורפי באמצעות קצוות עורפיים של GCE_VM_IP NEG:
אם עדיין לא עשיתם זאת, שדרגו את האשכול לגרסה 1.32.2-gke.1652000 של GKE או לגרסה חדשה יותר.
מזהים את שירות LoadBalancer החיצוני שרוצים להחליף במאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על שירות קצה עורפי באמצעות קצוות עורפיים של
GCE_VM_IPNEG. כדי לתאר את השירות, משתמשים בפקודה הבאה:kubectl describe svc SERVICE_NAME -n SERVICE_NAMESPACEמחליפים את מה שכתוב בשדות הבאים:
SERVICE_NAME: השם של שירות LoadBalancer חיצוני קיים.
SERVICE_NAMESPACE: מרחב השמות של שירות LoadBalancer חיצוני קיים.
בפלט הפקודה, מאתרים את כתובת ה-IPv4 החיצונית של מאזן העומסים שמופיעה אחרי
LoadBalancer Ingress.מאחזרים את מניפסט השירות של שירות LoadBalancer הקיים:
הכי טוב אם יש לכם את מניפסט השירות המקורי שהחלתם על האשכול בעבר. לדוגמה, יכול להיות שזה יופיע במאגר של בקרת מקור.
אם אין לכם את מניפסט השירות המקורי:
מריצים את הפקודה הבאה כדי לקבל עותק YAML של מניפסט השירות שמייצג את ההטמעה הנוכחית של איזון העומסים:
kubectl get svc SERVICE_NAME -n SERVICE_NAMESPACE -o yamlמעתיקים את קובץ המניפסט YAML לכלי לעריכת טקסט. מסירים את המאפיין
statusואת המאפיינים הבאים:metadata- כל ההערות הבאות:
- ההערה
kubectl.kubernetes.io/last-applied-configuration - כל ההערות שמתחילות ב-
service.kubernetes.io
- ההערה
creationTimestampfinalizersresourceVersionuid
- כל ההערות הבאות:
מוודאים שהמניפסט כולל את ההערה
cloud.google.com/l4-rbs: "enabled". אם אתם עוברים ממאזן עומסי רשת חיצוני להעברת סיגנל ללא שינוי שמבוסס על מאגר יעד, צריך להוסיף את ההערה.
שומרים את קובץ המניפסט ורושמים לעצמכם איפה שמרתם אותו. בהמשך התהליך הזה, הנתיב שבו שמרתם את קובץ המניפסט נקרא MANIFEST_FILE_PATH.
מגדירים משאב של כתובת IPv4 חיצונית סטטית כדי להחזיק את כתובת ה-IPv4 החיצונית שמשמשת את מאזן העומסים הקיים:
gcloud compute addresses create IP_ADDRESS_NAME --region=CLUSTER_REGION --addresses LB_EXTERNAL_IPמחליפים את מה שכתוב בשדות הבאים:
IP_ADDRESS_NAME: השם של כתובת ה-IP החיצונית הסטטית. השם צריך לעמוד במוסכמות למתן שמות למשאבי Compute Engine.
CLUSTER_REGION: האזור שבו נמצא האשכול. במקרה של אשכולות אזוריים, זהו האזור שמכיל את התחום של האשכול.
LB_EXTERNAL_IP: כתובת ה-IPv4 החיצונית שבה נעשה שימוש במאזן העומסים הנוכחי, כפי שנקבע בשלב השני של התהליך הזה.
מוודאים שנוצר משאב של כתובת IPv4 חיצונית סטטית:
gcloud compute addresses describe IP_ADDRESS_NAME --region=CLUSTER_REGIONמחליפים את המשתנים כמו שמוסבר בשלב הקודם.
מוחקים את השירות הקיים:
kubectl delete svc SERVICE_NAME -n SERVICE_NAMESPACEמוסיפים את ההערה הבאה לקובץ המניפסט של שירות
MANIFEST_FILE_PATH:networking.gke.io/load-balancer-ip-addresses: IP_ADDRESS_NAMEמידע נוסף על ההערה הזו זמין במאמר כתובות IP סטטיות בפרמטרים של שירות LoadBalancer.
מחילים את מניפסט השירות המעודכן על האשכול:
kubectl apply -f MANIFEST_FILE_PATH(אופציונלי) משחררים את משאב כתובת ה-IPv4 הסטטית.
gcloud compute addresses delete IP_ADDRESS_NAME --region=CLUSTER_REGION
פתרון בעיות
בקטע הזה מתוארת בעיה שאולי תיתקלו בה כשאתם מגדירים איזון עומסים משוקלל.
מדיניות שגויה בנושא תנועה חיצונית לאיזון עומסים משוקלל
אם לא מגדירים את externalTrafficPolicy: Local כשמפעילים איזון עומסים משוקלל, יכול להיות שתקבלו אירוע אזהרה כשמתארים את השירות באמצעות הפקודה הבאה:
kubectl describe svc store-v1-lb-svc`
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Warning UnsupportedConfiguration 4m55s loadbalancer-controller Weighted load balancing by pods-per-node has no effect with External Traffic Policy: Cluster.
כדי להפעיל איזון עומסים משוקלל בצורה יעילה, צריך להגדיר את externalTrafficPolicy: Local.
המאמרים הבאים
- סקירה כללית על שירותי מאזן עומסים זמינה במאמר בנושא שירותי LoadBalancer.
- תיאור של הפרמטרים של שירות Load Balancer מופיע במאמר פרמטרים של שירות LoadBalancer.
- פתרון בעיות באיזון עומסים ב-GKE