בדף הזה מוסבר איך לנהל מכונות וירטואליות ב-Google Distributed Cloud שמופעל בהן VM Runtime ב-Google Distributed Cloud. כדי לבצע את השלבים שבדף הזה, אתם צריכים להכיר את VM Runtime ב-GDC. רשימה של מערכות הפעלה נתמכות של אורחים זמינה במאמר מערכות הפעלה מאומתות של אורחים עבור VM Runtime ב-GDC.
כדי להבין איך מכונות וירטואליות משמשות כרכיב חיוני בפלטפורמת Distributed Cloud, אפשר לעיין במאמר בנושא הרחבת GKE Enterprise לניהול מכונות וירטואליות בפריסה מקומית.
קלאסטרים של מישור בקרה מקומי תומכים בוווב-הוקים של מכונות וירטואליות. כך Distributed Cloud יכול לאמת בקשות משתמש שנשלחות לשרת Kubernetes API המקומי. בקשות שנדחו יוצרות מידע מפורט על סיבת הדחייה.
הפעלת VM Runtime ב-GDC support ב-Distributed Cloud
כברירת מחדל, התמיכה בזמן ריצה של מכונות וירטואליות ב-GDC מושבתת ב-Distributed Cloud. כדי להפעיל את האפשרות הזו, צריך לבצע את השלבים שמפורטים בקטע הזה. ההוראות בקטע הזה מניחות שיש לכם אשכול Distributed Cloud שפועל באופן מלא.
המשאב VMRuntime שמגדיר את VM Runtime בתמיכה של GDC ב-Distributed Cloud גם מגדיר תמיכה ב-GPU באשכול באמצעות הפרמטר enableGPU. חשוב להגדיר את שני הפרמטרים בהתאם לצרכים של עומס העבודה. לא צריך להפעיל תמיכה ב-GPU כדי להפעיל את זמן הריצה של מכונה וירטואלית בתמיכה של GDC באשכול Distributed Cloud.
בטבלה הבאה מתוארות התצורות האפשריות:
ערך של enable |
ערך של enableGPU |
ההגדרה שמתקבלת |
|---|---|---|
false |
false |
עומסי העבודה פועלים רק במאגרי מידע, ואי אפשר להשתמש במשאבי GPU. |
false |
true |
עומסי עבודה פועלים רק בקונטיינרים ויכולים להשתמש במשאבי GPU. |
true |
true |
עומסי עבודה יכולים לפעול במכונות וירטואליות ובקונטיינרים. שני סוגי עומסי העבודה יכולים להשתמש במשאבי GPU. |
true |
false |
עומסי עבודה יכולים לפעול במכונות וירטואליות ובקונטיינרים. אי אפשר להשתמש במשאבי GPU בשני סוגי עומסי העבודה. |
אם כבר הפעלתם תמיכה ב-GPU, צריך לשנות את המשאב VMRuntime כדי להוסיף את הפרמטר enable, להגדיר את הערך שלו ל-true ואז להחיל אותו על אשכול Distributed Cloud.
הפעלת VM Runtime במערכת המשנה של מכונות וירטואליות ב-GDC
בהתאם לסוג האשכול שבו רוצים להפעיל את VM Runtime במערכת המשנה של המכונה הווירטואלית ב-GDC, מבצעים אחת מהפעולות הבאות:
- במקרה של אשכולות של מישור הבקרה ב-Cloud, צריך ליצור את המשאב
VMRuntimeבאופן ידני. - במקרים של אשכולות של מישור בקרה מקומי, צריך לערוך את משאב
VMRuntimeהקיים.
כדי להפעיל את VM Runtime במערכת המשנה של מכונה וירטואלית ב-GDC, צריך לבצע את השלבים הבאים:
בהתאם לסוג אשכול היעד, יוצרים או משנים את
VMRuntimeהמשאב המותאם אישית עם התוכן הבא ומחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VMRuntime metadata: name: vmruntime spec: # Enable Anthos VM Runtime support enabled: true # vmImageFormat defaults to "raw" if not set vmImageFormat: "raw"
אל תשנו את הערך של הפרמטר
vmImageFormat. Distributed Cloud לא תומך בפורמטים אחרים של דיסקים וירטואליים.בדרך כלל התהליך נמשך כמה דקות.
כדי לוודא ש
VMRuntimeהמשאב המותאם אישית הוחל על האשכול, משתמשים בפקודה הבאה:kubectl get vmruntime -o yaml
הפקודה מחזירה פלט שדומה לדוגמה הבאה:
- apiVersion: vm.cluster.gke.io/v1 kind: VMRuntime metadata: name: vmruntime ... spec: enabled: true vmImageFormat: raw status: ... ready: true ...כדי לוודא שהפעלתם את התמיכה ב-VM Runtime במכונה הווירטואלית של GDC באשכול, מריצים את הפקודה הבאה:
kubectl get pods -n vm-system
הפקודה מחזירה פלט שמציג את ה-VM Runtime ב-Pods של מערכת המשנה GDC שפועלים באשכול, בדומה לדוגמה הבאה:
NAME READY STATUS RESTARTS AGE cdi-apiserver-6c76c6cf7b-n68wn 1/1 Running 0 132m cdi-deployment-f78fd599-vj7tv 1/1 Running 0 132m cdi-operator-65c4df9647-fcb9d 1/1 Running 0 134m cdi-uploadproxy-7765ffb694-6j7bf 1/1 Running 0 132m macvtap-fjfjr 1/1 Running 0 134m virt-api-77dd99dbbb-bs2fb 1/1 Running 0 132m virt-api-77dd99dbbb-pqc27 1/1 Running 0 132m virt-controller-5b44dbbbd7-hc222 1/1 Running 0 132m virt-controller-5b44dbbbd7-p8xkk 1/1 Running 0 132m virt-handler-n76fs 1/1 Running 0 132m virt-operator-86565697d9-fpxqh 2/2 Running 0 134m virt-operator-86565697d9-jnbt7 2/2 Running 0 134m vm-controller-controller-manager-7844d5fb7b-72d8m 2/2 Running 0 134m vmruntime-controller-manager-845649c847-m78r9 2/2 Running 0 175m
מתן גישה למרחב השמות של היעד למאגר Distributed Cloud
השלבים בקטע הזה רלוונטיים רק לאשכולות של מישור הבקרה בענן. אם אתם מגדירים את VM Runtime במערכת המשנה של מכונה וירטואלית ב-GDC באשכול של מישור בקרה מקומי, דלגו על הקטע הזה.
כדי ליצור מכונה וירטואלית במרחב שמות, צריך להעניק למרחב השמות הזה גישה למאגר Distributed Cloud. המאגר מכיל רכיבים שנדרשים ליצירה ולפריסה של מכונות וירטואליות במרחב השמות של היעד. חשוב לזכור שאי אפשר להפעיל מכונות וירטואליות במרחבי שמות ששמורים לניהול מערכת של Distributed Cloud. מידע נוסף מופיע במאמר בנושא הגבלות על מרחב שמות לניהול.
כדי להעניק למרחב השמות של היעד גישה למאגר Distributed Cloud, צריך לבצע את השלבים הבאים:
מבצעים תיקון לחשבון השירות שמוגדר כברירת מחדל במרחב השמות של היעד באמצעות המפתח
imagePullSecretשנקראgcr-pull:kubectl patch sa default -p "{\"imagePullSecrets\": [{\"name\": \"gcr-pull\"}]}" -n NAMESPACE
מחליפים את
NAMESPACEבשם של מרחב השמות של היעד.מרעננים את הסוד המשויך במרחב השמות של היעד:
# Delete existing secret. kubectl delete secret gcr-pull -n NAMESPACE --ignore-not-found # Copy the new secret to the target namespace. kubectl get secret gcr-pull -n vm-system -o yaml | sed "s/namespace: vm-system/namespace: NAMESPACE/g" | kubectl apply -f -
מחליפים את
NAMESPACEבשם של מרחב השמות של היעד.תוקף הסוד יפוג אחרי שעה. צריך לרענן אותו ידנית אחרי שהוא פג.
התקנה של כלי הניהול virtctl
אתם צריכים את כלי הלקוח virtctl כדי לנהל מכונות וירטואליות באשכול Distributed Cloud. כדי להתקין את הכלי, מבצעים את השלבים הבאים:
מתקינים את כלי הלקוח
virtctlכפלאגין שלkubectl:export VERSION=v0.49.0-anthos1.12-gke.7 gcloud storage cp gs://anthos-baremetal-release/virtctl/${VERSION}/linux-amd64/virtctl /usr/local/bin/virtctl cd /usr/local/bin sudo ln -s virtctl kubectl-virt sudo chmod a+x virtctl cd -
מוודאים שהפלאגין
virtמותקן:kubectl plugin list
אם הפלאגין הותקן בהצלחה, הפלט של הפקודה יכלול את
kubectl-virtכאחד מהפלאגינים.
הקצאת מכונה וירטואלית ב-Distributed Cloud עם אחסון בלוקים (block storage) גולמי
בקטע הזה מופיעות דוגמאות להגדרות שממחישות איך להקצות מכונה וירטואלית של Linux ומכונה וירטואלית של Windows באשכול Distributed Cloud עם אחסון בלוקים גולמי. בדוגמאות נעשה שימוש באחסון בלוקים שמופעל כ-PersistentVolume.
מגבלות השימוש באחסון בלוקים גולמי
המגבלות הבאות חלות כשמריצים מכונות וירטואליות עם אחסון בלוקים גולמי ב-Distributed Cloud:
- השדה
OSTypeלא נתמך במפרטים של משאביVirtualMachineבאשכולות של מישור הבקרה ב-Cloud. לכן, רק methodconsoleו-methodvncנתמכות לגישה למכונות וירטואליות שפועלות באשכולות של מישור הבקרה ב-Cloud. - אי אפשר ליצור מכונה וירטואלית באשכול Distributed Cloud ישירות באמצעות הפקודה
kubectl virt, כי Distributed Cloud לא מספק אחסון במערכת קבצים למכונות וירטואליות. - במשאבי אחסון בלוקים
PersistentVolumeClaimאין תמיכה בפורמטqcow2של תמונת דיסק. - התוסף Containerized Data Importer (CDI) לא תומך במשאבי
DataVolumeאחסון בלוקים כי מרחב העבודה הזמני של התוסף פועל רק באחסון של מערכת קבצים. מידע נוסף זמין במאמר בנושא שטח אחסון זמני.
הקצאת מכונה וירטואלית של Linux ב-Distributed Cloud עם אחסון בלוקים גולמי
בדוגמה הבאה מוסבר איך להקצות מכונה וירטואלית של Linux עם אחסון בלוקים גולמי שמריץ את Ubuntu Server 22.04. מקור ההתקנה הוא קובץ אימג' של דיסק ISO של Ubuntu Server 22.04.
יוצרים משאב
PersistentVolumeClaimעם התוכן הבא עבור תמונת הדיסק להתקנה של Ubuntu Server, ואז מחילים אותו על האשכול:apiVersion: v1 kind: PersistentVolumeClaim metadata: labels: app: containerized-data-importer name: iso-ubuntu annotations: cdi.kubevirt.io/storage.import.endpoint: "https://releases.ubuntu.com/jammy/ubuntu-22.04.3-live-server-amd64.iso" spec: accessModes: - ReadWriteOnce storageClassName: local-block volumeMode: Block resources: requests: storage: 5Gi
יוצרים משאב
PersistentVolumeClaimעם התוכן הבא עבור הדיסק הקשיח הווירטואלי של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: v1 kind: PersistentVolumeClaim metadata: name: ubuntuhd spec: accessModes: - ReadWriteOnce resources: requests: storage: 15Gi storageClassName: local-block volumeMode: Block
יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור תמונת הדיסק להתקנה של Ubuntu Server, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: "ubuntu-iso-disk" spec: persistentVolumeClaimName: iso-ubuntu diskType: cdrom
יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור הדיסק הקשיח הווירטואלי של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: "ubuntu-main-disk" spec: persistentVolumeClaimName: ubuntuhd
יוצרים משאב
VirtualMachineTypeעם התוכן הבא שמציין את ההגדרות של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineType metadata: name: small-2-20 spec: cpu: vcpus: 2 memory: capacity: 20Gi
יוצרים משאב
VirtualMachineעם התוכן הבא, שמפעיל את המכונה הווירטואלית באשכול, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachine metadata: labels: kubevirt.io/vm: ubu-vm name: ubu-vm # Propagate the virtual machine name to the VMI spec: osType: Linux compute: virtualMachineTypeName: small-2-20 interfaces: - name: eth0 networkName: pod-network default: true disks: - virtualMachineDiskName: ubuntu-main-disk boot: true - virtualMachineDiskName: ubuntu-iso-disk
השדה
osTypeרלוונטי רק לאשכולות של מישור בקרה מקומי. הוא נדרש באשכולות של מישור הבקרה המקומי כדי להגדיר את התכונות הבאות:מתקינים את Ubuntu Server במכונה הווירטואלית:
- מחכים עד ש-
importerPod יוריד את קובץ האימג' של דיסק ההתקנה של Ubuntu Server. בודקים את הסטטוס של המכונה הווירטואלית:
kubectl get gvm VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.מתחברים למכונה הווירטואלית:
kubectl virt vnc VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.משלימים את שלבי ההתקנה של Ubuntu Linux.
- מחכים עד ש-
לפנות:
מפסיקים את המכונה הווירטואלית:
kubectl virt stop VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.עורכים את קובץ ה-YAML של המכונה הווירטואלית כדי להסיר את ההפניה לקובץ האימג' של דיסק ההתקנה:
kubectl edit gvm VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.מפעילים את המכונה הווירטואלית:
kubectl virt start VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.מוחקים את המשאבים
VirtualMachineDiskו-PersistentVolumeClaimשל תמונת הדיסק להתקנה:kubectl delete virtualmachinedisk ubuntu-iso-disk kubectl delete pvc iso-ubuntu
הקצאת מכונה וירטואלית של Windows ב-Distributed Cloud עם אחסון בלוקים גולמי
בדוגמה הבאה אפשר לראות איך מקצים מכונה וירטואלית של Windows עם אחסון בלוקים גולמי. השלבים דומים לאלה של הקצאת מכונה וירטואלית של Linux, עם תוספת של תמונת הדיסק של מנהל ההתקן virtio, שנדרשת להתקנת Windows.
משיגים עותק מורשה של Windows וקובץ אימג' של מדיה להתקנה.
יוצרים משאב
PersistentVolumeClaimעם התוכן הבא עבור תמונת דיסק ההתקנה של Windows, ואז מחילים אותו על האשכול. הוראות מפורטות מופיעות בקטע מתוך תמונה.יוצרים משאב
PersistentVolumeClaimעם התוכן הבא עבור מנהל ההתקןvirtio, ואז מחילים אותו על האשכול:apiVersion: v1 kind: PersistentVolumeClaim metadata: labels: app: containerized-data-importer name: virtio-driver annotations: cdi.kubevirt.io/storage.import.endpoint: "https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso" spec: accessModes: - ReadWriteOnce storageClassName: local-block volumeMode: Block resources: requests: storage: 1Gi
יוצרים משאב
PersistentVolumeClaimעם התוכן הבא עבור הדיסק הקשיח הווירטואלי של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: v1 kind: PersistentVolumeClaim metadata: name: windowshd spec: accessModes: - ReadWriteOnce resources: requests: storage: 15Gi storageClassName: local-block volumeMode: Block
יוצרים משאב
VirtualMachineDiskעם התוכן הבא בשביל תמונת הדיסק להתקנה של Windows, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: "windows-iso-disk" spec: persistentVolumeClaimName: iso-windows diskType: cdrom
יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור מנהל ההתקןvirtio, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: "win-virtio-driver" spec: persistentVolumeClaimName: virtio-driver diskType: cdrom
יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור הדיסק הקשיח הווירטואלי של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: "windows-main-disk" spec: persistentVolumeClaimName: windowshd
יוצרים משאב
VirtualMachineTypeעם התוכן הבא שמציין את ההגדרות של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineType metadata: name: small-2-20 spec: cpu: vcpus: 2 memory: capacity: 20Gi
יוצרים משאב
VirtualMachineעם התוכן הבא, שמפעיל את המכונה הווירטואלית באשכול, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachine metadata: labels: kubevirt.io/vm: win-vm name: win-vm # Propagate the virtual machine name to the VMI spec: osType: Windows compute: virtualMachineTypeName: my-vmt interfaces: - name: eth0 networkName: pod-network default: true disks: - virtualMachineDiskName: windows-main-disk boot: true - virtualMachineDiskName: windows-iso-disk - virtualMachineDiskName: win-virtio-driver
השדה
osTypeרלוונטי רק לאשכולות של מישור בקרה מקומי. הוא נדרש באשכולות של מישור הבקרה המקומי כדי להגדיר את התכונות הבאות:מתקינים את Windows במכונה הווירטואלית:
- ממתינים להורדה של קובץ האימג' של דיסק ההתקנה של Windows ב-
importerPod. בודקים את הסטטוס של המכונה הווירטואלית:
kubectl get gvm VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –win-vmבדוגמה הזו.משלימים את ההתקנה של Windows לפי השלבים במאמר התחברות ל-VM של Windows והשלמת ההתקנה של מערכת ההפעלה.
- ממתינים להורדה של קובץ האימג' של דיסק ההתקנה של Windows ב-
לפנות:
מפסיקים את המכונה הווירטואלית:
kubectl virt stop VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –win-vmבדוגמה הזו.פועלים לפי ההוראות שבמאמר ניתוק קובץ ה-ISO ודיסק מנהלי ההתקנים.
הקצאת מכונה וירטואלית ב-Distributed Cloud באמצעות Symcloud Storage
בקטע הזה מופיעות דוגמאות להגדרות שממחישות איך להקצות מכונה וירטואלית של Linux ומכונה וירטואלית של Windows באשכול Distributed Cloud עם שכבת ההפשטה של Symcloud Storage.
לפני שמבצעים את השלבים שבקטע הזה, צריך קודם לבצע את השלבים שבקטע הגדרת Distributed Cloud ל-Symcloud Storage. אם תשביתו בהמשך את Symcloud Storage באשכול, המכונות הווירטואליות שהוגדרו לשימוש ב-Symcloud Storage ייכשלו.
הקצאת מכונה וירטואלית של Linux ב-Distributed Cloud באמצעות Symcloud Storage
בדוגמה הבאה מוסבר איך להקצות מכונה וירטואלית של Linux עם Symcloud Storage שמופעלת בה Ubuntu Server 22.04. מקור ההתקנה הוא קובץ אימג' של דיסק ISO של Ubuntu Server 22.04.
יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור תמונת הדיסק להתקנה של Ubuntu Server, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: ubuntu-iso-disk spec: size: 20Gi storageClassName: robin diskType: cdrom source: http: url: https://releases.ubuntu.com/jammy/ubuntu-22.04.3-live-server-amd64.iso
יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור הדיסק הקשיח הווירטואלי של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: "ubuntu-main-disk" spec: size: 200Gi storageClassName: robin
יוצרים משאב
VirtualMachineTypeעם התוכן הבא שמציין את ההגדרות של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineType metadata: name: small-2-20 spec: cpu: vcpus: 2 memory: capacity: 20Gi
יוצרים משאב
VirtualMachineעם התוכן הבא, שמפעיל את המכונה הווירטואלית באשכול, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachine metadata: labels: kubevirt.io/vm: ubu-vm name: ubu-vm # Propagate the virtual machine name to the VMI spec: osType: Linux compute: virtualMachineTypeName: small-2-20 interfaces: - name: eth0 networkName: pod-network default: true disks: - virtualMachineDiskName: ubuntu-main-disk boot: true - virtualMachineDiskName: ubuntu-iso-disk
השדה
osTypeרלוונטי רק לאשכולות של מישור בקרה מקומי. הוא נדרש באשכולות של מישור הבקרה המקומי כדי להגדיר את התכונות הבאות:מתקינים את Ubuntu Server במכונה הווירטואלית:
- מחכים עד ש-
importerPod יוריד את קובץ האימג' של דיסק ההתקנה של Ubuntu Server. בודקים את הסטטוס של המכונה הווירטואלית:
kubectl get gvm VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.מתחברים למכונה הווירטואלית:
kubectl virt vnc VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.משלימים את שלבי ההתקנה של Ubuntu Linux.
- מחכים עד ש-
לפנות:
מפסיקים את המכונה הווירטואלית:
kubectl virt stop VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.עורכים את קובץ ה-YAML של המכונה הווירטואלית כדי להסיר את ההפניה לקובץ האימג' של דיסק ההתקנה:
kubectl edit gvm VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.מפעילים את המכונה הווירטואלית:
kubectl virt start VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –ubu-vmבדוגמה הזו.מוחקים את משאב
VirtualMachineDiskשל קובץ האימג' של דיסק ההתקנה:kubectl delete virtualmachinedisk ubuntu-iso-disk
הקצאת מכונה וירטואלית של Windows ב-Distributed Cloud באמצעות Symcloud Storage
בדוגמה הבאה מוצג תהליך הקצאת מכונה וירטואלית של Windows עם Symcloud Storage. השלבים דומים לאלה של הקצאת מכונה וירטואלית של Linux, עם תוספת של תמונת הדיסק של מנהל ההתקן virtio, שנדרשת להתקנת Windows.
משיגים עותק מורשה של Windows וקובץ אימג' של מדיה להתקנה.
יוצרים משאב
VirtualMachineDiskעם התוכן הבא בשביל תמונת הדיסק להתקנה של Windows, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: windows-iso-disk namespace: default spec: size: 5Gi storageClassName: robin diskType: cdrom source: http: url: WINDOWS_ISO_URL
מחליפים את
NAT_GATEWAYבכתובת ה-URL המלאה של קובץ ה-ISO של התקנת Windows.יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור מנהל ההתקןvirtio, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: windows-virtio-driver namespace: default spec: size: 1Gi storageClassName: robin diskType: cdrom source: http: url: https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso
יוצרים משאב
VirtualMachineDiskעם התוכן הבא עבור הדיסק הקשיח הווירטואלי של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineDisk metadata: name: windows-main-disk namespace: default spec: size: 15Gi storageClassName: robin
יוצרים משאב
VirtualMachineTypeעם התוכן הבא שמציין את ההגדרות של המכונה הווירטואלית, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachineType metadata: name: small-2-20 spec: cpu: vcpus: 2 memory: capacity: 20Gi
יוצרים משאב
VirtualMachineעם התוכן הבא, שמפעיל את המכונה הווירטואלית באשכול, ואז מחילים אותו על האשכול:apiVersion: vm.cluster.gke.io/v1 kind: VirtualMachine metadata: labels: kubevirt.io/vm: win-vm name: win-vm # Propagate the virtual machine name to the VMI spec: osType: Windows compute: virtualMachineTypeName: my-vmt interfaces: - name: eth0 networkName: pod-network default: true disks: - virtualMachineDiskName: windows-main-disk boot: true - virtualMachineDiskName: windows-iso-disk - virtualMachineDiskName: win-virtio-driver
השדה
osTypeרלוונטי רק לאשכולות של מישור בקרה מקומי. הוא נדרש באשכולות של מישור הבקרה המקומי כדי להגדיר את התכונות הבאות:מתקינים את Windows במכונה הווירטואלית:
- ממתינים להורדה של קובץ האימג' של דיסק ההתקנה של Windows ב-
importerPod. בודקים את הסטטוס של המכונה הווירטואלית:
kubectl get gvm VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –win-vmבדוגמה הזו.משלימים את ההתקנה של Windows לפי השלבים במאמר התחברות ל-VM של Windows והשלמת ההתקנה של מערכת ההפעלה.
- ממתינים להורדה של קובץ האימג' של דיסק ההתקנה של Windows ב-
לפנות:
מפסיקים את המכונה הווירטואלית:
kubectl virt stop VM_NAME
מחליפים את
VM_NAMEבשם של המכונה הווירטואלית –win-vmבדוגמה הזו.פועלים לפי ההוראות שבמאמר ניתוק קובץ ה-ISO ודיסק מנהלי ההתקנים.
הקצאת מכונה וירטואלית ב-Distributed Cloud באמצעות virtctl
אם אתם לא צריכים את ההתאמה האישית שמתקבלת מכתיבת מפרטים משלכם למכונות וירטואליות, אתם יכולים להקצות מכונה וירטואלית ב-Distributed Cloud באמצעות virtctlכלי שורת הפקודה, כמו שמתואר במאמר יצירת מכונה וירטואלית.
ניהול מכונות וירטואליות שפועלות ב-Distributed Cloud
הוראות לניהול מכונות וירטואליות שפועלות ב-Distributed Cloud מופיעות במסמכי התיעוד הבאים בנושא VM Runtime ב-GDC:
- התחברות למכונות וירטואליות
- הצגה של רשימת מכונות וירטואליות
- ניהול מצב ההפעלה
- עריכת מכונה וירטואלית
- מחיקת מכונה וירטואלית
- צפייה ביומני המסוף של מכונה וירטואלית
כדי לנהל מכונות וירטואליות שפועלות באשכולות של מישור בקרה מקומי, קודם צריך להגדיר קישוריות של kubectl.
הגדרת מכשיר ttyS0 לגישה למסוף הטורי למכונות וירטואליות של Linux
אם אתם מתכננים לגשת למכונות וירטואליות של Linux באמצעות המסוף הטורי (kubectl virt console), אתם צריכים לוודא שהמסוף הטורי של ttyS0 הוגדר במערכת ההפעלה של האורח. כדי להגדיר את המכשיר הזה, צריך לבצע את השלבים הבאים:
יוצרים מופע של המכשיר עם יציאה טורית
ttyS0במערכת:setserial -g /dev/ttyS0
מגדירים את תוכנת האתחול
grubכך שתשתמש במכשיר עם יציאה טוריתttyS0על ידי הוספת השורות הבאות לקובץ התצורה/etc/default/grub. השורה הראשונה מחליפה את המשתנהGRUB_CMDLINE_LINUXהקיים.GRUB_CMDLINE_LINUX='console=tty0 console=ttyS0,19200n8' GRUB_TERMINAL=serial GRUB_SERIAL_COMMAND="serial --speed=19200 --unit=0 --word=8 --parity=no --stop=1"
מחילים את ההגדרה החדשה של
grubעל מגזר האתחול:update-grub
מפעילים מחדש את המכונה הווירטואלית.
השבתה של VM Runtime ב-GDC ב-Distributed Cloud
כדי להשבית את VM Runtime ב-GDC ב-Distributed Cloud, פועלים לפי השלבים שמפורטים בקטע הזה. לפני שמשביתים את VM Runtime ב-GDC ב-Distributed Cloud, צריך לעצור ולמחוק את כל המכונות הווירטואליות באשכול Distributed Cloud, כמו שמתואר במאמר מחיקת מכונה וירטואלית.
כדי להשבית את VM Runtime ב-GDC ב-Distributed Cloud, משנים את המשאב המותאם אישית VMRuntime על ידי הגדרת הפרמטר spec ל-false באופן הבא, ואז מחילים אותו על האשכול:enabled
apiVersion: vm.cluster.gke.io/v1 kind: VMRuntime metadata: name: vmruntime spec: # Disable Anthos VM Runtime enabled: false # vmImageFormat defaults to "raw" if not set vmImageFormat: "raw"
המאמרים הבאים
- פריסת עומסי עבודה ב-Distributed Cloud
- ניהול עומסי עבודה של GPU
- ניהול אזורים
- ניהול מכונות
- ניהול אשכולות
- ניהול מאגרי צמתים