במאמר הזה מוסבר איך לפרוס עומס עבודה שמבוסס על מכונה וירטואלית (VM) בהתקנה של Google Distributed Cloud (תוכנה בלבד) ב-Bare Metal באמצעות VM Runtime ב-GDC. עומס העבודה שמשמש במדריך הזה הוא אפליקציית נקודת המכירה לדוגמה. האפליקציה הזו מייצגת מסוף של נקודת מכירה טיפוסי שפועל על חומרה מקומית בחנות קמעונאית.
במסמך הזה, תעבירו את האפליקציה הזו ממכונה וירטואלית לאשכול ותגשו לחלק הקדמי של האפליקציה באינטרנט. כדי להעביר מכונה וירטואלית קיימת לאשכול, צריך קודם ליצור תמונת דיסק של המכונה הווירטואלית הזו. לאחר מכן, התמונה צריכה להיות מאוחסנת במאגר שהאשכול יכול לגשת אליו. לבסוף, אפשר להשתמש בכתובת ה-URL של התמונה כדי ליצור את המכונה הווירטואלית. VM Runtime on GDC מצפה שהתמונות יהיו בפורמט qcow2. אם תספקו סוג אחר של תמונה, היא תומר באופן אוטומטי לפורמט qcow2. כדי להימנע מהמרות חוזרות ולאפשר שימוש חוזר, אפשר להמיר תמונה של דיסק וירטואלי ולארח את תמונת qcow2.
במסמך הזה נעשה שימוש בתמונה מוכנה מראש של מכונה וירטואלית (VM) של Compute Engine, שבה עומס העבודה פועל כשירות systemd. אפשר לפעול לפי אותם השלבים כדי לפרוס אפליקציה משלכם.
מטרות
לפני שמתחילים
כדי למלא את המסמך הזה, תצטרכו את מקורות המידע הבאים:
- גישה לאשכול בשרת פיזי בגרסה 1.12.0 ואילך, שנוצר לפי המדריך Install with Manual Loadbalancer. במסמך הזה מוגדרים משאבי רשת כדי שתוכלו לגשת לעומס העבודה שפועל בתוך המכונה הווירטואלית דרך דפדפן. אם אתם לא צריכים את ההתנהגות הזו, אתם יכולים לפעול לפי ההוראות במאמר הזה כדי להתקין את Google Distributed Cloud על bare metal.
- תחנת עבודה שעומדת בדרישות הבאות:
הפעלת VM Runtime ב-GDC והתקנה של הפלאגין virtctl
ה-VM Runtime בהגדרת משאב בהתאמה אישית של GDC הוא חלק מכל האשכולות מסוג Bare Metal החל מגרסה 1.10. מופע של המשאב המותאם אישית VMRuntime כבר נוצר במהלך ההתקנה. אבל הוא מושבת כברירת מחדל.
הפעלת VM Runtime ב-GDC:
sudo bmctl enable vmruntime --kubeconfig KUBECONFIG_PATH- KUBECONFIG_PATH: הנתיב לקובץ ה-kubeconfig של אשכול משתמשים.
בודקים ש-
VMRuntimeמופעל:kubectl wait --for=jsonpath='{.status.ready}'=true vmruntime vmruntimeיכול להיות שיעברו כמה דקות עד שהשעון יהיה מוכן.
VMRuntimeאם הוא לא מוכן, כדאי לבדוק כמה פעמים בהפרשי זמן קצרים. בדוגמה הבאה של פלט אפשר לראות שהערךVMRuntimeמוכן:vmruntime.vm.cluster.gke.io/vmruntime condition metמתקינים את הפלאגין virtctl ל-
kubectl:sudo -E bmctl install virtctlבדוגמה הבאה של הפלט מוצג תהליך ההתקנה של התוסף
virtctl:Please check the logs at bmctl-workspace/log/install-virtctl-20220831-182135/install-virtctl.log [2022-08-31 18:21:35+0000] Install virtctl succeededכדי לוודא שהפלאגין
virtctlהותקן:kubectl virtבדוגמה הבאה של הפלט אפשר לראות שהפלאגין
virtctlזמין לשימוש עםkubectl:Available Commands: addvolume add a volume to a running VM completion generate the autocompletion script for the specified shell config Config subcommands. console Connect to a console of a virtual machine instance. create Create subcommands. delete Delete subcommands. ...
פריסת עומס העבודה שמבוסס על מכונה וירטואלית
כשפורסים מכונה וירטואלית בהתקנה של Google Distributed Cloud (תוכנה בלבד) בשרת פיזי, VM Runtime ב-GDC מצפה לתמונה של מכונה וירטואלית. התמונה הזו משמשת כדיסק אתחול למכונה הווירטואלית שנפרסה.
במדריך הזה תלמדו איך להעביר עומס עבודה שמבוסס על מכונה וירטואלית ב-Compute Engine לאשכול. נוצרה מכונה וירטואלית ב-Compute Engine, והאפליקציה לדוגמה של נקודת המכירה (PoS) הוגדרה לפעול כשירות systemd. נוצר קובץ אימג' של הדיסק של מכונת ה-VM הזו, יחד עם עומס העבודה של אפליקציית ה-PoS ב- Google Cloud. לאחר מכן יוצאה התמונה לקטגוריה של Cloud Storage כתמונה בפורמט qcow2. משתמשים בתמונה המוכנה מראש qcow2 בשלבים הבאים.
קוד המקור במסמך הזה זמין במאגר anthos-samples ב-GitHub. משתמשים במשאבים ממאגר זה כדי להשלים את השלבים הבאים.
פריסה של MySQL
StatefulSet. אפליקציית נקודת המכירה מצפה להתחבר למסד נתונים מסוג MySQL כדי לאחסן נתוני מלאי ופרטי תשלום. מאגר המידע של מערכת הקופה מכיל קובץ מניפסט לדוגמה שפורס MySQLStatefulSet, מגדירConfigMapמשויך ו-KubernetesService. הקובץConfigMapמגדיר את פרטי הכניסה למופע MySQL, שהם אותם פרטי כניסה שמועברים לאפליקציית נקודת המכירה.kubectl apply -f https://raw.githubusercontent.com/GoogleCloudPlatform/point-of-sale/main/k8-manifests/common/mysql-db.yamlפורסים את עומס העבודה של ה-VM באמצעות קובץ האימג'
qcow2שהוכן מראש:kubectl virt create vm pos-vm \ --boot-disk-size=80Gi \ --memory=4Gi \ --vcpu=2 \ --image=https://storage.googleapis.com/pos-vm-images/pos-vm.qcow2הפקודה הזו יוצרת קובץ YAML שנקרא על שם מכונת ה-VM (
google-virtctl/pos-vm.yaml). אפשר לבדוק את הקובץ כדי לראות את ההגדרה שלVirtualMachineושלVirtualMachineDisk. במקום להשתמש בתוסףvirtctl, אפשר לפרוס את עומס העבודה של מכונת ה-VM באמצעות הגדרות של Kubernetes Resource Model (KRM), כמו שרואים בקובץ ה-YAML שנוצר.כשהפקודה מופעלת בהצלחה, היא יוצרת פלט כמו בדוגמה הבאה, שבו מוסברים המשאבים השונים שנוצרו:
Constructing manifest for vm "pos-vm": Manifest for vm "pos-vm" is saved to /home/tfadmin/google-virtctl/pos-vm.yaml Applying manifest for vm "pos-vm" Created gvm "pos-vm"בודקים את סטטוס היצירה של המכונה הווירטואלית.
משאב
VirtualMachineמזוהה על ידי משאבvm.cluster.gke.io/v1.VirtualMachineב-VM Runtime ב-GDC. הקיצור שלו הואgvm.כשיוצרים מכונת VM, נוצרים שני המשאבים הבאים:
- VirtualMachineDisk הוא דיסק אחסון מתמיד שאליו מיובא התוכן של תמונת מכונת ה-VM.
- VirtualMachine היא המכונה הוירטואלית עצמה. ה-DataVolume מותקן ב-VirtualMachine לפני שהמכונה הווירטואלית מופעלת.
בודקים את הסטטוס של VirtualMachineDisk. VirtualMachineDisk יוצר באופן פנימי משאב
DataVolume. קובץ האימג' של המכונה הווירטואלית מיובא אל DataVolume שמוטמע במכונה הווירטואלית:kubectl get datavolumeבדוגמה הבאה של פלט אפשר לראות את תחילת הייבוא של התמונה:
NAME PHASE PROGRESS RESTARTS AGE pos-vm-boot-dv ImportScheduled N/A 8sבודקים את הסטטוס של
VirtualMachine. הסטטוס שלVirtualMachineהואProvisioningעד לייבוא מלא שלDataVolume:kubectl get gvmבדוגמת הפלט הבאה אפשר לראות את הקצאת המשאבים של
VirtualMachine:NAME STATUS AGE IP pos-vm Provisioning 1mמחכים עד שתמונת המכונה הווירטואלית תיווצר באופן מלא ב-
DataVolume. כדי לראות את התקדמות הייבוא של התמונה:kubectl get datavolume -wבדוגמה הבאה של פלט אפשר לראות את ייבוא תמונת הדיסק:
NAME PHASE PROGRESS RESTARTS AGE pos-vm-boot-dv ImportInProgress 0.00% 14s ... ... pos-vm-boot-dv ImportInProgress 0.00% 31s pos-vm-boot-dv ImportInProgress 1.02% 33s pos-vm-boot-dv ImportInProgress 1.02% 35s ...כשהייבוא מסתיים ונוצר
DataVolume, פלט הדוגמה הבא מציג אתPHASEשלSucceeded:kubectl get datavolumeNAME PHASE PROGRESS RESTARTS AGE pos-vm-boot-dv Succeeded 100.0% 14m18sמוודאים שהמדיניות
VirtualMachineנוצרה בהצלחה:kubectl get gvmאם היצירה הצליחה, ב-
STATUSיופיעRUNNING, כמו בדוגמה הבאה, יחד עם כתובת ה-IP של מכונת ה-VM:NAME STATUS AGE IP pos-vm Running 40m 192.168.3.250
התחברות למכונה הווירטואלית ובדיקת סטטוס האפליקציה
התמונה שמשמשת את ה-VM כוללת את האפליקציה לדוגמה של נקודת המכירה. האפליקציה מוגדרת להפעלה אוטומטית בזמן האתחול כשירות systemd. אפשר לראות את קובצי ההגדרות של שירותי systemd בספרייה pos-systemd-services.
מתחברים למסוף של ה-VM. מריצים את הפקודה הבאה ומקישים על Enter⏎ אחרי שרואים את ההודעה
Successfully connected to pos-vm…:kubectl virt console pos-vmהפקודה הזו יוצרת פלט לדוגמה שבו מוצגת בקשה להזנת פרטי ההתחברות:
Successfully connected to pos-vm console. The escape sequence is ^] pos-from-public-image login:משתמשים בחשבון המשתמש ובסיסמה הבאים. החשבון הזה הוגדר בתוך המכונה הווירטואלית המקורית שממנה נוצרה התמונה של VM Runtime ב-GDC VirtualMachine.
- שם משתמש להתחברות:
abmuser - סיסמה:
abmworks
- שם משתמש להתחברות:
בודקים את הסטטוס של שירותי אפליקציית נקודת המכירה. אפליקציית הקופה כוללת שלושה שירותים: API, מלאי ותשלומים. כל השירותים האלה פועלים כשירותי מערכת.
שלושת השירותים מתחברים זה לזה דרך localhost. עם זאת, האפליקציה מתחברת למסד הנתונים של MySQL באמצעות שירות mysql-db Kubernetes שנוצר בשלב הקודם. ההתנהגות הזו אומרת שהמכונה הווירטואלית מחוברת אוטומטית לאותה רשת כמו
Podsו-Services, מה שמאפשר תקשורת חלקה בין עומסי העבודה של המכונה הווירטואלית לבין אפליקציות אחרות שמבוססות על קונטיינרים. לא צריך לעשות שום דבר נוסף כדי לאפשר גישה ל-Kubernetes (Services) ממכונות וירטואליות שנפרסו באמצעות VM Runtime ב-GDC.sudo systemctl status pos*בדוגמה הבאה מוצג הפלט של הסטטוס של שלושת השירותים ושירות מערכת הבסיס,
pos.service:● pos_payments.service - Payments service of the Point of Sale Application Loaded: loaded (/etc/systemd/system/pos_payments.service; enabled; vendor > Active: active (running) since Tue 2022-06-21 18:55:30 UTC; 1h 10min ago Main PID: 750 (payments.sh) Tasks: 27 (limit: 4664) Memory: 295.1M CGroup: /system.slice/pos_payments.service ├─750 /bin/sh /pos/scripts/payments.sh └─760 java -jar /pos/jars/payments.jar --server.port=8083 ● pos_inventory.service - Inventory service of the Point of Sale Application Loaded: loaded (/etc/systemd/system/pos_inventory.service; enabled; vendor> Active: active (running) since Tue 2022-06-21 18:55:30 UTC; 1h 10min ago Main PID: 749 (inventory.sh) Tasks: 27 (limit: 4664) Memory: 272.6M CGroup: /system.slice/pos_inventory.service ├─749 /bin/sh /pos/scripts/inventory.sh └─759 java -jar /pos/jars/inventory.jar --server.port=8082 ● pos.service - Point of Sale Application Loaded: loaded (/etc/systemd/system/pos.service; enabled; vendor preset: e> Active: active (exited) since Tue 2022-06-21 18:55:30 UTC; 1h 10min ago Main PID: 743 (code=exited, status=0/SUCCESS) Tasks: 0 (limit: 4664) Memory: 0B CGroup: /system.slice/pos.service Jun 21 18:55:30 pos-vm systemd[1]: Starting Point of Sale Application... Jun 21 18:55:30 pos-vm systemd[1]: Finished Point of Sale Application. ● pos_apiserver.service - API Server of the Point of Sale Application Loaded: loaded (/etc/systemd/system/pos_apiserver.service; enabled; vendor> Active: active (running) since Tue 2022-06-21 18:55:31 UTC; 1h 10min ago Main PID: 751 (api-server.sh) Tasks: 26 (limit: 4664) Memory: 203.1M CGroup: /system.slice/pos_apiserver.service ├─751 /bin/sh /pos/scripts/api-server.sh └─755 java -jar /pos/jars/api-server.jar --server.port=8081יוצאים מה-VM. כדי לצאת מהחיבור למסוף, משתמשים ברצף בריחה
^]על ידי לחיצה עלCtrl + ].
גישה לעומס עבודה מבוסס מכונה וירטואלית
אם הגדרתם את האשכול לפי המדריך Install with Manual Loadbalancer, כבר נוצר משאב Ingress בשם pos-ingress. המשאב הזה מעביר את התנועה מכתובת ה-IP החיצונית של מאזן העומסים של Ingress לשירות של שרת ה-API של אפליקציית הדוגמה של נקודת המכירה.
אם אין במערכת שלכם את המשאב
Ingress, צריך ליצור אותו על ידי החלת המניפסט הבא:kubectl apply -f https://raw.githubusercontent.com/GoogleCloudPlatform/anthos-samples/main/anthos-bm-gcp-terraform/resources/manifests/pos-ingress.yamlיוצרים Kubernetes
Serviceשמנתב תנועה למכונה הווירטואלית. מקור המידעIngressמפנה תנועה אלService:kubectl apply -f https://raw.githubusercontent.com/GoogleCloudPlatform/anthos-samples/main/anthos-vmruntime/pos-service.yamlבדוגמת הפלט הבאה אפשר לראות שהשירות נוצר:
service/api-server-svc createdמקבלים את כתובת ה-IP החיצונית של מאזן העומסים
Ingress. מאזן העומסיםIngressמנתב את התנועה על סמך הכללים של משאבIngress. כבר יש לכם כללpos-ingressלהעברת בקשות לשרת ה-APIService. ה-Serviceמעביר את הבקשות ל-VM:INGRESS_IP=$(kubectl get ingress/pos-ingress -o jsonpath='{.status.loadBalancer.ingress[0].ip}') echo $INGRESS_IPבדוגמה הבאה של פלט אפשר לראות את כתובת ה-IP של איזון העומסים
Ingress:172.29.249.159 # you might have a different IP addressניגשים לאפליקציה באמצעות כתובת ה-IP של מאזן העומסים של Ingress בדפדפן. צילומי המסך הבאים מציגים קיוסק של נקודת מכירה עם שני פריטים. אפשר ללחוץ על הפריטים, יותר מפעם אחת אם רוצים להזמין כמה פריטים, ולבצע הזמנה באמצעות הלחצן תשלום. החוויה הזו מראה שפרסת בהצלחה עומס עבודה מבוסס-מכונה וירטואלית באשכול באמצעות VM Runtime ב-GDC.
הסרת המשאבים
אפשר למחוק את כל המשאבים שנוצרו במדריך הזה, או למחוק רק את המכונה הווירטואלית ולשמור משאבים שאפשר לעשות בהם שימוש חוזר. במאמר מחיקת מכונה וירטואלית מוסברות האפשרויות הזמינות בפירוט.
מחיקה של הכול
מוחקים את VM Runtime ב-GDC
VirtualMachineיחד עם כל המשאבים:kubectl virt delete vm pos-vm --allבדוגמה הבאה של פלט אפשר לראות את אישור המחיקה:
vm "pos-vm" used the following resources: gvm: pos-vm VirtualMachineDisk: pos-vm-boot-dv Start deleting the resources: Deleted gvm "pos-vm". Deleted VirtualMachineDisk "pos-vm-boot-dv".
מחיקת מכונה וירטואלית בלבד
אם מוחקים רק את המכונה הווירטואלית, ה-
VirtualMachineDiskשנוצר נשמר. כך אפשר לעשות שימוש חוזר באימג' של המכונה הווירטואלית ולחסוך זמן בייבוא האימג' כשיוצרים מכונה וירטואלית חדשה.kubectl virt delete vm pos-vmבדוגמה הבאה של פלט אפשר לראות את אישור המחיקה:
vm "pos-vm" used the following resources: gvm: pos-vm VirtualMachineDisk: pos-vm-boot-dv Start deleting the resources: Deleted gvm "pos-vm".
המאמרים הבאים
- המכונה הווירטואלית המקורית שבה נעשה שימוש במדריך הזה היא מכונה של Compute Engine שמופעלת באמצעות Ubuntu 20.04 LTS. התמונה של מכונת ה-VM הזו נגישה לציבור דרך קטגוריית Cloud Storage pos-vm-images. מידע נוסף על אופן ההגדרה של המכונה הווירטואלית ועל אופן יצירת התמונה שלה זמין בהוראות במאגר של מערכת הקופה.
- כשיוצרים מכונה וירטואלית באשכול באמצעות הפקודה
kubectl virt create vm pos-vm, נוצר קובץ YAML שנקרא על שם המכונה הווירטואלית (google-virtctl/pos-vm.yaml). אפשר לבדוק את הקובץ כדי לראות את ההגדרה שלVirtualMachineושלVirtualMachineDisk. במקום להשתמש בפלאגיןvirtctl, אפשר לפרוס מכונה וירטואלית באמצעות הגדרות KRM, כמו שמופיע בקובץ ה-YAML שנוצר.