Este conteúdo não está disponível no idioma selecionado.
Chapter 7. Virtual machines
7.1. Creating VMs from Red Hat images
7.1.1. Creating virtual machines from Red Hat images overview
					Red Hat images are golden images. They are published as container disks in a secure registry. The Containerized Data Importer (CDI) polls and imports the container disks into your cluster and stores them in the openshift-virtualization-os-images project as snapshots or persistent volume claims (PVCs).
				
Red Hat images are automatically updated. You can disable and re-enable automatic updates for these images. See Managing Red Hat boot source updates.
Cluster administrators can enable automatic subscription for Red Hat Enterprise Linux (RHEL) virtual machines in the OpenShift Virtualization web console.
You can create virtual machines (VMs) from operating system images provided by Red Hat by using one of the following methods:
						Do not create VMs in the default openshift-* namespaces. Instead, create a new namespace or use an existing namespace without the openshift prefix.
					
7.1.1.1. About golden images
A golden image is a preconfigured snapshot of a virtual machine (VM) that you can use as a resource to deploy new VMs. For example, you can use golden images to provision the same system environment consistently and deploy systems more quickly and efficiently.
7.1.1.1.1. How do golden images work?
Golden images are created by installing and configuring an operating system and software applications on a reference machine or virtual machine. This includes setting up the system, installing required drivers, applying patches and updates, and configuring specific options and preferences.
After the golden image is created, it is saved as a template or image file that can be replicated and deployed across multiple clusters. The golden image can be updated by its maintainer periodically to incorporate necessary software updates and patches, ensuring that the image remains up to date and secure, and newly created VMs are based on this updated image.
7.1.1.1.2. Red Hat implementation of golden images
Red Hat publishes golden images as container disks in the registry for versions of Red Hat Enterprise Linux (RHEL). Container disks are virtual machine images that are stored as a container image in a container image registry. Any published image will automatically be made available in connected clusters after the installation of OpenShift Virtualization. After the images are available in a cluster, they are ready to use to create VMs.
7.1.1.2. About VM boot sources
Virtual machines (VMs) consist of a VM definition and one or more disks that are backed by data volumes. VM templates enable you to create VMs using predefined specifications.
Every template requires a boot source, which is a fully configured disk image including configured drivers. Each template contains a VM definition with a pointer to the boot source. Each boot source has a predefined name and namespace. For some operating systems, a boot source is automatically provided. If it is not provided, then an administrator must prepare a custom boot source.
Provided boot sources are updated automatically to the latest version of the operating system. For auto-updated boot sources, persistent volume claims (PVCs) and volume snapshots are created with the cluster’s default storage class. If you select a different default storage class after configuration, you must delete the existing boot sources in the cluster namespace that are configured with the previous default storage class.
7.1.2. Creating virtual machines from templates
You can create virtual machines (VMs) from Red Hat templates by using the OpenShift Container Platform web console.
7.1.2.1. About VM templates
- Boot sources
- You can expedite VM creation by using templates that have an available boot source. Templates with a boot source are labeled Available boot source if they do not have a custom label. - Templates without a boot source are labeled Boot source required. See Creating virtual machines from custom images. 
- Customization
- You can customize the disk source and VM parameters before you start the VM: - See storage volume types and storage fields for details about disk source settings.
- See the Overview, YAML, and Configuration tab documentation for details about VM settings.
 
If you copy a VM template with all its labels and annotations, your version of the template is marked as deprecated when a new version of the Scheduling, Scale, and Performance (SSP) Operator is deployed. You can remove this designation. See Customizing a VM template by using the web console.
- Single-node OpenShift
- 
									Due to differences in storage behavior, some templates are incompatible with single-node OpenShift. To ensure compatibility, do not set the evictionStrategyfield for templates or VMs that use data volumes or storage profiles.
7.1.2.2. Creating a VM from a template
You can create a virtual machine (VM) from a template with an available boot source by using the OpenShift Container Platform web console.
Optional: You can customize template or VM parameters, such as data sources, cloud-init, or SSH keys, before you start the VM.
Procedure
- 
								Navigate to Virtualization Catalog in the web console. 
- Click Boot source available to filter templates with boot sources. - The catalog displays the default templates. Click All Items to view all available templates for your filters. 
- Click a template tile to view its details.
- Click Quick create VirtualMachine to create a VM from the template. - Optional: Customize the template or VM parameters: - Click Customize VirtualMachine.
- Expand Storage or Optional parameters to edit data source settings.
- Click Customize VirtualMachine parameters. - The Customize and create VirtualMachine pane displays the Overview, YAML, Scheduling, Environment, Network interfaces, Disks, Scripts, and Metadata tabs. 
- Edit the parameters that must be set before the VM boots, such as cloud-init or a static SSH key.
- Click Create VirtualMachine. - The VirtualMachine details page displays the provisioning status. 
 
7.1.2.2.1. Storage volume types
| Type | Description | 
|---|---|
| ephemeral | A local copy-on-write (COW) image that uses a network volume as a read-only backing store. The backing volume must be a PersistentVolumeClaim. The ephemeral image is created when the virtual machine starts and stores all writes locally. The ephemeral image is discarded when the virtual machine is stopped, restarted, or deleted. The backing volume (PVC) is not mutated in any way. | 
| persistentVolumeClaim | Attaches an available PV to a virtual machine. Attaching a PV allows for the virtual machine data to persist between sessions. Importing an existing virtual machine disk into a PVC by using CDI and attaching the PVC to a virtual machine instance is the recommended method for importing existing virtual machines into OpenShift Container Platform. There are some requirements for the disk to be used within a PVC. | 
| dataVolume | 
											Data volumes build on the  
											Specify  | 
| cloudInitNoCloud | Attaches a disk that contains the referenced cloud-init NoCloud data source, providing user data and metadata to the virtual machine. A cloud-init installation is required inside the virtual machine disk. | 
| containerDisk | References an image, such as a virtual machine disk, that is stored in the container image registry. The image is pulled from the registry and attached to the virtual machine as a disk when the virtual machine is launched. 
											A  Only RAW and QCOW2 formats are supported disk types for the container image registry. QCOW2 is recommended for reduced image size. Note 
												A  | 
| emptyDisk | Creates an additional sparse QCOW2 disk that is tied to the life-cycle of the virtual machine interface. The data survives guest-initiated reboots in the virtual machine but is discarded when the virtual machine stops or is restarted from the web console. The empty disk is used to store application dependencies and data that otherwise exceeds the limited temporary file system of an ephemeral disk. The disk capacity size must also be provided. | 
7.1.2.2.2. Storage fields
| Field | Description | 
|---|---|
| Blank (creates PVC) | Create an empty disk. | 
| Import via URL (creates PVC) | Import content via URL (HTTP or HTTPS endpoint). | 
| Use an existing PVC | Use a PVC that is already available in the cluster. | 
| Clone existing PVC (creates PVC) | Select an existing PVC available in the cluster and clone it. | 
| Import via Registry (creates PVC) | Import content via container registry. | 
| Container (ephemeral) | Upload content from a container located in a registry accessible from the cluster. The container disk should be used only for read-only filesystems such as CD-ROMs or temporary virtual machines. | 
| Name | 
											Name of the disk. The name can contain lowercase letters ( | 
| Size | Size of the disk in GiB. | 
| Type | Type of disk. Example: Disk or CD-ROM | 
| Interface | Type of disk device. Supported interfaces are virtIO, SATA, and SCSI. | 
| Storage Class | The storage class that is used to create the disk. | 
Advanced storage settings
The following advanced storage settings are optional and available for Blank, Import via URL, and Clone existing PVC disks.
If you do not specify these parameters, the system uses the default storage profile values.
| Parameter | Option | Parameter description | 
|---|---|---|
| Volume Mode | Filesystem | Stores the virtual disk on a file system-based volume. | 
| Block | 
											Stores the virtual disk directly on the block volume. Only use  | |
| Access Mode | ReadWriteOnce (RWO) | Volume can be mounted as read-write by a single node. | 
| ReadWriteMany (RWX) | Volume can be mounted as read-write by many nodes at one time. Note This mode is required for live migration. | 
7.1.2.2.3. Customizing a VM template by using the web console
You can customize an existing virtual machine (VM) template by modifying the VM or template parameters, such as data sources, cloud-init, or SSH keys, before you start the VM. If you customize a template by copying it and including all of its labels and annotations, the customized template is marked as deprecated when a new version of the Scheduling, Scale, and Performance (SSP) Operator is deployed.
You can remove the deprecated designation from the customized template.
Procedure
- 
									Navigate to Virtualization Templates in the web console. 
- From the list of VM templates, click the template marked as deprecated.
- Click Edit next to the pencil icon beside Labels.
- Remove the following two labels: - 
											template.kubevirt.io/type: "base"
- 
											template.kubevirt.io/version: "version"
 
- 
											
- Click Save.
- Click the pencil icon beside the number of existing Annotations.
- Remove the following annotation: - 
											template.kubevirt.io/deprecated
 
- 
											
- Click Save.
7.1.2.2.4. Creating a custom VM template in the web console
You create a virtual machine template by editing a YAML file example in the OpenShift Container Platform web console.
Procedure
- 
									In the web console, click Virtualization Templates in the side menu. 
- 
									Optional: Use the Project drop-down menu to change the project associated with the new template. All templates are saved to the openshiftproject by default.
- Click Create Template.
- Specify the template parameters by editing the YAML file.
- Click Create. - The template is displayed on the Templates page. 
- Optional: Click Download to download and save the YAML file.
7.1.3. Creating virtual machines from instance types
You can create virtual machines (VMs) from instance types by using the OpenShift Container Platform web console.
Creating a VM from an instance type is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
7.1.3.1. Creating a VM from an instance type
You can create a virtual machine (VM) from an instance type by using the OpenShift Container Platform web console.
Procedure
- 
								In the web console, navigate to Virtualization Catalog and click the InstanceTypes tab. 
- Select a bootable volume. Note- The volume table only lists volumes in the - openshift-virtualization-os-imagesnamespace that have the- instancetype.kubevirt.io/default-preferencelabel.
- Click an instance type tile and select the configuration appropriate for your workload.
- If you have not already added a public SSH key to your project, click the edit icon beside Authorized SSH key in the VirtualMachine details section.
- Select one of the following options: - Use existing: Select a secret from the secrets list.
- Add new: - Browse to the public SSH key file or paste the file in the key field.
- Enter the secret name.
- Optional: Select Automatically apply this key to any new VirtualMachine you create in this project.
- Click Save.
 
 
- Optional: Click View YAML & CLI to view the YAML file. Click CLI to view the CLI commands. You can also download or copy either the YAML file contents or the CLI commands.
- Click Create VirtualMachine.
After the VM is created, you can monitor the status on the VirtualMachine details page.
7.1.4. Creating virtual machines from the command line
					You can create virtual machines (VMs) from the command line by editing or creating a VirtualMachine manifest.
				
7.1.4.1. Creating a VM from a VirtualMachine manifest
						You can create a virtual machine (VM) from a VirtualMachine manifest.
					
Procedure
- Edit the - VirtualMachinemanifest for your VM. The following example configures a Red Hat Enterprise Linux (RHEL) VM:
- Create a virtual machine by using the manifest file: - oc create -f <vm_manifest_file>.yaml - $ oc create -f <vm_manifest_file>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: Start the virtual machine: - virtctl start <vm_name> -n <namespace> - $ virtctl start <vm_name> -n <namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.2. Creating VMs from custom images
7.2.1. Creating virtual machines from custom images overview
You can create virtual machines (VMs) from custom operating system images by using one of the following methods:
- Importing the image as a container disk from a registry. - Optional: You can enable auto updates for your container disks. See Managing automatic boot source updates for details. 
- Importing the image from a web page.
- Uploading the image from a local machine.
- Cloning a persistent volume claim (PVC) that contains the image.
The Containerized Data Importer (CDI) imports the image into a PVC by using a data volume. You add the PVC to the VM by using the OpenShift Container Platform web console or command line.
You must install the QEMU guest agent on VMs created from operating system images that are not provided by Red Hat.
You must also install VirtIO drivers on Windows VMs.
The QEMU guest agent is included with Red Hat images.
7.2.2. Creating VMs by using container disks
You can create virtual machines (VMs) by using container disks built from operating system images.
You can enable auto updates for your container disks. See Managing automatic boot source updates for details.
If the container disks are large, the I/O traffic might increase and cause worker nodes to be unavailable. You can perform the following tasks to resolve this issue:
You create a VM from a container disk by performing the following steps:
- Build an operating system image into a container disk and upload it to your container registry.
- If your container registry does not have TLS, configure your environment to disable TLS for your registry.
- Create a VM with the container disk as the disk source by using the web console or the command line.
You must install the QEMU guest agent on VMs created from operating system images that are not provided by Red Hat.
7.2.2.1. Building and uploading a container disk
You can build a virtual machine (VM) image into a container disk and upload it to a registry.
The size of a container disk is limited by the maximum layer size of the registry where the container disk is hosted.
For Red Hat Quay, you can change the maximum layer size by editing the YAML configuration file that is created when Red Hat Quay is first deployed.
Prerequisites
- 
								You must have podmaninstalled.
- You must have a QCOW2 or RAW image file.
Procedure
- Create a Dockerfile to build the VM image into a container image. The VM image must be owned by QEMU, which has a UID of - 107, and placed in the- /disk/directory inside the container. Permissions for the- /disk/directory must then be set to- 0440.- The following example uses the Red Hat Universal Base Image (UBI) to handle these configuration changes in the first stage, and uses the minimal - scratchimage in the second stage to store the result:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Where<vm_image>is the image in either QCOW2 or RAW format. If you use a remote image, replace<vm_image>.qcow2with the complete URL.
 
- Build and tag the container: - podman build -t <registry>/<container_disk_name>:latest . - $ podman build -t <registry>/<container_disk_name>:latest .- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Push the container image to the registry: - podman push <registry>/<container_disk_name>:latest - $ podman push <registry>/<container_disk_name>:latest- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.2.2.2. Disabling TLS for a container registry
						You can disable TLS (transport layer security) for one or more container registries by editing the insecureRegistries field of the HyperConverged custom resource.
					
Prerequisites
- Open the - HyperConvergedCR in your default editor by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add a list of insecure registries to the - spec.storageImport.insecureRegistriesfield.- Example - HyperConvergedcustom resource- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace the examples in this list with valid registry hostnames.
 
7.2.2.3. Creating a VM from a container disk by using the web console
You can create a virtual machine (VM) by importing a container disk from a container registry by using the OpenShift Container Platform web console.
Procedure
- 
								Navigate to Virtualization Catalog in the web console. 
- Click a template tile without an available boot source.
- Click Customize VirtualMachine.
- On the Customize template parameters page, expand Storage and select Registry (creates PVC) from the Disk source list.
- 
								Enter the container image URL. Example: https://mirror.arizona.edu/fedora/linux/releases/38/Cloud/x86_64/images/Fedora-Cloud-Base-38-1.6.x86_64.qcow2
- Set the disk size.
- Click Next.
- Click Create VirtualMachine.
7.2.2.4. Creating a VM from a container disk by using the command line
You can create a virtual machine (VM) from a container disk by using the command line.
When the virtual machine (VM) is created, the data volume with the container disk is imported into persistent storage.
Prerequisites
- You must have access credentials for the container registry that contains the container disk.
Procedure
- If the container registry requires authentication, create a - Secretmanifest, specifying the credentials, and save it as a- data-source-secret.yamlfile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the - Secretmanifest by running the following command:- oc apply -f data-source-secret.yaml - $ oc apply -f data-source-secret.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If the VM must communicate with servers that use self-signed certificates or certificates that are not signed by the system CA bundle, create a config map in the same namespace as the VM: - oc create configmap tls-certs - $ oc create configmap tls-certs- 1 - --from-file=</path/to/file/ca.pem>- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the - VirtualMachinemanifest and save it as a- vm-fedora-datavolume.yamlfile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the name of the VM.
- 2
- Specify the name of the data volume.
- 3
- Specify the size of the storage requested for the data volume.
- 4
- Optional: If you do not specify a storage class, the default storage class is used.
- 5
- Specify the URL of the container registry.
- 6
- Optional: Specify the secret name if you created a secret for the container registry access credentials.
- 7
- Optional: Specify a CA certificate config map.
 
- Create the VM by running the following command: - oc create -f vm-fedora-datavolume.yaml - $ oc create -f vm-fedora-datavolume.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The - oc createcommand creates the data volume and the VM. The CDI controller creates an underlying PVC with the correct annotation and the import process begins. When the import is complete, the data volume status changes to- Succeeded. You can start the VM.- Data volume provisioning happens in the background, so there is no need to monitor the process. 
Verification
- The importer pod downloads the container disk from the specified URL and stores it on the provisioned persistent volume. View the status of the importer pod by running the following command: - oc get pods - $ oc get pods- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Monitor the data volume until its status is - Succeededby running the following command:- oc describe dv fedora-dv - $ oc describe dv fedora-dv- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the data volume name that you defined in theVirtualMachinemanifest.
 
- Verify that provisioning is complete and that the VM has started by accessing its serial console: - virtctl console vm-fedora-datavolume - $ virtctl console vm-fedora-datavolume- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.2.3. Creating VMs by importing images from web pages
You can create virtual machines (VMs) by importing operating system images from web pages.
You must install the QEMU guest agent on VMs created from operating system images that are not provided by Red Hat.
7.2.3.1. Creating a VM from an image on a web page by using the web console
You can create a virtual machine (VM) by importing an image from a web page by using the OpenShift Container Platform web console.
Prerequisites
- You must have access to the web page that contains the image.
Procedure
- 
								Navigate to Virtualization Catalog in the web console. 
- Click a template tile without an available boot source.
- Click Customize VirtualMachine.
- On the Customize template parameters page, expand Storage and select URL (creates PVC) from the Disk source list.
- 
								Enter the image URL. Example: https://access.redhat.com/downloads/content/69/ver=/rhel---7/7.9/x86_64/product-software
- 
								Enter the container image URL. Example: https://mirror.arizona.edu/fedora/linux/releases/38/Cloud/x86_64/images/Fedora-Cloud-Base-38-1.6.x86_64.qcow2
- Set the disk size.
- Click Next.
- Click Create VirtualMachine.
7.2.3.2. Creating a VM from an image on a web page by using the command line
You can create a virtual machine (VM) from an image on a web page by using the command line.
When the virtual machine (VM) is created, the data volume with the image is imported into persistent storage.
Prerequisites
- You must have access credentials for the web page that contains the image.
Procedure
- If the web page requires authentication, create a - Secretmanifest, specifying the credentials, and save it as a- data-source-secret.yamlfile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the - Secretmanifest by running the following command:- oc apply -f data-source-secret.yaml - $ oc apply -f data-source-secret.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If the VM must communicate with servers that use self-signed certificates or certificates that are not signed by the system CA bundle, create a config map in the same namespace as the VM: - oc create configmap tls-certs - $ oc create configmap tls-certs- 1 - --from-file=</path/to/file/ca.pem>- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the - VirtualMachinemanifest and save it as a- vm-fedora-datavolume.yamlfile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the name of the VM.
- 2
- Specify the name of the data volume.
- 3
- Specify the size of the storage requested for the data volume.
- 4
- Optional: If you do not specify a storage class, the default storage class is used.
- 5 6
- Specify the URL of the web page.
- 7
- Optional: Specify the secret name if you created a secret for the web page access credentials.
- 8
- Optional: Specify a CA certificate config map.
 
- Create the VM by running the following command: - oc create -f vm-fedora-datavolume.yaml - $ oc create -f vm-fedora-datavolume.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The - oc createcommand creates the data volume and the VM. The CDI controller creates an underlying PVC with the correct annotation and the import process begins. When the import is complete, the data volume status changes to- Succeeded. You can start the VM.- Data volume provisioning happens in the background, so there is no need to monitor the process. 
Verification
- The importer pod downloads the image from the specified URL and stores it on the provisioned persistent volume. View the status of the importer pod by running the following command: - oc get pods - $ oc get pods- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Monitor the data volume until its status is - Succeededby running the following command:- oc describe dv fedora-dv - $ oc describe dv fedora-dv- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the data volume name that you defined in theVirtualMachinemanifest.
 
- Verify that provisioning is complete and that the VM has started by accessing its serial console: - virtctl console vm-fedora-datavolume - $ virtctl console vm-fedora-datavolume- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.2.4. Creating VMs by uploading images
You can create virtual machines (VMs) by uploading operating system images from your local machine.
You can create a Windows VM by uploading a Windows image to a PVC. Then you clone the PVC when you create the VM.
You must install the QEMU guest agent on VMs created from operating system images that are not provided by Red Hat.
You must also install VirtIO drivers on Windows VMs.
7.2.4.1. Creating a VM from an uploaded image by using the web console
You can create a virtual machine (VM) from an uploaded operating system image by using the OpenShift Container Platform web console.
Prerequisites
- 
								You must have an IMG,ISO, orQCOW2image file.
Procedure
- 
								Navigate to Virtualization Catalog in the web console. 
- Click a template tile without an available boot source.
- Click Customize VirtualMachine.
- On the Customize template parameters page, expand Storage and select Upload (Upload a new file to a PVC) from the Disk source list.
- Browse to the image on your local machine and set the disk size.
- Click Customize VirtualMachine.
- Click Create VirtualMachine.
7.2.4.2. Creating a Windows VM
You can create a Windows virtual machine (VM) by uploading a Windows image to a persistent volume claim (PVC) and then cloning the PVC when you create a VM by using the OpenShift Container Platform web console.
Prerequisites
- You created a Windows installation DVD or USB with the Windows Media Creation Tool. See Create Windows 10 installation media in the Microsoft documentation.
- 
								You created an autounattend.xmlanswer file. See Answer files (unattend.xml) in the Microsoft documentation.
Procedure
- Upload the Windows image as a new PVC: - 
										Navigate to Storage PersistentVolumeClaims in the web console. 
- 
										Click Create PersistentVolumeClaim With Data upload form. 
- Browse to the Windows image and select it.
- Enter the PVC name, select the storage class and size and then click Upload. - The Windows image is uploaded to a PVC. 
 
- 
										Navigate to Storage 
- Configure a new VM by cloning the uploaded PVC: - 
										Navigate to Virtualization Catalog. 
- Select a Windows template tile and click Customize VirtualMachine.
- Select Clone (clone PVC) from the Disk source list.
- Select the PVC project, the Windows image PVC, and the disk size.
 
- 
										Navigate to Virtualization 
- Apply the answer file to the VM: - Click Customize VirtualMachine parameters.
- On the Sysprep section of the Scripts tab, click Edit.
- 
										Browse to the autounattend.xmlanswer file and click Save.
 
- Set the run strategy of the VM: - Clear Start this VirtualMachine after creation so that the VM does not start immediately.
- Click Create VirtualMachine.
- 
										On the YAML tab, replace running:falsewithrunStrategy: RerunOnFailureand click Save.
 
- Click the options menu  and select Start. and select Start.- The VM boots from the - sysprepdisk containing the- autounattend.xmlanswer file.
7.2.4.2.1. Generalizing a Windows VM image
You can generalize a Windows operating system image to remove all system-specific configuration data before you use the image to create a new virtual machine (VM).
							Before generalizing the VM, you must ensure the sysprep tool cannot detect an answer file after the unattended Windows installation.
						
Prerequisites
- A running Windows VM with the QEMU guest agent installed.
Procedure
- 
									In the OpenShift Container Platform console, click Virtualization VirtualMachines. 
- Select a Windows VM to open the VirtualMachine details page.
- 
									Click Configuration Disks. 
- 
									Click the Options menu 
									 beside the beside thesysprepdisk and select Detach.
- Click Detach.
- 
									Rename C:\Windows\Panther\unattend.xmlto avoid detection by thesyspreptool.
- Start the - sysprepprogram by running the following command:- %WINDIR%\System32\Sysprep\sysprep.exe /generalize /shutdown /oobe /mode:vm - %WINDIR%\System32\Sysprep\sysprep.exe /generalize /shutdown /oobe /mode:vm- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									After the syspreptool completes, the Windows VM shuts down. The disk image of the VM is now available to use as an installation image for Windows VMs.
You can now specialize the VM.
7.2.4.2.2. Specializing a Windows VM image
Specializing a Windows virtual machine (VM) configures the computer-specific information from a generalized Windows image onto the VM.
Prerequisites
- You must have a generalized Windows disk image.
- 
									You must create an unattend.xmlanswer file. See the Microsoft documentation for details.
Procedure
- 
									In the OpenShift Container Platform console, click Virtualization Catalog. 
- Select a Windows template and click Customize VirtualMachine.
- Select PVC (clone PVC) from the Disk source list.
- Select the PVC project and PVC name of the generalized Windows image.
- Click Customize VirtualMachine parameters.
- Click the Scripts tab.
- 
									In the Sysprep section, click Edit, browse to the unattend.xmlanswer file, and click Save.
- Click Create VirtualMachine.
							During the initial boot, Windows uses the unattend.xml answer file to specialize the VM. The VM is now ready to use.
						
7.2.4.3. Creating a VM from an uploaded image by using the command line
						You can upload an operating system image by using the virtctl command-line tool. You can use an existing data volume or create a new data volume for the image.
					
Prerequisites
- 
								You must have an ISO,IMG, orQCOW2operating system image file.
- 
								For best performance, compress the image file by using the virt-sparsify tool or the xzorgziputilities.
- 
								You must have virtctlinstalled.
- The client machine must be configured to trust the OpenShift Container Platform router’s certificate.
Procedure
- Upload the image by running the - virtctl image-uploadcommand:- virtctl image-upload dv <datavolume_name> \ --size=<datavolume_size> \ --image-path=</path/to/image> \ - $ virtctl image-upload dv <datavolume_name> \- 1 - --size=<datavolume_size> \- 2 - --image-path=</path/to/image> \- 3 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- 
											If you do not want to create a new data volume, omit the --sizeparameter and include the--no-createflag.
- When uploading a disk image to a PVC, the PVC size must be larger than the size of the uncompressed virtual disk.
- 
											To allow insecure server connections when using HTTPS, use the --insecureparameter. When you use the--insecureflag, the authenticity of the upload endpoint is not verified.
 
- 
											If you do not want to create a new data volume, omit the 
- Optional. To verify that a data volume was created, view all data volumes by running the following command: - oc get dvs - $ oc get dvs- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.2.5. Creating VMs by cloning PVCs
You can create virtual machines (VMs) by cloning existing persistent volume claims (PVCs) with custom images.
You clone a PVC by creating a data volume that references a source PVC.
You must install the QEMU guest agent on VMs created from operating system images that are not provided by Red Hat.
7.2.5.1. Creating a VM from a PVC by using the web console
You can create a virtual machine (VM) by importing an image from a web page by using the OpenShift Container Platform web console. You can create a virtual machine (VM) by cloning a persistent volume claim (PVC) by using the OpenShift Container Platform web console.
Prerequisites
- You must have access to the web page that contains the image.
- You must have access to the namespace that contains the source PVC.
Procedure
- 
								Navigate to Virtualization Catalog in the web console. 
- Click a template tile without an available boot source.
- Click Customize VirtualMachine.
- On the Customize template parameters page, expand Storage and select PVC (clone PVC) from the Disk source list.
- 
								Enter the image URL. Example: https://access.redhat.com/downloads/content/69/ver=/rhel---7/7.9/x86_64/product-software
- 
								Enter the container image URL. Example: https://mirror.arizona.edu/fedora/linux/releases/38/Cloud/x86_64/images/Fedora-Cloud-Base-38-1.6.x86_64.qcow2
- Select the PVC project and the PVC name.
- Set the disk size.
- Click Next.
- Click Create VirtualMachine.
7.2.5.2. Creating a VM from a PVC by using the command line
You can create a virtual machine (VM) by cloning the persistent volume claim (PVC) of an existing VM by using the command line.
You can clone a PVC by using one of the following options:
- Cloning a PVC to a new data volume. - This method creates a data volume whose lifecycle is independent of the original VM. Deleting the original VM does not affect the new data volume or its associated PVC. 
- Cloning a PVC by creating a - VirtualMachinemanifest with a- dataVolumeTemplatesstanza.- This method creates a data volume whose lifecycle is dependent on the original VM. Deleting the original VM deletes the cloned data volume and its associated PVC. 
7.2.5.2.1. Optimizing clone Performance at scale in OpenShift Data Foundation
							When you use OpenShift Data Foundation, the storage profile configures the default cloning strategy as csi-clone. However, this method has limitations, as shown in the following link. After a certain number of clones are created from a persistent volume claim (PVC), a background flattening process begins, which can significantly reduce clone creation performance at scale.
						
							To improve performance when creating hundreds of clones from a single source PVC, use the VolumeSnapshot cloning method instead of the default csi-clone strategy.
						
Procedure
								Create a VolumeSnapshot custom resource (CR) of the source image by using the following content:
							
- 
									Add the spec.source.snapshotstanza to reference theVolumeSnapshotas the source for theDataVolume clone:
spec:
  source:
    snapshot:
      namespace: golden-ns
      name: golden-volumesnapshot
spec:
  source:
    snapshot:
      namespace: golden-ns
      name: golden-volumesnapshot7.2.5.2.2. Cloning a PVC to a data volume
You can clone the persistent volume claim (PVC) of an existing virtual machine (VM) disk to a data volume by using the command line.
You create a data volume that references the original source PVC. The lifecycle of the new data volume is independent of the original VM. Deleting the original VM does not affect the new data volume or its associated PVC.
							Cloning between different volume modes is supported for host-assisted cloning, such as cloning from a block persistent volume (PV) to a file system PV, as long as the source and target PVs belong to the kubevirt content type.
						
Smart-cloning is faster and more efficient than host-assisted cloning because it uses snapshots to clone PVCs. Smart-cloning is supported by storage providers that support snapshots, such as Red Hat OpenShift Data Foundation.
Cloning between different volume modes is not supported for smart-cloning.
Prerequisites
- The VM with the source PVC must be powered down.
- If you clone a PVC to a different namespace, you must have permissions to create resources in the target namespace.
- Additional prerequisites for smart-cloning: - Your storage provider must support snapshots.
- The source and target PVCs must have the same storage provider and volume mode.
- The value of the - driverkey of the- VolumeSnapshotClassobject must match the value of the- provisionerkey of the- StorageClassobject as shown in the following example:- Example - VolumeSnapshotClassobject- kind: VolumeSnapshotClass apiVersion: snapshot.storage.k8s.io/v1 driver: openshift-storage.rbd.csi.ceph.com # ... - kind: VolumeSnapshotClass apiVersion: snapshot.storage.k8s.io/v1 driver: openshift-storage.rbd.csi.ceph.com # ...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example - StorageClassobject- kind: StorageClass apiVersion: storage.k8s.io/v1 # ... provisioner: openshift-storage.rbd.csi.ceph.com - kind: StorageClass apiVersion: storage.k8s.io/v1 # ... provisioner: openshift-storage.rbd.csi.ceph.com- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
Procedure
- Create a - DataVolumemanifest as shown in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the data volume by running the following command: - oc create -f <datavolume>.yaml - $ oc create -f <datavolume>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- Data volumes prevent a VM from starting before the PVC is prepared. You can create a VM that references the new data volume while the PVC is being cloned. 
7.2.5.2.3. Creating a VM from a cloned PVC by using a data volume template
You can create a virtual machine (VM) that clones the persistent volume claim (PVC) of an existing VM by using a data volume template.
This method creates a data volume whose lifecycle is dependent on the original VM. Deleting the original VM deletes the cloned data volume and its associated PVC.
Prerequisites
- The VM with the source PVC must be powered down.
Procedure
- Create a - VirtualMachinemanifest as shown in the following example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the virtual machine with the PVC-cloned data volume: - oc create -f <vm-clone-datavolumetemplate>.yaml - $ oc create -f <vm-clone-datavolumetemplate>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.2.6. Installing the QEMU guest agent and VirtIO drivers
The QEMU guest agent is a daemon that runs on the virtual machine (VM) and passes information to the host about the VM, users, file systems, and secondary networks.
You must install the QEMU guest agent on VMs created from operating system images that are not provided by Red Hat.
7.2.6.1. Installing the QEMU guest agent
7.2.6.1.1. Installing the QEMU guest agent on a Linux VM
							The qemu-guest-agent is widely available and available by default in Red Hat Enterprise Linux (RHEL) virtual machines (VMs). Install the agent and start the service.
						
To create snapshots of an online (Running state) VM with the highest integrity, install the QEMU guest agent.
The QEMU guest agent takes a consistent snapshot by attempting to quiesce the VM file system as much as possible, depending on the system workload. This ensures that in-flight I/O is written to the disk before the snapshot is taken. If the guest agent is not present, quiescing is not possible and a best-effort snapshot is taken. The conditions under which the snapshot was taken are reflected in the snapshot indications that are displayed in the web console or CLI.
Procedure
- Log in to the VM by using a console or SSH.
- Install the QEMU guest agent by running the following command: - yum install -y qemu-guest-agent - $ yum install -y qemu-guest-agent- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Ensure the service is persistent and start it: - systemctl enable --now qemu-guest-agent - $ systemctl enable --now qemu-guest-agent- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Run the following command to verify that - AgentConnectedis listed in the VM spec:- oc get vm <vm_name> - $ oc get vm <vm_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.2.6.1.2. Installing the QEMU guest agent on a Windows VM
For Windows virtual machines (VMs), the QEMU guest agent is included in the VirtIO drivers. You can install the drivers during a Windows installation or on an existing Windows VM.
To create snapshots of an online (Running state) VM with the highest integrity, install the QEMU guest agent.
The QEMU guest agent takes a consistent snapshot by attempting to quiesce the VM file system as much as possible, depending on the system workload. This ensures that in-flight I/O is written to the disk before the snapshot is taken. If the guest agent is not present, quiescing is not possible and a best-effort snapshot is taken. The conditions under which the snapshot was taken are reflected in the snapshot indications that are displayed in the web console or CLI.
Procedure
- 
									In the Windows guest operating system, use the File Explorer to navigate to the guest-agentdirectory in thevirtio-winCD drive.
- 
									Run the qemu-ga-x86_64.msiinstaller.
Verification
- Obtain a list of network services by running the following command: - net start - $ net start- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Verify that the output contains the QEMU Guest Agent.
7.2.6.2. Installing VirtIO drivers on Windows VMs
VirtIO drivers are paravirtualized device drivers required for Microsoft Windows virtual machines (VMs) to run in OpenShift Virtualization. The drivers are shipped with the rest of the images and do not require a separate download.
						The container-native-virtualization/virtio-win container disk must be attached to the VM as a SATA CD drive to enable driver installation. You can install VirtIO drivers during Windows installation or added to an existing Windows installation.
					
						After the drivers are installed, the container-native-virtualization/virtio-win container disk can be removed from the VM.
					
| Driver name | Hardware ID | Description | 
|---|---|---|
| viostor | 
										VEN_1AF4&DEV_1001 | The block driver. Sometimes labeled as an SCSI Controller in the Other devices group. | 
| viorng | 
										VEN_1AF4&DEV_1005 | The entropy source driver. Sometimes labeled as a PCI Device in the Other devices group. | 
| NetKVM | 
										VEN_1AF4&DEV_1000 | The network driver. Sometimes labeled as an Ethernet Controller in the Other devices group. Available only if a VirtIO NIC is configured. | 
7.2.6.2.1. Attaching VirtIO container disk to Windows VMs during installation
You must attach the VirtIO container disk to the Windows VM to install the necessary Windows drivers. This can be done during creation of the VM.
Procedure
- When creating a Windows VM from a template, click Customize VirtualMachine.
- Select Mount Windows drivers disk.
- Click the Customize VirtualMachine parameters.
- Click Create VirtualMachine.
							After the VM is created, the virtio-win SATA CD disk will be attached to the VM.
						
7.2.6.2.2. Attaching VirtIO container disk to an existing Windows VM
You must attach the VirtIO container disk to the Windows VM to install the necessary Windows drivers. This can be done to an existing VM.
Procedure
- 
									Navigate to the existing Windows VM, and click Actions Stop. 
- 
									Go to VM Details Configuration Disks and click Add disk. 
- 
									Add windows-driver-diskfrom container source, set the Type to CD-ROM, and then set the Interface to SATA.
- Click Save.
- Start the VM, and connect to a graphical console.
7.2.6.2.3. Installing VirtIO drivers during Windows installation
You can install the VirtIO drivers while installing Windows on a virtual machine (VM).
This procedure uses a generic approach to the Windows installation and the installation method might differ between versions of Windows. See the documentation for the version of Windows that you are installing.
Prerequisites
- 
									A storage device containing the virtiodrivers must be attached to the VM.
Procedure
- 
									In the Windows operating system, use the File Explorerto navigate to thevirtio-winCD drive.
- Double-click the drive to run the appropriate installer for your VM. - For a 64-bit vCPU, select the - virtio-win-gt-x64installer. 32-bit vCPUs are no longer supported.
- Optional: During the Custom Setup step of the installer, select the device drivers you want to install. The recommended driver set is selected by default.
- After the installation is complete, select Finish.
- Reboot the VM.
Verification
- 
									Open the system disk on the PC. This is typically C:.
- 
									Navigate to Program Files Virtio-Win. 
If the Virtio-Win directory is present and contains a sub-directory for each driver, the installation was successful.
7.2.6.2.4. Installing VirtIO drivers from a SATA CD drive on an existing Windows VM
You can install the VirtIO drivers from a SATA CD drive on an existing Windows virtual machine (VM).
This procedure uses a generic approach to adding drivers to Windows. See the installation documentation for your version of Windows for specific installation steps.
Prerequisites
- A storage device containing the virtio drivers must be attached to the VM as a SATA CD drive.
Procedure
- Start the VM and connect to a graphical console.
- Log in to a Windows user session.
- Open Device Manager and expand Other devices to list any Unknown device. - Open the Device Properties to identify the unknown device.
- Right-click the device and select Properties.
- Click the Details tab and select Hardware Ids in the Property list.
- Compare the Value for the Hardware Ids with the supported VirtIO drivers.
 
- Right-click the device and select Update Driver Software.
- Click Browse my computer for driver software and browse to the attached SATA CD drive, where the VirtIO drivers are located. The drivers are arranged hierarchically according to their driver type, operating system, and CPU architecture.
- Click Next to install the driver.
- Repeat this process for all the necessary VirtIO drivers.
- After the driver installs, click Close to close the window.
- Reboot the VM to complete the driver installation.
7.2.6.2.5. Installing VirtIO drivers from a container disk added as a SATA CD drive
You can install VirtIO drivers from a container disk that you add to a Windows virtual machine (VM) as a SATA CD drive.
							Downloading the container-native-virtualization/virtio-win container disk from the Red Hat Ecosystem Catalog is not mandatory, because the container disk is downloaded from the Red Hat registry if it not already present in the cluster. However, downloading reduces the installation time.
						
Prerequisites
- 
									You must have access to the Red Hat registry or to the downloaded container-native-virtualization/virtio-wincontainer disk in a restricted environment.
Procedure
- Add the - container-native-virtualization/virtio-wincontainer disk as a CD drive by editing the- VirtualMachinemanifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- OpenShift Virtualization boots the VM disks in the order defined in theVirtualMachinemanifest. You can either define other VM disks that boot before thecontainer-native-virtualization/virtio-wincontainer disk or use the optionalbootOrderparameter to ensure the VM boots from the correct disk. If you configure the boot order for a disk, you must configure the boot order for the other disks.
 
- Apply the changes: - If the VM is not running, run the following command: - virtctl start <vm> -n <namespace> - $ virtctl start <vm> -n <namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If the VM is running, reboot the VM or run the following command: - oc apply -f <vm.yaml> - $ oc apply -f <vm.yaml>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- After the VM has started, install the VirtIO drivers from the SATA CD drive.
7.2.6.3. Updating VirtIO drivers
7.2.6.3.1. Updating VirtIO drivers on a Windows VM
							Update the virtio drivers on a Windows virtual machine (VM) by using the Windows Update service.
						
Prerequisites
- The cluster must be connected to the internet. Disconnected clusters cannot reach the Windows Update service.
Procedure
- In the Windows Guest operating system, click the Windows key and select Settings.
- 
									Navigate to Windows Update Advanced Options Optional Updates. 
- Install all updates from Red Hat, Inc..
- Reboot the VM.
Verification
- On the Windows VM, navigate to the Device Manager.
- Select a device.
- Select the Driver tab.
- 
									Click Driver Details and confirm that the virtiodriver details displays the correct version.
7.3. Connecting to virtual machine consoles
You can connect to the following consoles to access running virtual machines (VMs):
7.3.1. Connecting to the VNC console
					You can connect to the VNC console of a virtual machine by using the OpenShift Container Platform web console or the virtctl command-line tool.
				
7.3.1.1. Connecting to the VNC console by using the web console
You can connect to the VNC console of a virtual machine (VM) by using the OpenShift Container Platform web console.
If you connect to a Windows VM with a vGPU assigned as a mediated device, you can switch between the default display and the vGPU display.
Procedure
- 
								On the Virtualization VirtualMachines page, click a VM to open the VirtualMachine details page. 
- Click the Console tab. The VNC console session starts automatically.
- Optional: To switch to the vGPU display of a Windows VM, select Ctl + Alt + 2 from the Send key list. - Select Ctl + Alt + 1 from the Send key list to restore the default display.
 
- To end the console session, click outside the console pane and then click Disconnect.
7.3.1.2. Connecting to the VNC console by using virtctl
						You can use the virtctl command-line tool to connect to the VNC console of a running virtual machine.
					
							If you run the virtctl vnc command on a remote machine over an SSH connection, you must forward the X session to your local machine by running the ssh command with the -X or -Y flags.
						
Prerequisites
- 
								You must install the virt-viewerpackage.
Procedure
- Run the following command to start the console session: - virtctl vnc <vm_name> - $ virtctl vnc <vm_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If the connection fails, run the following command to collect troubleshooting information: - virtctl vnc <vm_name> -v 4 - $ virtctl vnc <vm_name> -v 4- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.3.1.3. Generating a temporary token for the VNC console
Generate a temporary authentication bearer token for the Kubernetes API to access the VNC of a virtual machine (VM).
Kubernetes also supports authentication using client certificates, instead of a bearer token, by modifying the curl command.
Prerequisites
- 
								A running VM with OpenShift Virtualization 4.14 or later and ssp-operator4.14 or later.
Procedure
- Enable the feature gate in the HyperConverged ( - HCO) custom resource (CR):- oc patch hyperconverged kubevirt-hyperconverged -n openshift-cnv --type json -p '[{"op": "replace", "path": "/spec/featureGates/deployVmConsoleProxy", "value": true}]'- $ oc patch hyperconverged kubevirt-hyperconverged -n openshift-cnv --type json -p '[{"op": "replace", "path": "/spec/featureGates/deployVmConsoleProxy", "value": true}]'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Generate a token by running the following command: - curl --header "Authorization: Bearer ${TOKEN}" \ "https://api.<cluster_fqdn>/apis/token.kubevirt.io/v1alpha1/namespaces/<namespace>/virtualmachines/<vm_name>/vnc?duration=<duration>"- $ curl --header "Authorization: Bearer ${TOKEN}" \ "https://api.<cluster_fqdn>/apis/token.kubevirt.io/v1alpha1/namespaces/<namespace>/virtualmachines/<vm_name>/vnc?duration=<duration>"- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Duration can be in hours and minutes, with a minimum duration of 10 minutes. Example:5h30m. The token is valid for 10 minutes by default if this parameter is not set.
 - Sample output: - { "token": "eyJhb..." }- { "token": "eyJhb..." }- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: Use the token provided in the output to create a variable: - export VNC_TOKEN="<token>" - $ export VNC_TOKEN="<token>"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
You can now use the token to access the VNC console of a VM.
Verification
- Log in to the cluster by running the following command: - oc login --token ${VNC_TOKEN}- $ oc login --token ${VNC_TOKEN}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use - virtctlto test access to the VNC console of the VM by running the following command:- virtctl vnc <vm_name> -n <namespace> - $ virtctl vnc <vm_name> -n <namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.3.2. Connecting to the serial console
					You can connect to the serial console of a virtual machine by using the OpenShift Container Platform web console or the virtctl command-line tool.
				
Running concurrent VNC connections to a single virtual machine is not currently supported.
7.3.2.1. Connecting to the serial console by using the web console
You can connect to the serial console of a virtual machine (VM) by using the OpenShift Container Platform web console.
If you connect to a Windows VM with a vGPU assigned as a mediated device, you can switch between the default display and the vGPU display.
Procedure
- 
								On the Virtualization VirtualMachines page, click a VM to open the VirtualMachine details page. 
- Click the Console tab. The VNC console session starts automatically.
- Click Disconnect to end the VNC console session. Otherwise, the VNC console session continues to run in the background.
- Select Serial console from the console list.
- Optional: To switch to the vGPU display of a Windows VM, select Ctl + Alt + 2 from the Send key list. - Select Ctl + Alt + 1 from the Send key list to restore the default display.
 
- To end the console session, click outside the console pane and then click Disconnect.
7.3.2.2. Connecting to the serial console by using virtctl
						You can use the virtctl command-line tool to connect to the serial console of a running virtual machine.
					
							If you run the virtctl vnc command on a remote machine over an SSH connection, you must forward the X session to your local machine by running the ssh command with the -X or -Y flags.
						
Prerequisites
- 
								You must install the virt-viewerpackage.
Procedure
- Run the following command to start the console session: - virtctl console <vm_name> - $ virtctl console <vm_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Press - Ctrl+]to end the console session.- virtctl vnc <vm_name> - $ virtctl vnc <vm_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If the connection fails, run the following command to collect troubleshooting information: - virtctl vnc <vm_name> -v 4 - $ virtctl vnc <vm_name> -v 4- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.3.3. Connecting to the desktop viewer
You can connect to a Windows virtual machine (VM) by using the desktop viewer and the Remote Desktop Protocol (RDP).
7.3.3.1. Connecting to the desktop viewer by using the web console
You can connect to the desktop viewer of a virtual machine (VM) by using the OpenShift Container Platform web console. You can connect to the desktop viewer of a Windows virtual machine (VM) by using the OpenShift Container Platform web console.
If you connect to a Windows VM with a vGPU assigned as a mediated device, you can switch between the default display and the vGPU display.
Prerequisites
- You installed the QEMU guest agent on the Windows VM.
- You have an RDP client installed.
Procedure
- 
								On the Virtualization VirtualMachines page, click a VM to open the VirtualMachine details page. 
- Click the Console tab. The VNC console session starts automatically.
- Click Disconnect to end the VNC console session. Otherwise, the VNC console session continues to run in the background.
- Select Desktop viewer from the console list.
- Click Create RDP Service to open the RDP Service dialog.
- Select Expose RDP Service and click Save to create a node port service.
- 
								Click Launch Remote Desktop to download an .rdpfile and launch the desktop viewer.
- Optional: To switch to the vGPU display of a Windows VM, select Ctl + Alt + 2 from the Send key list. - Select Ctl + Alt + 1 from the Send key list to restore the default display.
 
- To end the console session, click outside the console pane and then click Disconnect.
7.4. Configuring SSH access to virtual machines
You can configure SSH access to virtual machines (VMs) by using the following methods:
- You create an SSH key pair, add the public key to a VM, and connect to the VM by running the - virtctl sshcommand with the private key.- You can add public SSH keys to Red Hat Enterprise Linux (RHEL) 9 VMs at runtime or at first boot to VMs with guest operating systems that can be configured by using a cloud-init data source. 
- You add the - virtctl port-fowardcommand to your- .ssh/configfile and connect to the VM by using OpenSSH.
- You create a service, associate the service with the VM, and connect to the IP address and port exposed by the service. 
- You configure a secondary network, attach a virtual machine (VM) to the secondary network interface, and connect to the DHCP-allocated IP address. 
7.4.1. Access configuration considerations
Each method for configuring access to a virtual machine (VM) has advantages and limitations, depending on the traffic load and client requirements.
Services provide excellent performance and are recommended for applications that are accessed from outside the cluster.
If the internal cluster network cannot handle the traffic load, you can configure a secondary network.
- virtctl sshand- virtctl port-forwardingcommands
- Simple to configure.
- Recommended for troubleshooting VMs.
- 
										virtctl port-forwardingrecommended for automated configuration of VMs with Ansible.
- Dynamic public SSH keys can be used to provision VMs with Ansible.
- Not recommended for high-traffic applications like Rsync or Remote Desktop Protocol because of the burden on the API server.
- The API server must be able to handle the traffic load.
- The clients must be able to access the API server.
- The clients must have access credentials for the cluster.
 
- Cluster IP service
- The internal cluster network must be able to handle the traffic load.
- The clients must be able to access an internal cluster IP address.
 
- Node port service
- The internal cluster network must be able to handle the traffic load.
- The clients must be able to access at least one node.
 
- Load balancer service
- A load balancer must be configured.
- Each node must be able to handle the traffic load of one or more load balancer services.
 
- Secondary network
- Excellent performance because traffic does not go through the internal cluster network.
- Allows a flexible approach to network topology.
- Guest operating system must be configured with appropriate security because the VM is exposed directly to the secondary network. If a VM is compromised, an intruder could gain access to the secondary network.
 
7.4.2. Using virtctl ssh
					You can add a public SSH key to a virtual machine (VM) and connect to the VM by running the virtctl ssh command.
				
This method is simple to configure. However, it is not recommended for high traffic loads because it places a burden on the API server.
7.4.2.1. About static and dynamic SSH key management
You can add public SSH keys to virtual machines (VMs) statically at first boot or dynamically at runtime.
Only Red Hat Enterprise Linux (RHEL) 9 supports dynamic key injection.
Static SSH key management
You can add a statically managed SSH key to a VM with a guest operating system that supports configuration by using a cloud-init data source. The key is added to the virtual machine (VM) at first boot.
You can add the key by using one of the following methods:
- Add a key to a single VM when you create it by using the web console or the command line.
- Add a key to a project by using the web console. Afterwards, the key is automatically added to the VMs that you create in this project.
Use cases
- As a VM owner, you can provision all your newly created VMs with a single key.
Dynamic SSH key management
You can enable dynamic SSH key management for a VM with Red Hat Enterprise Linux (RHEL) 9 installed. Afterwards, you can update the key during runtime. The key is added by the QEMU guest agent, which is installed with Red Hat boot sources.
When dynamic key management is disabled, the default key management setting of a VM is determined by the image used for the VM.
Use cases
- 
								Granting or revoking access to VMs: As a cluster administrator, you can grant or revoke remote VM access by adding or removing the keys of individual users from a Secretobject that is applied to all VMs in a namespace.
- User access: You can add your access credentials to all VMs that you create and manage.
- Ansible provisioning: - As an operations team member, you can create a single secret that contains all the keys used for Ansible provisioning.
- As a VM owner, you can create a VM and attach the keys used for Ansible provisioning.
 
- Key rotation: - As a cluster administrator, you can rotate the Ansible provisioner keys used by VMs in a namespace.
- As a workload owner, you can rotate the key for the VMs that you manage.
 
7.4.2.2. Static key management
You can add a statically managed public SSH key when you create a virtual machine (VM) by using the OpenShift Container Platform web console or the command line. The key is added as a cloud-init data source when the VM boots for the first time.
You can also add a public SSH key to a project when you create a VM by using the web console. The key is saved as a secret and is added automatically to all VMs that you create.
If you add a secret to a project and then delete the VM, the secret is retained because it is a namespace resource. You must delete the secret manually.
7.4.2.2.1. Adding a key when creating a VM from a template
You can add a statically managed public SSH key when you create a virtual machine (VM) by using the OpenShift Container Platform web console. The key is added to the VM as a cloud-init data source at first boot. This method does not affect cloud-init user data.
Optional: You can add a key to a project. Afterwards, this key is added automatically to VMs that you create in the project.
Prerequisites
- 
									You generated an SSH key pair by running the ssh-keygencommand.
Procedure
- 
									Navigate to Virtualization Catalog in the web console. 
- Click a template tile. - The guest operating system must support configuration from a cloud-init data source. 
- Click Customize VirtualMachine.
- Click Next.
- Click the Scripts tab.
- If you have not already added a public SSH key to your project, click the edit icon beside Authorized SSH key and select one of the following options: - Use existing: Select a secret from the secrets list.
- Add new: - Browse to the SSH key file or paste the file in the key field.
- Enter the secret name.
- Optional: Select Automatically apply this key to any new VirtualMachine you create in this project.
 
 
- Click Save.
- Click Create VirtualMachine. - The VirtualMachine details page displays the progress of the VM creation. 
Verification
- Click the Scripts tab on the Configuration tab. - The secret name is displayed in the Authorized SSH key section. 
7.4.2.2.2. Adding a key when creating a VM from an instance type
You can create a virtual machine (VM) from an instance type by using the OpenShift Container Platform web console. You can add a statically managed SSH key when you create a virtual machine (VM) from an instance type by using the OpenShift Container Platform web console. The key is added to the VM as a cloud-init data source at first boot. This method does not affect cloud-init user data.
Procedure
- 
									In the web console, navigate to Virtualization Catalog and click the InstanceTypes tab. 
- Select a bootable volume. Note- The volume table only lists volumes in the - openshift-virtualization-os-imagesnamespace that have the- instancetype.kubevirt.io/default-preferencelabel.
- Click an instance type tile and select the configuration appropriate for your workload.
- If you have not already added a public SSH key to your project, click the edit icon beside Authorized SSH key in the VirtualMachine details section.
- Select one of the following options: - Use existing: Select a secret from the secrets list.
- Add new: - Browse to the public SSH key file or paste the file in the key field.
- Enter the secret name.
- Optional: Select Automatically apply this key to any new VirtualMachine you create in this project.
- Click Save.
 
 
- Optional: Click View YAML & CLI to view the YAML file. Click CLI to view the CLI commands. You can also download or copy either the YAML file contents or the CLI commands.
- Click Create VirtualMachine.
After the VM is created, you can monitor the status on the VirtualMachine details page.
7.4.2.2.3. Adding a key when creating a VM by using the command line
You can add a statically managed public SSH key when you create a virtual machine (VM) by using the command line. The key is added to the VM at first boot.
The key is added to the VM as a cloud-init data source. This method separates the access credentials from the application data in the cloud-init user data. This method does not affect cloud-init user data.
Prerequisites
- 
									You generated an SSH key pair by running the ssh-keygencommand.
Procedure
- Create a manifest file for a - VirtualMachineobject and a- Secretobject:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - <.> Specify - cloudInitConfigDriveto create a configuration drive. <.> Specify the- Secretobject name. <.> Paste the public SSH key.
- Create the - VirtualMachineand- Secretobjects:- oc create -f <manifest_file>.yaml - $ oc create -f <manifest_file>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Start the VM: - virtctl start vm example-vm -n example-namespace - $ virtctl start vm example-vm -n example-namespace- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Get the VM configuration: - oc describe vm example-vm -n example-namespace - $ oc describe vm example-vm -n example-namespace- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.4.2.3. Dynamic key management
You can enable dynamic key injection for a virtual machine (VM) by using the OpenShift Container Platform web console or the command line. Then, you can update the key at runtime.
Only Red Hat Enterprise Linux (RHEL) 9 supports dynamic key injection.
If you disable dynamic key injection, the VM inherits the key management method of the image from which it was created.
7.4.2.3.1. Enabling dynamic key injection when creating a VM from a template
You can enable dynamic public SSH key injection when you create a virtual machine (VM) from a template by using the OpenShift Container Platform web console. Then, you can update the key at runtime.
Only Red Hat Enterprise Linux (RHEL) 9 supports dynamic key injection.
The key is added to the VM by the QEMU guest agent, which is installed with RHEL 9.
Prerequisites
- 
									You generated an SSH key pair by running the ssh-keygencommand.
Procedure
- 
									Navigate to Virtualization Catalog in the web console. 
- Click the Red Hat Enterprise Linux 9 VM tile.
- Click Customize VirtualMachine.
- Click Next.
- Click the Scripts tab.
- If you have not already added a public SSH key to your project, click the edit icon beside Authorized SSH key and select one of the following options: - Use existing: Select a secret from the secrets list.
- Add new: - Browse to the SSH key file or paste the file in the key field.
- Enter the secret name.
- Optional: Select Automatically apply this key to any new VirtualMachine you create in this project.
 
 
- Set Dynamic SSH key injection to on.
- Click Save.
- Click Create VirtualMachine. - The VirtualMachine details page displays the progress of the VM creation. 
Verification
- Click the Scripts tab on the Configuration tab. - The secret name is displayed in the Authorized SSH key section. 
7.4.2.3.2. Enabling dynamic key injection when creating a VM from an instance type
You can create a virtual machine (VM) from an instance type by using the OpenShift Container Platform web console. You can enable dynamic SSH key injection when you create a virtual machine (VM) from an instance type by using the OpenShift Container Platform web console. Then, you can add or revoke the key at runtime.
Only Red Hat Enterprise Linux (RHEL) 9 supports dynamic key injection.
The key is added to the VM by the QEMU guest agent, which is installed with RHEL 9.
Procedure
- 
									In the web console, navigate to Virtualization Catalog and click the InstanceTypes tab. 
- Select a bootable volume. Note- The volume table only lists volumes in the - openshift-virtualization-os-imagesnamespace that have the- instancetype.kubevirt.io/default-preferencelabel.
- Click an instance type tile and select the configuration appropriate for your workload.
- Click the Red Hat Enterprise Linux 9 VM tile.
- If you have not already added a public SSH key to your project, click the edit icon beside Authorized SSH key in the VirtualMachine details section.
- Select one of the following options: - Use existing: Select a secret from the secrets list.
- Add new: - Browse to the public SSH key file or paste the file in the key field.
- Enter the secret name.
- Optional: Select Automatically apply this key to any new VirtualMachine you create in this project.
- Click Save.
 
 
- Set Dynamic SSH key injection in the VirtualMachine details section to on.
- Optional: Click View YAML & CLI to view the YAML file. Click CLI to view the CLI commands. You can also download or copy either the YAML file contents or the CLI commands.
- Click Create VirtualMachine.
After the VM is created, you can monitor the status on the VirtualMachine details page.
7.4.2.3.3. Enabling dynamic SSH key injection by using the web console
You can enable dynamic key injection for a virtual machine (VM) by using the OpenShift Container Platform web console. Then, you can update the public SSH key at runtime.
The key is added to the VM by the QEMU guest agent, which is installed with Red Hat Enterprise Linux (RHEL) 9.
Prerequisites
- The guest operating system is RHEL 9.
Procedure
- 
									Navigate to Virtualization VirtualMachines in the web console. 
- Select a VM to open the VirtualMachine details page.
- On the Configuration tab, click Scripts.
- If you have not already added a public SSH key to your project, click the edit icon beside Authorized SSH key and select one of the following options: - Use existing: Select a secret from the secrets list.
- Add new: - Browse to the SSH key file or paste the file in the key field.
- Enter the secret name.
- Optional: Select Automatically apply this key to any new VirtualMachine you create in this project.
 
 
- Set Dynamic SSH key injection to on.
- Click Save.
7.4.2.3.4. Enabling dynamic key injection by using the command line
You can enable dynamic key injection for a virtual machine (VM) by using the command line. Then, you can update the public SSH key at runtime.
Only Red Hat Enterprise Linux (RHEL) 9 supports dynamic key injection.
The key is added to the VM by the QEMU guest agent, which is installed automatically with RHEL 9.
Prerequisites
- 
									You generated an SSH key pair by running the ssh-keygencommand.
Procedure
- Create a manifest file for a - VirtualMachineobject and a- Secretobject:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - <.> Specify - cloudInitConfigDriveto create a configuration drive. <.> Specify the user names. <.> Specify the- Secretobject name. <.> Paste the public SSH key.
- Create the - VirtualMachineand- Secretobjects:- oc create -f <manifest_file>.yaml - $ oc create -f <manifest_file>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Start the VM: - virtctl start vm example-vm -n example-namespace - $ virtctl start vm example-vm -n example-namespace- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Get the VM configuration: - oc describe vm example-vm -n example-namespace - $ oc describe vm example-vm -n example-namespace- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.4.2.4. Using the virtctl ssh command
						You can access a running virtual machine (VM) by using the virtcl ssh command.
					
Prerequisites
- 
								You installed the virtctlcommand-line tool.
- You added a public SSH key to the VM.
- You have an SSH client installed.
- 
								The environment where you installed the virtctltool has the cluster permissions required to access the VM. For example, you ranoc loginor you set theKUBECONFIGenvironment variable.
Procedure
- Run the - virtctl sshcommand:- virtctl -n <namespace> ssh <username>@example-vm -i <ssh_key> - $ virtctl -n <namespace> ssh <username>@example-vm -i <ssh_key>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the namespace, user name, and the SSH private key. The default SSH key location is/home/user/.ssh. If you save the key in a different location, you must specify the path.
 - Example - virtctl -n my-namespace ssh cloud-user@example-vm -i my-key - $ virtctl -n my-namespace ssh cloud-user@example-vm -i my-key- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
						You can copy the virtctl ssh command in the web console by selecting Copy SSH command from the options 
						 menu beside a VM on the VirtualMachines page.
						 menu beside a VM on the VirtualMachines page.
					
7.4.3. Using the virtctl port-forward command
					You can use your local OpenSSH client and the virtctl port-forward command to connect to a running virtual machine (VM). You can use this method with Ansible to automate the configuration of VMs.
				
This method is recommended for low-traffic applications because port-forwarding traffic is sent over the control plane. This method is not recommended for high-traffic applications such as Rsync or Remote Desktop Protocol because it places a heavy burden on the API server.
Prerequisites
- 
							You have installed the virtctlclient.
- The virtual machine you want to access is running.
- 
							The environment where you installed the virtctltool has the cluster permissions required to access the VM. For example, you ranoc loginor you set theKUBECONFIGenvironment variable.
Procedure
- Add the following text to the - ~/.ssh/configfile on your client machine:- Host vm/* ProxyCommand virtctl port-forward --stdio=true %h %p - Host vm/* ProxyCommand virtctl port-forward --stdio=true %h %p- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Connect to the VM by running the following command: - ssh <user>@vm/<vm_name>.<namespace> - $ ssh <user>@vm/<vm_name>.<namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.4.4. Using a service for SSH access
You can create a service for a virtual machine (VM) and connect to the IP address and port exposed by the service.
Services provide excellent performance and are recommended for applications that are accessed from outside the cluster or within the cluster. Ingress traffic is protected by firewalls.
If the cluster network cannot handle the traffic load, consider using a secondary network for VM access.
7.4.4.1. About services
						A Kubernetes service exposes network access for clients to an application running on a set of pods. Services offer abstraction, load balancing, and, in the case of the NodePort and LoadBalancer types, exposure to the outside world.
					
- ClusterIP
- 
									Exposes the service on an internal IP address and as a DNS name to other applications within the cluster. A single service can map to multiple virtual machines. When a client tries to connect to the service, the client’s request is load balanced among available backends. ClusterIPis the default service type.
- NodePort
- 
									Exposes the service on the same port of each selected node in the cluster. NodePortmakes a port accessible from outside the cluster, as long as the node itself is externally accessible to the client.
- LoadBalancer
- Creates an external load balancer in the current cloud (if supported) and assigns a fixed, external IP address to the service.
For on-premise clusters, you can configure a load-balancing service by deploying the MetalLB Operator.
7.4.4.2. Creating a service
						You can create a service to expose a virtual machine (VM) by using the OpenShift Container Platform web console, virtctl command-line tool, or a YAML file.
					
7.4.4.2.1. Enabling load balancer service creation by using the web console
You can enable the creation of load balancer services for a virtual machine (VM) by using the OpenShift Container Platform web console.
Prerequisites
- You have configured a load balancer for the cluster.
- 
									You are logged in as a user with the cluster-adminrole.
- You created a network attachment definition for the network.
Procedure
- 
									Navigate to Virtualization Overview. 
- On the Settings tab, click Cluster.
- Expand LoadBalancer service and select Enable the creation of LoadBalancer services for SSH connections to VirtualMachines.
7.4.4.2.2. Creating a service by using the web console
You can create a node port or load balancer service for a virtual machine (VM) by using the OpenShift Container Platform web console.
Prerequisites
- You configured the cluster network to support either a load balancer or a node port.
- To create a load balancer service, you enabled the creation of load balancer services.
Procedure
- Navigate to VirtualMachines and select a virtual machine to view the VirtualMachine details page.
- On the Details tab, select SSH over LoadBalancer from the SSH service type list.
- 
									Optional: Click the copy icon to copy the SSHcommand to your clipboard.
Verification
- Check the Services pane on the Details tab to view the new service.
7.4.4.2.3. Creating a service by using virtctl
							You can create a service for a virtual machine (VM) by using the virtctl command-line tool.
						
Prerequisites
- 
									You installed the virtctlcommand-line tool.
- You configured the cluster network to support the service.
- 
									The environment where you installed virtctlhas the cluster permissions required to access the VM. For example, you ranoc loginor you set theKUBECONFIGenvironment variable.
Procedure
- Create a service by running the following command: - virtctl expose vm <vm_name> --name <service_name> --type <service_type> --port <port> - $ virtctl expose vm <vm_name> --name <service_name> --type <service_type> --port <port>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify theClusterIP,NodePort, orLoadBalancerservice type.
 - Example - virtctl expose vm example-vm --name example-service --type NodePort --port 22 - $ virtctl expose vm example-vm --name example-service --type NodePort --port 22- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Verify the service by running the following command: - oc get service - $ oc get service- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Next steps
								After you create a service with virtctl, you must add special: key to the spec.template.metadata.labels stanza of the VirtualMachine manifest. See Creating a service by using the command line.
							
7.4.4.2.4. Creating a service by using the command line
You can create a service and associate it with a virtual machine (VM) by using the command line.
Prerequisites
- You configured the cluster network to support the service.
Procedure
- Edit the - VirtualMachinemanifest to add the label for service creation:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Addspecial: keyto thespec.template.metadata.labelsstanza.
 Note- Labels on a virtual machine are passed through to the pod. The - special: keylabel must match the label in the- spec.selectorattribute of the- Servicemanifest.
- 
									Save the VirtualMachinemanifest file to apply your changes.
- Create a - Servicemanifest to expose the VM:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
									Save the Servicemanifest file.
- Create the service by running the following command: - oc create -f example-service.yaml - $ oc create -f example-service.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Restart the VM to apply the changes.
Verification
- Query the - Serviceobject to verify that it is available:- oc get service -n example-namespace - $ oc get service -n example-namespace- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.4.4.3. Connecting to a VM exposed by a service by using SSH
You can connect to a virtual machine (VM) that is exposed by a service by using SSH.
Prerequisites
- You created a service to expose the VM.
- You have an SSH client installed.
- You are logged in to the cluster.
Procedure
- Run the following command to access the VM: - ssh <user_name>@<ip_address> -p <port> - $ ssh <user_name>@<ip_address> -p <port>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the cluster IP for a cluster IP service, the node IP for a node port service, or the external IP address for a load balancer service.
 
7.4.5. Using a secondary network for SSH access
You can configure a secondary network, attach a virtual machine (VM) to the secondary network interface, and connect to the DHCP-allocated IP address by using SSH.
Secondary networks provide excellent performance because the traffic is not handled by the cluster network stack. However, the VMs are exposed directly to the secondary network and are not protected by firewalls. If a VM is compromised, an intruder could gain access to the secondary network. You must configure appropriate security within the operating system of the VM if you use this method.
See the Multus and SR-IOV documentation in the OpenShift Virtualization Tuning & Scaling Guide for additional information about networking options.
Prerequisites
- You configured a secondary network such as Linux bridge or SR-IOV.
- 
							You created a network attachment definition for a Linux bridge network or the SR-IOV Network Operator created a network attachment definition when you created an SriovNetworkobject.
7.4.5.1. Configuring a VM network interface by using the web console
You can configure a network interface for a virtual machine (VM) by using the OpenShift Container Platform web console.
Prerequisites
- You created a network attachment definition for the network.
Procedure
- 
								Navigate to Virtualization VirtualMachines. 
- Click a VM to view the VirtualMachine details page.
- On the Configuration tab, click the Network interfaces tab.
- Click Add network interface.
- Enter the interface name and select the network attachment definition from the Network list.
- Click Save.
- Restart the VM to apply the changes.
7.4.5.2. Connecting to a VM attached to a secondary network by using SSH
You can connect to a virtual machine (VM) attached to a secondary network by using SSH.
Prerequisites
- You attached a VM to a secondary network with a DHCP server.
- You have an SSH client installed.
Procedure
- Obtain the IP address of the VM by running the following command: - oc describe vm <vm_name> -n <namespace> - $ oc describe vm <vm_name> -n <namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Connect to the VM by running the following command: - ssh <user_name>@<ip_address> -i <ssh_key> - $ ssh <user_name>@<ip_address> -i <ssh_key>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example - ssh cloud-user@10.244.0.37 -i ~/.ssh/id_rsa_cloud-user - $ ssh cloud-user@10.244.0.37 -i ~/.ssh/id_rsa_cloud-user- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.5. Editing virtual machines
You can update a virtual machine (VM) configuration by using the OpenShift Container Platform web console. You can update the YAML file or the VirtualMachine details page.
You can also edit a VM by using the command line.
7.5.1. Editing a virtual machine by using the command line
You can edit a virtual machine (VM) by using the command line.
Prerequisites
- 
							You installed the ocCLI.
Procedure
- Obtain the virtual machine configuration by running the following command: - oc edit vm <vm_name> - $ oc edit vm <vm_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the YAML configuration.
- If you edit a running virtual machine, you need to do one of the following: - Restart the virtual machine.
- Run the following command for the new configuration to take effect: - oc apply vm <vm_name> -n <namespace> - $ oc apply vm <vm_name> -n <namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
7.5.2. Adding a disk to a virtual machine
You can add a virtual disk to a virtual machine (VM) by using the OpenShift Container Platform web console.
Procedure
- 
							Navigate to Virtualization VirtualMachines in the web console. 
- Select a VM to open the VirtualMachine details page.
- On the Disks tab, click Add disk.
- Specify the Source, Name, Size, Type, Interface, and Storage Class. - Optional: You can enable preallocation if you use a blank disk source and require maximum write performance when creating data volumes. To do so, select the Enable preallocation checkbox.
- 
									Optional: You can clear Apply optimized StorageProfile settings to change the Volume Mode and Access Mode for the virtual disk. If you do not specify these parameters, the system uses the default values from the kubevirt-storage-class-defaultsconfig map.
 
- Click Add.
If the VM is running, you must restart the VM to apply the change.
7.5.2.1. Storage fields
| Field | Description | 
|---|---|
| Blank (creates PVC) | Create an empty disk. | 
| Import via URL (creates PVC) | Import content via URL (HTTP or HTTPS endpoint). | 
| Use an existing PVC | Use a PVC that is already available in the cluster. | 
| Clone existing PVC (creates PVC) | Select an existing PVC available in the cluster and clone it. | 
| Import via Registry (creates PVC) | Import content via container registry. | 
| Container (ephemeral) | Upload content from a container located in a registry accessible from the cluster. The container disk should be used only for read-only filesystems such as CD-ROMs or temporary virtual machines. | 
| Name | 
										Name of the disk. The name can contain lowercase letters ( | 
| Size | Size of the disk in GiB. | 
| Type | Type of disk. Example: Disk or CD-ROM | 
| Interface | Type of disk device. Supported interfaces are virtIO, SATA, and SCSI. | 
| Storage Class | The storage class that is used to create the disk. | 
Advanced storage settings
The following advanced storage settings are optional and available for Blank, Import via URL, and Clone existing PVC disks.
If you do not specify these parameters, the system uses the default storage profile values.
| Parameter | Option | Parameter description | 
|---|---|---|
| Volume Mode | Filesystem | Stores the virtual disk on a file system-based volume. | 
| Block | 
										Stores the virtual disk directly on the block volume. Only use  | |
| Access Mode | ReadWriteOnce (RWO) | Volume can be mounted as read-write by a single node. | 
| ReadWriteMany (RWX) | Volume can be mounted as read-write by many nodes at one time. Note This mode is required for live migration. | 
7.5.3. Adding a secret, config map, or service account to a virtual machine
You add a secret, config map, or service account to a virtual machine by using the OpenShift Container Platform web console.
These resources are added to the virtual machine as disks. You then mount the secret, config map, or service account as you would mount any other disk.
If the virtual machine is running, changes do not take effect until you restart the virtual machine. The newly added resources are marked as pending changes at the top of the page.
Prerequisites
- The secret, config map, or service account that you want to add must exist in the same namespace as the target virtual machine.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Select a virtual machine to open the VirtualMachine details page.
- 
							Click Configuration Environment. 
- Click Add Config Map, Secret or Service Account.
- Click Select a resource and select a resource from the list. A six character serial number is automatically generated for the selected resource.
- Optional: Click Reload to revert the environment to its last saved state.
- Click Save.
Verification
- 
							On the VirtualMachine details page, click Configuration Disks and verify that the resource is displayed in the list of disks. 
- 
							Restart the virtual machine by clicking Actions Restart. 
You can now mount the secret, config map, or service account as you would mount any other disk.
Additional resources for config maps, secrets, and service accounts
7.6. Editing boot order
You can update the values for a boot order list by using the web console or the CLI.
With Boot Order in the Virtual Machine Overview page, you can:
- Select a disk or network interface controller (NIC) and add it to the boot order list.
- Edit the order of the disks or NICs in the boot order list.
- Remove a disk or NIC from the boot order list, and return it back to the inventory of bootable sources.
7.6.1. Adding items to a boot order list in the web console
Add items to a boot order list by using the web console.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Select a virtual machine to open the VirtualMachine details page.
- Click the Details tab.
- Click the pencil icon that is located on the right side of Boot Order. If a YAML configuration does not exist, or if this is the first time that you are creating a boot order list, the following message displays: No resource selected. VM will attempt to boot from disks by order of appearance in YAML file.
- Click Add Source and select a bootable disk or network interface controller (NIC) for the virtual machine.
- Add any additional disks or NICs to the boot order list.
- Click Save.
If the virtual machine is running, changes to Boot Order will not take effect until you restart the virtual machine.
You can view pending changes by clicking View Pending Changes on the right side of the Boot Order field. The Pending Changes banner at the top of the page displays a list of all changes that will be applied when the virtual machine restarts.
7.6.2. Editing a boot order list in the web console
Edit the boot order list in the web console.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Select a virtual machine to open the VirtualMachine details page.
- Click the Details tab.
- Click the pencil icon that is located on the right side of Boot Order.
- Choose the appropriate method to move the item in the boot order list: - If you do not use a screen reader, hover over the arrow icon next to the item that you want to move, drag the item up or down, and drop it in a location of your choice.
- If you use a screen reader, press the Up Arrow key or Down Arrow key to move the item in the boot order list. Then, press the Tab key to drop the item in a location of your choice.
 
- Click Save.
If the virtual machine is running, changes to the boot order list will not take effect until you restart the virtual machine.
You can view pending changes by clicking View Pending Changes on the right side of the Boot Order field. The Pending Changes banner at the top of the page displays a list of all changes that will be applied when the virtual machine restarts.
7.6.3. Editing a boot order list in the YAML configuration file
Edit the boot order list in a YAML configuration file by using the CLI.
Procedure
- Open the YAML configuration file for the virtual machine by running the following command: - oc edit vm <vm_name> -n <namespace> - $ oc edit vm <vm_name> -n <namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the YAML file and modify the values for the boot order associated with a disk or network interface controller (NIC). For example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save the YAML file.
7.6.4. Removing items from a boot order list in the web console
Remove items from a boot order list by using the web console.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Select a virtual machine to open the VirtualMachine details page.
- Click the Details tab.
- Click the pencil icon that is located on the right side of Boot Order.
- 
							Click the Remove icon 
							 next to the item. The item is removed from the boot order list and saved in the list of available boot sources. If you remove all items from the boot order list, the following message displays: No resource selected. VM will attempt to boot from disks by order of appearance in YAML file. next to the item. The item is removed from the boot order list and saved in the list of available boot sources. If you remove all items from the boot order list, the following message displays: No resource selected. VM will attempt to boot from disks by order of appearance in YAML file.
If the virtual machine is running, changes to Boot Order will not take effect until you restart the virtual machine.
You can view pending changes by clicking View Pending Changes on the right side of the Boot Order field. The Pending Changes banner at the top of the page displays a list of all changes that will be applied when the virtual machine restarts.
7.7. Deleting virtual machines
				You can delete a virtual machine from the web console or by using the oc command-line interface.
			
7.7.1. Deleting a virtual machine using the web console
Deleting a virtual machine permanently removes it from the cluster.
Procedure
- 
							In the OpenShift Container Platform console, click Virtualization VirtualMachines from the side menu. 
- Click the Options menu  beside a virtual machine and select Delete. beside a virtual machine and select Delete.- Alternatively, click the virtual machine name to open the VirtualMachine details page and click Actions - Delete. 
- Optional: Select With grace period or clear Delete disks.
- Click Delete to permanently delete the virtual machine.
7.7.2. Deleting a virtual machine by using the CLI
					You can delete a virtual machine by using the oc command-line interface (CLI). The oc client enables you to perform actions on multiple virtual machines.
				
Prerequisites
- Identify the name of the virtual machine that you want to delete.
Procedure
- Delete the virtual machine by running the following command: - oc delete vm <vm_name> - $ oc delete vm <vm_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- This command only deletes a VM in the current project. Specify the - -n <project_name>option if the VM you want to delete is in a different project or namespace.
7.8. Exporting virtual machines
You can export a virtual machine (VM) and its associated disks in order to import a VM into another cluster or to analyze the volume for forensic purposes.
				You create a VirtualMachineExport custom resource (CR) by using the command-line interface.
			
				Alternatively, you can use the virtctl vmexport command to create a VirtualMachineExport CR and to download exported volumes.
			
7.8.1. Creating a VirtualMachineExport custom resource
					You can create a VirtualMachineExport custom resource (CR) to export the following objects:
				
- Virtual machine (VM): Exports the persistent volume claims (PVCs) of a specified VM.
- 
							VM snapshot: Exports PVCs contained in a VirtualMachineSnapshotCR.
- 
							PVC: Exports a PVC. If the PVC is used by another pod, such as the virt-launcherpod, the export remains in aPendingstate until the PVC is no longer in use.
					The VirtualMachineExport CR creates internal and external links for the exported volumes. Internal links are valid within the cluster. External links can be accessed by using an Ingress or Route.
				
The export server supports the following file formats:
- 
							raw: Raw disk image file.
- 
							gzip: Compressed disk image file.
- 
							dir: PVC directory and files.
- 
							tar.gz: Compressed PVC file.
Prerequisites
- The VM must be shut down for a VM export.
Procedure
- Create a - VirtualMachineExportmanifest to export a volume from a- VirtualMachine,- VirtualMachineSnapshot, or- PersistentVolumeClaimCR according to the following example and save it as- example-export.yaml:- VirtualMachineExportexample- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - VirtualMachineExportCR:- oc create -f example-export.yaml - $ oc create -f example-export.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Get the - VirtualMachineExportCR:- oc get vmexport example-export -o yaml - $ oc get vmexport example-export -o yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The internal and external links for the exported volumes are displayed in the - statusstanza:- Output example - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.8.2. Accessing exported virtual machine manifests
					After you export a virtual machine (VM) or snapshot, you can get the VirtualMachine manifest and related information from the export server.
				
Prerequisites
- You exported a virtual machine or VM snapshot by creating a - VirtualMachineExportcustom resource (CR).Note- VirtualMachineExportobjects that have the- spec.source.kind: PersistentVolumeClaimparameter do not generate virtual machine manifests.
Procedure
- To access the manifests, you must first copy the certificates from the source cluster to the target cluster. - Log in to the source cluster.
- Save the certificates to the - cacert.crtfile by running the following command:- oc get vmexport <export_name> -o jsonpath={.status.links.external.cert} > cacert.crt- $ oc get vmexport <export_name> -o jsonpath={.status.links.external.cert} > cacert.crt- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<export_name>with themetadata.namevalue from theVirtualMachineExportobject.
 
- 
									Copy the cacert.crtfile to the target cluster.
 
- Decode the token in the source cluster and save it to the - token_decodefile by running the following command:- oc get secret export-token-<export_name> -o jsonpath={.data.token} | base64 --decode > token_decode- $ oc get secret export-token-<export_name> -o jsonpath={.data.token} | base64 --decode > token_decode- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<export_name>with themetadata.namevalue from theVirtualMachineExportobject.
 
- 
							Copy the token_decodefile to the target cluster.
- Get the - VirtualMachineExportcustom resource by running the following command:- oc get vmexport <export_name> -o yaml - $ oc get vmexport <export_name> -o yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Review the - status.linksstanza, which is divided into- externaland- internalsections. Note the- manifests.urlfields within each section:- Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Contains theVirtualMachinemanifest,DataVolumemanifest, if present, and aConfigMapmanifest that contains the public certificate for the external URL’s ingress or route.
- 2
- Contains a secret containing a header that is compatible with Containerized Data Importer (CDI). The header contains a text version of the export token.
- 3
- Contains theVirtualMachinemanifest,DataVolumemanifest, if present, and aConfigMapmanifest that contains the certificate for the internal URL’s export server.
 
- Log in to the target cluster.
- Get the - Secretmanifest by running the following command:- curl --cacert cacert.crt <secret_manifest_url> -H \ "x-kubevirt-export-token:token_decode" -H \ "Accept:application/yaml" - $ curl --cacert cacert.crt <secret_manifest_url> -H \- 1 - "x-kubevirt-export-token:token_decode" -H \- 2 - "Accept:application/yaml"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For example: - curl --cacert cacert.crt https://vmexport-proxy.test.net/api/export.kubevirt.io/v1alpha1/namespaces/example/virtualmachineexports/example-export/external/manifests/secret -H "x-kubevirt-export-token:token_decode" -H "Accept:application/yaml" - $ curl --cacert cacert.crt https://vmexport-proxy.test.net/api/export.kubevirt.io/v1alpha1/namespaces/example/virtualmachineexports/example-export/external/manifests/secret -H "x-kubevirt-export-token:token_decode" -H "Accept:application/yaml"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Get the manifests of - type: all, such as the- ConfigMapand- VirtualMachinemanifests, by running the following command:- curl --cacert cacert.crt <all_manifest_url> -H \ "x-kubevirt-export-token:token_decode" -H \ "Accept:application/yaml" - $ curl --cacert cacert.crt <all_manifest_url> -H \- 1 - "x-kubevirt-export-token:token_decode" -H \- 2 - "Accept:application/yaml"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For example: - curl --cacert cacert.crt https://vmexport-proxy.test.net/api/export.kubevirt.io/v1alpha1/namespaces/example/virtualmachineexports/example-export/external/manifests/all -H "x-kubevirt-export-token:token_decode" -H "Accept:application/yaml" - $ curl --cacert cacert.crt https://vmexport-proxy.test.net/api/export.kubevirt.io/v1alpha1/namespaces/example/virtualmachineexports/example-export/external/manifests/all -H "x-kubevirt-export-token:token_decode" -H "Accept:application/yaml"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Next steps
- 
							You can now create the ConfigMapandVirtualMachineobjects on the target cluster by using the exported manifests.
7.9. Managing virtual machine instances
				If you have standalone virtual machine instances (VMIs) that were created independently outside of the OpenShift Virtualization environment, you can manage them by using the web console or by using oc or virtctl commands from the command-line interface (CLI).
			
				The virtctl command provides more virtualization options than the oc command. For example, you can use virtctl to pause a VM or expose a port.
			
7.9.1. About virtual machine instances
					A virtual machine instance (VMI) is a representation of a running virtual machine (VM). When a VMI is owned by a VM or by another object, you manage it through its owner in the web console or by using the oc command-line interface (CLI).
				
A standalone VMI is created and started independently with a script, through automation, or by using other methods in the CLI. In your environment, you might have standalone VMIs that were developed and started outside of the OpenShift Virtualization environment. You can continue to manage those standalone VMIs by using the CLI. You can also use the web console for specific tasks associated with standalone VMIs:
- List standalone VMIs and their details.
- Edit labels and annotations for a standalone VMI.
- Delete a standalone VMI.
When you delete a VM, the associated VMI is automatically deleted. You delete a standalone VMI directly because it is not owned by VMs or other objects.
Before you uninstall OpenShift Virtualization, list and view the standalone VMIs by using the CLI or the web console. Then, delete any outstanding VMIs.
7.9.2. Listing all virtual machine instances using the CLI
					You can list all virtual machine instances (VMIs) in your cluster, including standalone VMIs and those owned by virtual machines, by using the oc command-line interface (CLI).
				
Procedure
- List all VMIs by running the following command: - oc get vmis -A - $ oc get vmis -A- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.9.3. Listing standalone virtual machine instances using the web console
Using the web console, you can list and view standalone virtual machine instances (VMIs) in your cluster that are not owned by virtual machines (VMs).
VMIs that are owned by VMs or other objects are not displayed in the web console. The web console displays only standalone VMIs. If you want to list all VMIs in your cluster, you must use the CLI.
Procedure
- Click Virtualization - VirtualMachines from the side menu. - You can identify a standalone VMI by a dark colored badge next to its name. 
7.9.4. Editing a standalone virtual machine instance using the web console
You can edit the annotations and labels of a standalone virtual machine instance (VMI) using the web console. Other fields are not editable.
Procedure
- 
							In the OpenShift Container Platform console, click Virtualization VirtualMachines from the side menu. 
- Select a standalone VMI to open the VirtualMachineInstance details page.
- On the Details tab, click the pencil icon beside Annotations or Labels.
- Make the relevant changes and click Save.
7.9.5. Deleting a standalone virtual machine instance using the CLI
					You can delete a standalone virtual machine instance (VMI) by using the oc command-line interface (CLI).
				
Prerequisites
- Identify the name of the VMI that you want to delete.
Procedure
- Delete the VMI by running the following command: - oc delete vmi <vmi_name> - $ oc delete vmi <vmi_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.9.6. Deleting a standalone virtual machine instance using the web console
Delete a standalone virtual machine instance (VMI) from the web console.
Procedure
- 
							In the OpenShift Container Platform web console, click Virtualization VirtualMachines from the side menu. 
- 
							Click Actions Delete VirtualMachineInstance. 
- In the confirmation pop-up window, click Delete to permanently delete the standalone VMI.
7.10. Controlling virtual machine states
You can stop, start, restart, and unpause virtual machines from the web console.
				You can use virtctl to manage virtual machine states and perform other actions from the CLI. For example, you can use virtctl to force stop a VM or expose a port.
			
7.10.1. Starting a virtual machine
You can start a virtual machine from the web console.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Find the row that contains the virtual machine that you want to start.
- Navigate to the appropriate menu for your use case: - To stay on this page, where you can perform actions on multiple virtual machines: - 
											Click the Options menu 
											 located at the far right end of the row and click Start VirtualMachine. located at the far right end of the row and click Start VirtualMachine.
 
- 
											Click the Options menu 
											
- To view comprehensive information about the selected virtual machine before you start it: - Access the VirtualMachine details page by clicking the name of the virtual machine.
- 
											Click Actions Start. 
 
 
						When you start virtual machine that is provisioned from a URL source for the first time, the virtual machine has a status of Importing while OpenShift Virtualization imports the container from the URL endpoint. Depending on the size of the image, this process might take several minutes.
					
7.10.2. Stopping a virtual machine
You can stop a virtual machine from the web console.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Find the row that contains the virtual machine that you want to stop.
- Navigate to the appropriate menu for your use case: - To stay on this page, where you can perform actions on multiple virtual machines: - 
											Click the Options menu 
											 located at the far right end of the row and click Stop VirtualMachine. located at the far right end of the row and click Stop VirtualMachine.
 
- 
											Click the Options menu 
											
- To view comprehensive information about the selected virtual machine before you stop it: - Access the VirtualMachine details page by clicking the name of the virtual machine.
- 
											Click Actions Stop. 
 
 
7.10.3. Restarting a virtual machine
You can restart a running virtual machine from the web console.
To avoid errors, do not restart a virtual machine while it has a status of Importing.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Find the row that contains the virtual machine that you want to restart.
- Navigate to the appropriate menu for your use case: - To stay on this page, where you can perform actions on multiple virtual machines: - 
											Click the Options menu 
											 located at the far right end of the row and click Restart. located at the far right end of the row and click Restart.
 
- 
											Click the Options menu 
											
- To view comprehensive information about the selected virtual machine before you restart it: - Access the VirtualMachine details page by clicking the name of the virtual machine.
- 
											Click Actions Restart. 
 
 
7.10.4. Pausing a virtual machine
You can pause a virtual machine from the web console.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Find the row that contains the virtual machine that you want to pause.
- Navigate to the appropriate menu for your use case: - To stay on this page, where you can perform actions on multiple virtual machines: - 
											Click the Options menu 
											 located at the far right end of the row and click Pause VirtualMachine. located at the far right end of the row and click Pause VirtualMachine.
 
- 
											Click the Options menu 
											
- To view comprehensive information about the selected virtual machine before you pause it: - Access the VirtualMachine details page by clicking the name of the virtual machine.
- 
											Click Actions Pause. 
 
 
7.10.5. Unpausing a virtual machine
You can unpause a paused virtual machine from the web console.
Prerequisites
- At least one of your virtual machines must have a status of Paused.
Procedure
- 
							Click Virtualization VirtualMachines from the side menu. 
- Find the row that contains the virtual machine that you want to unpause.
- Navigate to the appropriate menu for your use case: - To stay on this page, where you can perform actions on multiple virtual machines: - 
											Click the Options menu 
											 located at the far right end of the row and click Unpause VirtualMachine. located at the far right end of the row and click Unpause VirtualMachine.
 
- 
											Click the Options menu 
											
- To view comprehensive information about the selected virtual machine before you unpause it: - Access the VirtualMachine details page by clicking the name of the virtual machine.
- 
											Click Actions Unpause. 
 
 
7.11. Using virtual Trusted Platform Module devices
				Add a virtual Trusted Platform Module (vTPM) device to a new or existing virtual machine by editing the VirtualMachine (VM) or VirtualMachineInstance (VMI) manifest.
			
7.11.1. About vTPM devices
A virtual Trusted Platform Module (vTPM) device functions like a physical Trusted Platform Module (TPM) hardware chip.
You can use a vTPM device with any operating system, but Windows 11 requires the presence of a TPM chip to install or boot. A vTPM device allows VMs created from a Windows 11 image to function without a physical TPM chip.
If you do not enable vTPM, then the VM does not recognize a TPM device, even if the node has one.
					A vTPM device also protects virtual machines by storing secrets without physical hardware. OpenShift Virtualization supports persisting vTPM device state by using Persistent Volume Claims (PVCs) for VMs. You must specify the storage class to be used by the PVC by setting the vmStateStorageClass attribute in the HyperConverged custom resource (CR):
				
						The storage class must be of type Filesystem and support the ReadWriteMany (RWX) access mode.
					
7.11.2. Adding a vTPM device to a virtual machine
Adding a virtual Trusted Platform Module (vTPM) device to a virtual machine (VM) allows you to run a VM created from a Windows 11 image without a physical TPM device. A vTPM device also stores secrets for that VM.
Prerequisites
- 
							You have installed the OpenShift CLI (oc).
- 
							You have configured a Persistent Volume Claim (PVC) to use a storage class of type Filesystemthat supports theReadWriteMany(RWX) access mode. This is necessary for the vTPM device data to persist across VM reboots.
Procedure
- Run the following command to update the VM configuration: - oc edit vm <vm_name> -n <namespace> - $ oc edit vm <vm_name> -n <namespace>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the VM specification to add the vTPM device. For example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To apply your changes, save and exit the editor.
- Optional: If you edited a running virtual machine, you must restart it for the changes to take effect.
7.12. Managing virtual machines with OpenShift Pipelines
Red Hat OpenShift Pipelines is a Kubernetes-native CI/CD framework that allows developers to design and run each step of the CI/CD pipeline in its own container.
The Scheduling, Scale, and Performance (SSP) Operator integrates OpenShift Virtualization with OpenShift Pipelines. The SSP Operator includes tasks and example pipelines that allow you to:
- Create and manage virtual machines (VMs), persistent volume claims (PVCs), and data volumes
- Run commands in VMs
- 
						Manipulate disk images with libguestfstools
Managing virtual machines with Red Hat OpenShift Pipelines is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
7.12.1. Prerequisites
- 
							You have access to an OpenShift Container Platform cluster with cluster-adminpermissions.
- 
							You have installed the OpenShift CLI (oc).
- You have installed OpenShift Pipelines.
7.12.2. Deploying the Scheduling, Scale, and Performance (SSP) resources
					The SSP Operator example Tekton Tasks and Pipelines are not deployed by default when you install OpenShift Virtualization. To deploy the SSP Operator’s Tekton resources, enable the deployTektonTaskResources feature gate in the HyperConverged custom resource (CR).
				
Procedure
- Open the - HyperConvergedCR in your default editor by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - spec.featureGates.deployTektonTaskResourcesfield to- true.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- The tasks and example pipelines remain available even if you disable the feature gate later. 
- Save your changes and exit the editor.
7.12.3. Virtual machine tasks supported by the SSP Operator
The following table shows the tasks that are included as part of the SSP Operator.
| Task | Description | 
|---|---|
| 
									 | 
									Create a virtual machine from a provided manifest or with  | 
| 
									 | Create a virtual machine from a template. | 
| 
									 | Copy a virtual machine template. | 
| 
									 | Modify a virtual machine template. | 
| 
									 | Create or delete data volumes or data sources. | 
| 
									 | Run a script or a command in a virtual machine and stop or delete the virtual machine afterward. | 
| 
									 | 
									Use the  | 
| 
									 | 
									Use the  | 
| 
									 | Wait for a specific status of a virtual machine instance and fail or succeed based on the status. | 
						Virtual machine creation in pipelines now utilizes ClusterInstanceType and ClusterPreference instead of template-based tasks, which have been deprecated. The create-vm-from-template, copy-template, and modify-vm-template commands remain available but are not used in default pipeline tasks.
					
7.12.4. Example pipelines
					The SSP Operator includes the following example Pipeline manifests. You can run the example pipelines by using the web console or CLI.
				
					You might have to run more than one installer pipline if you need multiple versions of Windows. If you run more than one installer pipeline, each one requires unique parameters, such as the autounattend config map and base image name. For example, if you need Windows 10 and Windows 11 or Windows Server 2022 images, you have to run both the Windows efi installer pipeline and the Windows bios installer pipeline. However, if you need Windows 11 and Windows Server 2022 images, you have to run only the Windows efi installer pipeline.
				
- Windows EFI installer pipeline
- This pipeline installs Windows 11 or Windows Server 2022 into a new data volume from a Windows installation image (ISO file). A custom answer file is used to run the installation process.
- Windows BIOS installer pipeline
- This pipeline installs Windows 10 into a new data volume from a Windows installation image, also called an ISO file. A custom answer file is used to run the installation process.
- Windows customize pipeline
- This pipeline clones the data volume of a basic Windows 10, 11, or Windows Server 2022 installation, customizes it by installing Microsoft SQL Server Express or Microsoft Visual Studio Code, and then creates a new image and template.
						The example pipelines use a config map file with sysprep predefined by OpenShift Container Platform and suitable for Microsoft ISO files. For ISO files pertaining to different Windows editions, it may be necessary to create a new config map file with a system-specific sysprep definition.
					
7.12.4.1. Running the example pipelines using the web console
You can run the example pipelines from the Pipelines menu in the web console.
Procedure
- 
								Click Pipelines Pipelines in the side menu. 
- Select a pipeline to open the Pipeline details page.
- From the Actions list, select Start. The Start Pipeline dialog is displayed.
- Keep the default values for the parameters and then click Start to run the pipeline. The Details tab tracks the progress of each task and displays the pipeline status.
7.12.4.2. Running the example pipelines using the CLI
						Use a PipelineRun resource to run the example pipelines. A PipelineRun object is the running instance of a pipeline. It instantiates a pipeline for execution with specific inputs, outputs, and execution parameters on a cluster. It also creates a TaskRun object for each task in the pipeline.
					
Procedure
- To run the Windows 10 installer pipeline, create the following - PipelineRunmanifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the URL for the Windows 10 64-bit ISO file. The product language must be English (United States).
 
- Apply the - PipelineRunmanifest:- oc apply -f windows10-installer-run.yaml - $ oc apply -f windows10-installer-run.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To run the Windows 10 customize pipeline, create the following - PipelineRunmanifest:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the - PipelineRunmanifest:- oc apply -f windows10-customize-run.yaml - $ oc apply -f windows10-customize-run.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13. Advanced virtual machine management
7.13.1. Working with resource quotas for virtual machines
Create and manage resource quotas for virtual machines.
7.13.1.1. Setting resource quota limits for virtual machines
Resource quotas that only use requests automatically work with virtual machines (VMs). If your resource quota uses limits, you must manually set resource limits on VMs. Resource limits must be at least 100 MiB larger than resource requests.
Procedure
- Set limits for a VM by editing the - VirtualMachinemanifest. For example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- This configuration is supported because thelimits.memoryvalue is at least100Milarger than therequests.memoryvalue.
 
- 
								Save the VirtualMachinemanifest.
7.13.2. Specifying nodes for virtual machines
You can place virtual machines (VMs) on specific nodes by using node placement rules.
7.13.2.1. About node placement for virtual machines
To ensure that virtual machines (VMs) run on appropriate nodes, you can configure node placement rules. You might want to do this if:
- You have several VMs. To ensure fault tolerance, you want them to run on different nodes.
- You have two chatty VMs. To avoid redundant inter-node routing, you want the VMs to run on the same node.
- Your VMs require specific hardware features that are not present on all available nodes.
- You have a pod that adds capabilities to a node, and you want to place a VM on that node so that it can use those capabilities.
Virtual machine placement relies on any existing node placement rules for workloads. If workloads are excluded from specific nodes on the component level, virtual machines cannot be placed on those nodes.
						You can use the following rule types in the spec field of a VirtualMachine manifest:
					
- nodeSelector
- Allows virtual machines to be scheduled on nodes that are labeled with the key-value pair or pairs that you specify in this field. The node must have labels that exactly match all listed pairs.
- affinity
- 
									Enables you to use more expressive syntax to set rules that match nodes with virtual machines. For example, you can specify that a rule is a preference, rather than a hard requirement, so that virtual machines are still scheduled if the rule is not satisfied. Pod affinity, pod anti-affinity, and node affinity are supported for virtual machine placement. Pod affinity works for virtual machines because the VirtualMachineworkload type is based on thePodobject.
- tolerations
- Allows virtual machines to be scheduled on nodes that have matching taints. If a taint is applied to a node, that node only accepts virtual machines that tolerate the taint. Note- Affinity rules only apply during scheduling. OpenShift Container Platform does not reschedule running workloads if the constraints are no longer met. 
7.13.2.2. Node placement examples
						The following example YAML file snippets use nodePlacement, affinity, and tolerations fields to customize node placement for virtual machines.
					
7.13.2.2.1. Example: VM node placement with nodeSelector
							In this example, the virtual machine requires a node that has metadata containing both example-key-1 = example-value-1 and example-key-2 = example-value-2 labels.
						
If there are no nodes that fit this description, the virtual machine is not scheduled.
Example VM manifest
7.13.2.2.2. Example: VM node placement with pod affinity and pod anti-affinity
							In this example, the VM must be scheduled on a node that has a running pod with the label example-key-1 = example-value-1. If there is no such pod running on any node, the VM is not scheduled.
						
							If possible, the VM is not scheduled on a node that has any pod with the label example-key-2 = example-value-2. However, if all candidate nodes have a pod with this label, the scheduler ignores this constraint.
						
Example VM manifest
- 1
- If you use therequiredDuringSchedulingIgnoredDuringExecutionrule type, the VM is not scheduled if the constraint is not met.
- 2
- If you use thepreferredDuringSchedulingIgnoredDuringExecutionrule type, the VM is still scheduled if the constraint is not met, as long as all required constraints are met.
7.13.2.2.3. Example: VM node placement with node affinity
							In this example, the VM must be scheduled on a node that has the label example.io/example-key = example-value-1 or the label example.io/example-key = example-value-2. The constraint is met if only one of the labels is present on the node. If neither label is present, the VM is not scheduled.
						
							If possible, the scheduler avoids nodes that have the label example-node-label-key = example-node-label-value. However, if all candidate nodes have this label, the scheduler ignores this constraint.
						
Example VM manifest
- 1
- If you use therequiredDuringSchedulingIgnoredDuringExecutionrule type, the VM is not scheduled if the constraint is not met.
- 2
- If you use thepreferredDuringSchedulingIgnoredDuringExecutionrule type, the VM is still scheduled if the constraint is not met, as long as all required constraints are met.
7.13.2.2.4. Example: VM node placement with tolerations
							In this example, nodes that are reserved for virtual machines are already labeled with the key=virtualization:NoSchedule taint. Because this virtual machine has matching tolerations, it can schedule onto the tainted nodes.
						
A virtual machine that tolerates a taint is not required to schedule onto a node with that taint.
Example VM manifest
7.13.3. Configuring certificate rotation
Configure certificate rotation parameters to replace existing certificates.
7.13.3.1. Configuring certificate rotation
						You can do this during OpenShift Virtualization installation in the web console or after installation in the HyperConverged custom resource (CR).
					
Procedure
- Open the - HyperConvergedCR by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the - spec.certConfigfields as shown in the following example. To avoid overloading the system, ensure that all values are greater than or equal to 10 minutes. Express all values as strings that comply with the golang- ParseDurationformat.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the YAML file to your cluster.
7.13.3.2. Troubleshooting certificate rotation parameters
						Deleting one or more certConfig values causes them to revert to the default values, unless the default values conflict with one of the following conditions:
					
- 
								The value of ca.renewBeforemust be less than or equal to the value ofca.duration.
- 
								The value of server.durationmust be less than or equal to the value ofca.duration.
- 
								The value of server.renewBeforemust be less than or equal to the value ofserver.duration.
If the default values conflict with these conditions, you will receive an error.
						If you remove the server.duration value in the following example, the default value of 24h0m0s is greater than the value of ca.duration, conflicting with the specified conditions.
					
Example
This results in the following error message:
error: hyperconvergeds.hco.kubevirt.io "kubevirt-hyperconverged" could not be patched: admission webhook "validate-hco.kubevirt.io" denied the request: spec.certConfig: ca.duration is smaller than server.duration
error: hyperconvergeds.hco.kubevirt.io "kubevirt-hyperconverged" could not be patched: admission webhook "validate-hco.kubevirt.io" denied the request: spec.certConfig: ca.duration is smaller than server.durationThe error message only mentions the first conflict. Review all certConfig values before you proceed.
7.13.4. Configuring the default CPU model
					Use the defaultCPUModel setting in the HyperConverged custom resource (CR) to define a cluster-wide default CPU model.
				
The virtual machine (VM) CPU model depends on the availability of CPU models within the VM and the cluster.
- If the VM does not have a defined CPU model: - 
									The defaultCPUModelis automatically set using the CPU model defined at the cluster-wide level.
 
- 
									The 
- If both the VM and the cluster have a defined CPU model: - The VM’s CPU model takes precedence.
 
- If neither the VM nor the cluster have a defined CPU model: - The host-model is automatically set using the CPU model defined at the host level.
 
7.13.4.1. Configuring the default CPU model
						Configure the defaultCPUModel by updating the HyperConverged custom resource (CR). You can change the defaultCPUModel while OpenShift Virtualization is running.
					
							The defaultCPUModel is case sensitive.
						
Prerequisites
- Install the OpenShift CLI (oc).
Procedure
- Open the - HyperConvergedCR by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the - defaultCPUModelfield to the CR and set the value to the name of a CPU model that exists in the cluster:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the YAML file to your cluster.
7.13.5. Using UEFI mode for virtual machines
You can boot a virtual machine (VM) in Unified Extensible Firmware Interface (UEFI) mode.
7.13.5.1. About UEFI mode for virtual machines
Unified Extensible Firmware Interface (UEFI), like legacy BIOS, initializes hardware components and operating system image files when a computer starts. UEFI supports more modern features and customization options than BIOS, enabling faster boot times.
						It stores all the information about initialization and startup in a file with a .efi extension, which is stored on a special partition called EFI System Partition (ESP). The ESP also contains the boot loader programs for the operating system that is installed on the computer.
					
7.13.5.2. Booting virtual machines in UEFI mode
						You can configure a virtual machine to boot in UEFI mode by editing the VirtualMachine manifest.
					
Prerequisites
- 
								Install the OpenShift CLI (oc).
Procedure
- Edit or create a - VirtualMachinemanifest file. Use the- spec.firmware.bootloaderstanza to configure UEFI mode:- Booting in UEFI mode with secure boot active - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- OpenShift Virtualization requires System Management Mode (SMM) to be enabled for Secure Boot in UEFI mode to occur.
- 2
- OpenShift Virtualization supports a VM with or without Secure Boot when using UEFI mode. If Secure Boot is enabled, then UEFI mode is required. However, UEFI mode can be enabled without using Secure Boot.
 
- Apply the manifest to your cluster by running the following command: - oc create -f <file_name>.yaml - $ oc create -f <file_name>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.6. Configuring PXE booting for virtual machines
PXE booting, or network booting, is available in OpenShift Virtualization. Network booting allows a computer to boot and load an operating system or other program without requiring a locally attached storage device. For example, you can use it to choose your desired OS image from a PXE server when deploying a new host.
7.13.6.1. Prerequisites
- A Linux bridge must be connected.
- The PXE server must be connected to the same VLAN as the bridge.
7.13.6.2. PXE booting with a specified MAC address
						As an administrator, you can boot a client over the network by first creating a NetworkAttachmentDefinition object for your PXE network. Then, reference the network attachment definition in your virtual machine instance configuration file before you start the virtual machine instance. You can also specify a MAC address in the virtual machine instance configuration file, if required by the PXE server.
					
Prerequisites
- A Linux bridge must be connected.
- The PXE server must be connected to the same VLAN as the bridge.
Procedure
- Configure a PXE network on the cluster: - Create the network attachment definition file for PXE network - pxe-net-conf:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name for theNetworkAttachmentDefinitionobject.
- 2
- The name for the configuration. It is recommended to match the configuration name to thenamevalue of the network attachment definition.
- 3
- The actual name of the Container Network Interface (CNI) plugin that provides the network for this network attachment definition. This example uses a Linux bridge CNI plugin. You can also use an OVN-Kubernetes localnet or an SR-IOV CNI plugin.
- 4
- The name of the Linux bridge configured on the node.
- 5
- Optional: A flag to enable the MAC spoof check. When set totrue, you cannot change the MAC address of the pod or guest interface. This attribute allows only a single MAC address to exit the pod, which provides security against a MAC spoofing attack.
- 6
- Optional: The VLAN tag. No additional VLAN configuration is required on the node network configuration policy.
- 7
- Optional: Indicates whether the VM connects to the bridge through the default VLAN. The default value istrue.
 
 
- Create the network attachment definition by using the file you created in the previous step: - oc create -f pxe-net-conf.yaml - $ oc create -f pxe-net-conf.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Edit the virtual machine instance configuration file to include the details of the interface and network. - Specify the network and MAC address, if required by the PXE server. If the MAC address is not specified, a value is assigned automatically. - Ensure that - bootOrderis set to- 1so that the interface boots first. In this example, the interface is connected to a network called- <pxe-net>:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- Boot order is global for interfaces and disks. 
- Assign a boot device number to the disk to ensure proper booting after operating system provisioning. - Set the disk - bootOrdervalue to- 2:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Specify that the network is connected to the previously created network attachment definition. In this scenario, - <pxe-net>is connected to the network attachment definition called- <pxe-net-conf>:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create the virtual machine instance: - oc create -f vmi-pxe-boot.yaml - $ oc create -f vmi-pxe-boot.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - virtualmachineinstance.kubevirt.io "vmi-pxe-boot" created - virtualmachineinstance.kubevirt.io "vmi-pxe-boot" created- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Wait for the virtual machine instance to run: - oc get vmi vmi-pxe-boot -o yaml | grep -i phase - $ oc get vmi vmi-pxe-boot -o yaml | grep -i phase phase: Running- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- View the virtual machine instance using VNC: - virtctl vnc vmi-pxe-boot - $ virtctl vnc vmi-pxe-boot- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Watch the boot screen to verify that the PXE boot is successful.
- Log in to the virtual machine instance: - virtctl console vmi-pxe-boot - $ virtctl console vmi-pxe-boot- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Verify the interfaces and MAC address on the virtual machine and that the interface connected to the bridge has the specified MAC address. In this case, we used - eth1for the PXE boot, without an IP address. The other interface,- eth0, got an IP address from OpenShift Container Platform.- ip addr - $ ip addr- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - ... 3. eth1: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000 link/ether de:00:00:00:00:de brd ff:ff:ff:ff:ff:ff - ... 3. eth1: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000 link/ether de:00:00:00:00:de brd ff:ff:ff:ff:ff:ff- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.6.3. OpenShift Virtualization networking glossary
The following terms are used throughout OpenShift Virtualization documentation:
- Container Network Interface (CNI)
- A Cloud Native Computing Foundation project, focused on container network connectivity. OpenShift Virtualization uses CNI plugins to build upon the basic Kubernetes networking functionality.
- Multus
- A "meta" CNI plugin that allows multiple CNIs to exist so that a pod or virtual machine can use the interfaces it needs.
- Custom resource definition (CRD)
- A Kubernetes API resource that allows you to define custom resources, or an object defined by using the CRD API resource.
- Network attachment definition (NAD)
- A CRD introduced by the Multus project that allows you to attach pods, virtual machines, and virtual machine instances to one or more networks.
- Node network configuration policy (NNCP)
- 
									A CRD introduced by the nmstate project, describing the requested network configuration on nodes. You update the node network configuration, including adding and removing interfaces, by applying a NodeNetworkConfigurationPolicymanifest to the cluster.
7.13.7. Using huge pages with virtual machines
You can use huge pages as backing memory for virtual machines in your cluster.
7.13.7.1. Prerequisites
- Nodes must have pre-allocated huge pages configured.
7.13.7.2. What huge pages do
Memory is managed in blocks known as pages. On most systems, a page is 4Ki. 1Mi of memory is equal to 256 pages; 1Gi of memory is 256,000 pages, and so on. CPUs have a built-in memory management unit that manages a list of these pages in hardware. The Translation Lookaside Buffer (TLB) is a small hardware cache of virtual-to-physical page mappings. If the virtual address passed in a hardware instruction can be found in the TLB, the mapping can be determined quickly. If not, a TLB miss occurs, and the system falls back to slower, software-based address translation, resulting in performance issues. Since the size of the TLB is fixed, the only way to reduce the chance of a TLB miss is to increase the page size.
A huge page is a memory page that is larger than 4Ki. On x86_64 architectures, there are two common huge page sizes: 2Mi and 1Gi. Sizes vary on other architectures. To use huge pages, code must be written so that applications are aware of them. Transparent Huge Pages (THP) attempt to automate the management of huge pages without application knowledge, but they have limitations. In particular, they are limited to 2Mi page sizes. THP can lead to performance degradation on nodes with high memory utilization or fragmentation due to defragmenting efforts of THP, which can lock memory pages. For this reason, some applications may be designed to (or recommend) usage of pre-allocated huge pages instead of THP.
In OpenShift Virtualization, virtual machines can be configured to consume pre-allocated huge pages.
7.13.7.3. Configuring huge pages for virtual machines
						You can configure virtual machines to use pre-allocated huge pages by including the memory.hugepages.pageSize and resources.requests.memory parameters in your virtual machine configuration.
					
						The memory request must be divisible by the page size. For example, you cannot request 500Mi memory with a page size of 1Gi.
					
The memory layouts of the host and the guest OS are unrelated. Huge pages requested in the virtual machine manifest apply to QEMU. Huge pages inside the guest can only be configured based on the amount of available memory of the virtual machine instance.
If you edit a running virtual machine, the virtual machine must be rebooted for the changes to take effect.
Prerequisites
- Nodes must have pre-allocated huge pages configured.
Procedure
- In your virtual machine configuration, add the - resources.requests.memoryand- memory.hugepages.pageSizeparameters to the- spec.domain. The following configuration snippet is for a virtual machine that requests a total of- 4Gimemory with a page size of- 1Gi:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the virtual machine configuration: - oc apply -f <virtual_machine>.yaml - $ oc apply -f <virtual_machine>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.8. Enabling dedicated resources for virtual machines
To improve performance, you can dedicate node resources, such as CPU, to a virtual machine.
7.13.8.1. About dedicated resources
When you enable dedicated resources for your virtual machine, your virtual machine’s workload is scheduled on CPUs that will not be used by other processes. By using dedicated resources, you can improve the performance of the virtual machine and the accuracy of latency predictions.
7.13.8.2. Prerequisites
- 
								The CPU Manager must be configured on the node. Verify that the node has the cpumanager = truelabel before scheduling virtual machine workloads.
- The virtual machine must be powered off.
7.13.8.3. Enabling dedicated resources for a virtual machine
You enable dedicated resources for a virtual machine in the Details tab. Virtual machines that were created from a Red Hat template can be configured with dedicated resources.
Procedure
- 
								In the OpenShift Container Platform console, click Virtualization VirtualMachines from the side menu. 
- Select a virtual machine to open the VirtualMachine details page.
- 
								On the Configuration Scheduling tab, click the edit icon beside Dedicated Resources. 
- Select Schedule this workload with dedicated resources (guaranteed policy).
- Click Save.
7.13.9. Scheduling virtual machines
You can schedule a virtual machine (VM) on a node by ensuring that the VM’s CPU model and policy attribute are matched for compatibility with the CPU models and policy attributes supported by the node.
7.13.9.1. Policy attributes
You can schedule a virtual machine (VM) by specifying a policy attribute and a CPU feature that is matched for compatibility when the VM is scheduled on a node. A policy attribute specified for a VM determines how that VM is scheduled on a node.
| Policy attribute | Description | 
|---|---|
| force | The VM is forced to be scheduled on a node. This is true even if the host CPU does not support the VM’s CPU. | 
| require | Default policy that applies to a VM if the VM is not configured with a specific CPU model and feature specification. If a node is not configured to support CPU node discovery with this default policy attribute or any one of the other policy attributes, VMs are not scheduled on that node. Either the host CPU must support the VM’s CPU or the hypervisor must be able to emulate the supported CPU model. | 
| optional | The VM is added to a node if that VM is supported by the host’s physical machine CPU. | 
| disable | The VM cannot be scheduled with CPU node discovery. | 
| forbid | The VM is not scheduled even if the feature is supported by the host CPU and CPU node discovery is enabled. | 
7.13.9.2. Setting a policy attribute and CPU feature
You can set a policy attribute and CPU feature for each virtual machine (VM) to ensure that it is scheduled on a node according to policy and feature. The CPU feature that you set is verified to ensure that it is supported by the host CPU or emulated by the hypervisor.
7.13.9.3. Scheduling virtual machines with the supported CPU model
You can configure a CPU model for a virtual machine (VM) to schedule it on a node where its CPU model is supported.
Procedure
- Edit the - domainspec of your virtual machine configuration file. The following example shows a specific CPU model defined for a VM:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- CPU model for the VM.
 
7.13.9.4. Scheduling virtual machines with the host model
						When the CPU model for a virtual machine (VM) is set to host-model, the VM inherits the CPU model of the node where it is scheduled.
					
Procedure
- Edit the - domainspec of your VM configuration file. The following example shows- host-modelbeing specified for the virtual machine:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The VM that inherits the CPU model of the node where it is scheduled.
 
7.13.9.5. Scheduling virtual machines with a custom scheduler
You can use a custom scheduler to schedule a virtual machine (VM) on a node.
Prerequisites
- A secondary scheduler is configured for your cluster.
Procedure
- Add the custom scheduler to the VM configuration by editing the - VirtualMachinemanifest. For example:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name of the custom scheduler. If theschedulerNamevalue does not match an existing scheduler, thevirt-launcherpod stays in aPendingstate until the specified scheduler is found.
 
Verification
- Verify that the VM is using the custom scheduler specified in the - VirtualMachinemanifest by checking the- virt-launcherpod events:- View the list of pods in your cluster by entering the following command: - oc get pods - $ oc get pods- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY STATUS RESTARTS AGE virt-launcher-vm-fedora-dpc87 2/2 Running 0 24m - NAME READY STATUS RESTARTS AGE virt-launcher-vm-fedora-dpc87 2/2 Running 0 24m- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the following command to display the pod events: - oc describe pod virt-launcher-vm-fedora-dpc87 - $ oc describe pod virt-launcher-vm-fedora-dpc87- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The value of the - Fromfield in the output verifies that the scheduler name matches the custom scheduler specified in the- VirtualMachinemanifest:- Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
7.13.10. Configuring PCI passthrough
The Peripheral Component Interconnect (PCI) passthrough feature enables you to access and manage hardware devices from a virtual machine (VM). When PCI passthrough is configured, the PCI devices function as if they were physically attached to the guest operating system.
					Cluster administrators can expose and manage host devices that are permitted to be used in the cluster by using the oc command-line interface (CLI).
				
7.13.10.1. Preparing nodes for GPU passthrough
You can prevent GPU operands from deploying on worker nodes that you designated for GPU passthrough.
7.13.10.1.1. Preventing NVIDIA GPU operands from deploying on nodes
							If you use the NVIDIA GPU Operator in your cluster, you can apply the nvidia.com/gpu.deploy.operands=false label to nodes that you do not want to configure for GPU or vGPU operands. This label prevents the creation of the pods that configure GPU or vGPU operands and terminates the pods if they already exist.
						
Prerequisites
- 
									The OpenShift CLI (oc) is installed.
Procedure
- Label the node by running the following command: - oc label node <node_name> nvidia.com/gpu.deploy.operands=false - $ oc label node <node_name> nvidia.com/gpu.deploy.operands=false- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<node_name>with the name of a node where you do not want to install the NVIDIA GPU operands.
 
Verification
- Verify that the label was added to the node by running the following command: - oc describe node <node_name> - $ oc describe node <node_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: If GPU operands were previously deployed on the node, verify their removal. - Check the status of the pods in the - nvidia-gpu-operatornamespace by running the following command:- oc get pods -n nvidia-gpu-operator - $ oc get pods -n nvidia-gpu-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Monitor the pod status until the pods with - Terminatingstatus are removed:- oc get pods -n nvidia-gpu-operator - $ oc get pods -n nvidia-gpu-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
7.13.10.2. Preparing host devices for PCI passthrough
7.13.10.2.1. About preparing a host device for PCI passthrough
							To prepare a host device for PCI passthrough by using the CLI, create a MachineConfig object and add kernel arguments to enable the Input-Output Memory Management Unit (IOMMU). Bind the PCI device to the Virtual Function I/O (VFIO) driver and then expose it in the cluster by editing the permittedHostDevices field of the HyperConverged custom resource (CR). The permittedHostDevices list is empty when you first install the OpenShift Virtualization Operator.
						
							To remove a PCI host device from the cluster by using the CLI, delete the PCI device information from the HyperConverged CR.
						
7.13.10.2.2. Adding kernel arguments to enable the IOMMU driver
							To enable the IOMMU driver in the kernel, create the MachineConfig object and add the kernel arguments.
						
Prerequisites
- You have cluster administrator permissions.
- Your CPU hardware is Intel or AMD.
- You enabled Intel Virtualization Technology for Directed I/O extensions or AMD IOMMU in the BIOS.
Procedure
- Create a - MachineConfigobject that identifies the kernel argument. The following example shows a kernel argument for an Intel CPU.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the new - MachineConfigobject:- oc create -f 100-worker-kernel-arg-iommu.yaml - $ oc create -f 100-worker-kernel-arg-iommu.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Verify that the new - MachineConfigobject was added.- oc get MachineConfig - $ oc get MachineConfig- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.10.2.3. Binding PCI devices to the VFIO driver
							To bind PCI devices to the VFIO (Virtual Function I/O) driver, obtain the values for vendor-ID and device-ID from each device and create a list with the values. Add this list to the MachineConfig object. The MachineConfig Operator generates the /etc/modprobe.d/vfio.conf on the nodes with the PCI devices, and binds the PCI devices to the VFIO driver.
						
Prerequisites
- You added kernel arguments to enable IOMMU for the CPU.
Procedure
- Run the - lspcicommand to obtain the- vendor-IDand the- device-IDfor the PCI device.- lspci -nnv | grep -i nvidia - $ lspci -nnv | grep -i nvidia- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - 02:01.0 3D controller [0302]: NVIDIA Corporation GV100GL [Tesla V100 PCIe 32GB] [10de:1eb8] (rev a1) - 02:01.0 3D controller [0302]: NVIDIA Corporation GV100GL [Tesla V100 PCIe 32GB] [10de:1eb8] (rev a1)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a Butane config file, - 100-worker-vfiopci.bu, binding the PCI device to the VFIO driver.Note- The Butane version you specify in the config file should match the OpenShift Container Platform version and always ends in - 0. For example,- 4.14.0. See "Creating machine configs with Butane" for information about Butane.- Example - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Applies the new kernel argument only to worker nodes.
- 2
- Specify the previously determinedvendor-IDvalue (10de) and thedevice-IDvalue (1eb8) to bind a single device to the VFIO driver. You can add a list of multiple devices with their vendor and device information.
- 3
- The file that loads the vfio-pci kernel module on the worker nodes.
 
- Use Butane to generate a - MachineConfigobject file,- 100-worker-vfiopci.yaml, containing the configuration to be delivered to the worker nodes:- butane 100-worker-vfiopci.bu -o 100-worker-vfiopci.yaml - $ butane 100-worker-vfiopci.bu -o 100-worker-vfiopci.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the - MachineConfigobject to the worker nodes:- oc apply -f 100-worker-vfiopci.yaml - $ oc apply -f 100-worker-vfiopci.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the - MachineConfigobject was added.- oc get MachineConfig - $ oc get MachineConfig- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Verify that the VFIO driver is loaded. - lspci -nnk -d 10de: - $ lspci -nnk -d 10de:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output confirms that the VFIO driver is being used. - Example output - 04:00.0 3D controller [0302]: NVIDIA Corporation GP102GL [Tesla P40] [10de:1eb8] (rev a1) Subsystem: NVIDIA Corporation Device [10de:1eb8] Kernel driver in use: vfio-pci Kernel modules: nouveau- 04:00.0 3D controller [0302]: NVIDIA Corporation GP102GL [Tesla P40] [10de:1eb8] (rev a1) Subsystem: NVIDIA Corporation Device [10de:1eb8] Kernel driver in use: vfio-pci Kernel modules: nouveau- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.10.2.4. Exposing PCI host devices in the cluster using the CLI
							To expose PCI host devices in the cluster, add details about the PCI devices to the spec.permittedHostDevices.pciHostDevices array of the HyperConverged custom resource (CR).
						
Procedure
- Edit the - HyperConvergedCR in your default editor by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the PCI device information to the - spec.permittedHostDevices.pciHostDevicesarray. For example:- Example configuration file - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The host devices that are permitted to be used in the cluster.
- 2
- The list of PCI devices available on the node.
- 3
- Thevendor-IDand thedevice-IDrequired to identify the PCI device.
- 4
- The name of a PCI host device.
- 5
- Optional: Setting this field totrueindicates that the resource is provided by an external device plugin. OpenShift Virtualization allows the usage of this device in the cluster but leaves the allocation and monitoring to an external device plugin.
 Note- The above example snippet shows two PCI host devices that are named - nvidia.com/GV100GL_Tesla_V100and- nvidia.com/TU104GL_Tesla_T4added to the list of permitted host devices in the- HyperConvergedCR. These devices have been tested and verified to work with OpenShift Virtualization.
- Save your changes and exit the editor.
Verification
- Verify that the PCI host devices were added to the node by running the following command. The example output shows that there is one device each associated with the - nvidia.com/GV100GL_Tesla_V100,- nvidia.com/TU104GL_Tesla_T4, and- intel.com/qatresource names.- oc describe node <node_name> - $ oc describe node <node_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.10.2.5. Removing PCI host devices from the cluster using the CLI
							To remove a PCI host device from the cluster, delete the information for that device from the HyperConverged custom resource (CR).
						
Procedure
- Edit the - HyperConvergedCR in your default editor by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Remove the PCI device information from the - spec.permittedHostDevices.pciHostDevicesarray by deleting the- pciDeviceSelector,- resourceNameand- externalResourceProvider(if applicable) fields for the appropriate device. In this example, the- intel.com/qatresource has been deleted.- Example configuration file - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save your changes and exit the editor.
Verification
- Verify that the PCI host device was removed from the node by running the following command. The example output shows that there are zero devices associated with the - intel.com/qatresource name.- oc describe node <node_name> - $ oc describe node <node_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.10.3. Configuring virtual machines for PCI passthrough
After the PCI devices have been added to the cluster, you can assign them to virtual machines. The PCI devices are now available as if they are physically connected to the virtual machines.
7.13.10.3.1. Assigning a PCI device to a virtual machine
When a PCI device is available in a cluster, you can assign it to a virtual machine and enable PCI passthrough.
Procedure
- Assign the PCI device to a virtual machine as a host device. - Example - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name of the PCI device that is permitted on the cluster as a host device. The virtual machine can access this host device.
 
Verification
- Use the following command to verify that the host device is available from the virtual machine. - lspci -nnk | grep NVIDIA - $ lspci -nnk | grep NVIDIA- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - 02:01.0 3D controller [0302]: NVIDIA Corporation GV100GL [Tesla V100 PCIe 32GB] [10de:1eb8] (rev a1) - $ 02:01.0 3D controller [0302]: NVIDIA Corporation GV100GL [Tesla V100 PCIe 32GB] [10de:1eb8] (rev a1)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.11. Configuring virtual GPUs
If you have graphics processing unit (GPU) cards, OpenShift Virtualization can automatically create virtual GPUs (vGPUs) that you can assign to virtual machines (VMs).
7.13.11.1. About using virtual GPUs with OpenShift Virtualization
						Some graphics processing unit (GPU) cards support the creation of virtual GPUs (vGPUs). OpenShift Virtualization can automatically create vGPUs and other mediated devices if an administrator provides configuration details in the HyperConverged custom resource (CR). This automation is especially useful for large clusters.
					
Refer to your hardware vendor’s documentation for functionality and support details.
- Mediated device
- A physical device that is divided into one or more virtual devices. A vGPU is a type of mediated device (mdev); the performance of the physical GPU is divided among the virtual devices. You can assign mediated devices to one or more virtual machines (VMs), but the number of guests must be compatible with your GPU. Some GPUs do not support multiple guests.
7.13.11.2. Preparing hosts for mediated devices
You must enable the Input-Output Memory Management Unit (IOMMU) driver before you can configure mediated devices.
7.13.11.2.1. Adding kernel arguments to enable the IOMMU driver
							To enable the IOMMU driver in the kernel, create the MachineConfig object and add the kernel arguments.
						
Prerequisites
- You have cluster administrator permissions.
- Your CPU hardware is Intel or AMD.
- You enabled Intel Virtualization Technology for Directed I/O extensions or AMD IOMMU in the BIOS.
Procedure
- Create a - MachineConfigobject that identifies the kernel argument. The following example shows a kernel argument for an Intel CPU.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the new - MachineConfigobject:- oc create -f 100-worker-kernel-arg-iommu.yaml - $ oc create -f 100-worker-kernel-arg-iommu.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Verify that the new - MachineConfigobject was added.- oc get MachineConfig - $ oc get MachineConfig- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.11.3. Configuring the NVIDIA GPU Operator
You can use the NVIDIA GPU Operator to provision worker nodes for running GPU-accelerated virtual machines (VMs) in OpenShift Virtualization.
The NVIDIA GPU Operator is supported only by NVIDIA. For more information, see Obtaining Support from NVIDIA in the Red Hat Knowledgebase.
7.13.11.3.1. About using the NVIDIA GPU Operator
You can use the NVIDIA GPU Operator with OpenShift Virtualization to rapidly provision worker nodes for running GPU-enabled virtual machines (VMs). The NVIDIA GPU Operator manages NVIDIA GPU resources in an OpenShift Container Platform cluster and automates tasks that are required when preparing nodes for GPU workloads.
Before you can deploy application workloads to a GPU resource, you must install components such as the NVIDIA drivers that enable the compute unified device architecture (CUDA), Kubernetes device plugin, container runtime, and other features, such as automatic node labeling and monitoring. By automating these tasks, you can quickly scale the GPU capacity of your infrastructure. The NVIDIA GPU Operator can especially facilitate provisioning complex artificial intelligence and machine learning (AI/ML) workloads.
7.13.11.3.2. Options for configuring mediated devices
There are two available methods for configuring mediated devices when using the NVIDIA GPU Operator. The method that Red Hat tests uses OpenShift Virtualization features to schedule mediated devices, while the NVIDIA method only uses the GPU Operator.
- Using the NVIDIA GPU Operator to configure mediated devices
- This method exclusively uses the NVIDIA GPU Operator to configure mediated devices. To use this method, refer to NVIDIA GPU Operator with OpenShift Virtualization in the NVIDIA documentation.
- Using OpenShift Virtualization to configure mediated devices
- This method, which is tested by Red Hat, uses OpenShift Virtualization’s capabilities to configure mediated devices. In this case, the NVIDIA GPU Operator is only used for installing drivers with the NVIDIA vGPU Manager. The GPU Operator does not configure mediated devices. - When using the OpenShift Virtualization method, you still configure the GPU Operator by following the NVIDIA documentation. However, this method differs from the NVIDIA documentation in the following ways: - You must not overwrite the default - disableMDEVConfiguration: falsesetting in the- HyperConvergedcustom resource (CR).Important- Setting this feature gate as described in the NVIDIA documentation prevents OpenShift Virtualization from configuring mediated devices. 
- You must configure your - ClusterPolicymanifest so that it matches the following example:- Example manifest - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Set this value tofalse. Not required for VMs.
- 2
- Set this value totrue. Required for using vGPUs with VMs.
- 3
- Substitute<vgpu_container_registry>with your registry value.
- 4
- Set this value tofalseto allow OpenShift Virtualization to configure mediated devices instead of the NVIDIA GPU Operator.
- 5
- Set this value tofalseto prevent discovery and advertising of the vGPU devices to the kubelet.
- 6
- Set this value tofalseto prevent loading thevfio-pcidriver. Instead, follow the OpenShift Virtualization documentation to configure PCI passthrough.
 
 
7.13.11.4. How vGPUs are assigned to nodes
For each physical device, OpenShift Virtualization configures the following values:
- A single mdev type.
- 
								The maximum number of instances of the selected mdevtype.
The cluster architecture affects how devices are created and assigned to nodes.
- Large cluster with multiple cards per node
- On nodes with multiple cards that can support similar vGPU types, the relevant device types are created in a round-robin manner. For example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - In this scenario, each node has two cards, both of which support the following vGPU types: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - On each node, OpenShift Virtualization creates the following vGPUs: - 16 vGPUs of type nvidia-105 on the first card.
- 2 vGPUs of type nvidia-108 on the second card.
 
- One node has a single card that supports more than one requested vGPU type
- OpenShift Virtualization uses the supported type that comes first on the - mediatedDeviceTypeslist.- For example, the card on a node card supports - nvidia-223and- nvidia-224. The following- mediatedDeviceTypeslist is configured:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - In this example, OpenShift Virtualization uses the - nvidia-223type.
7.13.11.5. Managing mediated devices
Before you can assign mediated devices to virtual machines, you must create the devices and expose them to the cluster. You can also reconfigure and remove mediated devices.
7.13.11.5.1. Creating and exposing mediated devices
							As an administrator, you can create mediated devices and expose them to the cluster by editing the HyperConverged custom resource (CR).
						
Prerequisites
- You enabled the Input-Output Memory Management Unit (IOMMU) driver.
- If your hardware vendor provides drivers, you installed them on the nodes where you want to create mediated devices. - If you use NVIDIA cards, you installed the NVIDIA GRID driver.
 
Procedure
- Open the - HyperConvergedCR in your default editor by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example 7.2. Example configuration file with mediated devices configured - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create mediated devices by adding them to the - spec.mediatedDevicesConfigurationstanza:- Example YAML snippet - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Required: Configures global settings for the cluster.
- 2
- Optional: Overrides the global configuration for a specific node or group of nodes. Must be used with the globalmediatedDeviceTypesconfiguration.
- 3
- Required if you usenodeMediatedDeviceTypes. Overrides the globalmediatedDeviceTypesconfiguration for the specified nodes.
- 4
- Required if you usenodeMediatedDeviceTypes. Must include akey:valuepair.
 Important- Before OpenShift Virtualization 4.14, the - mediatedDeviceTypesfield was named- mediatedDevicesTypes. Ensure that you use the correct field name when configuring mediated devices.
- Identify the name selector and resource name values for the devices that you want to expose to the cluster. You will add these values to the - HyperConvergedCR in the next step.- Find the - resourceNamevalue by running the following command:- oc get $NODE -o json \ | jq '.status.allocatable \ | with_entries(select(.key | startswith("nvidia.com/"))) \ | with_entries(select(.value != "0"))'- $ oc get $NODE -o json \ | jq '.status.allocatable \ | with_entries(select(.key | startswith("nvidia.com/"))) \ | with_entries(select(.value != "0"))'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Find the - mdevNameSelectorvalue by viewing the contents of- /sys/bus/pci/devices/<slot>:<bus>:<domain>.<function>/mdev_supported_types/<type>/name, substituting the correct values for your system.- For example, the name file for the - nvidia-231type contains the selector string- GRID T4-2Q. Using- GRID T4-2Qas the- mdevNameSelectorvalue allows nodes to use the- nvidia-231type.
 
- Expose the mediated devices to the cluster by adding the - mdevNameSelectorand- resourceNamevalues to the- spec.permittedHostDevices.mediatedDevicesstanza of the- HyperConvergedCR:- Example YAML snippet - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save your changes and exit the editor.
Verification
- Optional: Confirm that a device was added to a specific node by running the following command: - oc describe node <node_name> - $ oc describe node <node_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.11.5.2. About changing and removing mediated devices
You can reconfigure or remove mediated devices in several ways:
- 
									Edit the HyperConvergedCR and change the contents of themediatedDeviceTypesstanza.
- 
									Change the node labels that match the nodeMediatedDeviceTypesnode selector.
- Remove the device information from the - spec.mediatedDevicesConfigurationand- spec.permittedHostDevicesstanzas of the- HyperConvergedCR.Note- If you remove the device information from the - spec.permittedHostDevicesstanza without also removing it from the- spec.mediatedDevicesConfigurationstanza, you cannot create a new mediated device type on the same node. To properly remove mediated devices, remove the device information from both stanzas.
7.13.11.5.3. Removing mediated devices from the cluster
							To remove a mediated device from the cluster, delete the information for that device from the HyperConverged custom resource (CR).
						
Procedure
- Edit the - HyperConvergedCR in your default editor by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Remove the device information from the - spec.mediatedDevicesConfigurationand- spec.permittedHostDevicesstanzas of the- HyperConvergedCR. Removing both entries ensures that you can later create a new mediated device type on the same node. For example:- Example configuration file - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Save your changes and exit the editor.
7.13.11.6. Using mediated devices
You can assign mediated devices to one or more virtual machines.
7.13.11.6.1. Assigning a vGPU to a VM by using the CLI
Assign mediated devices such as virtual GPUs (vGPUs) to virtual machines (VMs).
Prerequisites
- 
									The mediated device is configured in the HyperConvergedcustom resource.
- The VM is stopped.
Procedure
- Assign the mediated device to a virtual machine (VM) by editing the - spec.domain.devices.gpusstanza of the- VirtualMachinemanifest:- Example virtual machine manifest - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- To verify that the device is available from the virtual machine, run the following command, substituting - <device_name>with the- deviceNamevalue from the- VirtualMachinemanifest:- lspci -nnk | grep <device_name> - $ lspci -nnk | grep <device_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.11.6.2. Assigning a vGPU to a VM by using the web console
You can assign virtual GPUs to virtual machines by using the OpenShift Container Platform web console.
You can add hardware devices to virtual machines created from customized templates or a YAML file. You cannot add devices to pre-supplied boot source templates for specific operating systems.
Prerequisites
- The vGPU is configured as a mediated device in your cluster. - 
											To view the devices that are connected to your cluster, click Compute Hardware Devices from the side menu. 
 
- 
											To view the devices that are connected to your cluster, click Compute 
- The VM is stopped.
Procedure
- 
									In the OpenShift Container Platform web console, click Virtualization VirtualMachines from the side menu. 
- Select the VM that you want to assign the device to.
- On the Details tab, click GPU devices.
- Click Add GPU device.
- Enter an identifying value in the Name field.
- From the Device name list, select the device that you want to add to the VM.
- Click Save.
Verification
- 
									To confirm that the devices were added to the VM, click the YAML tab and review the VirtualMachineconfiguration. Mediated devices are added to thespec.domain.devicesstanza.
7.13.12. Enabling descheduler evictions on virtual machines
You can use the descheduler to evict pods so that the pods can be rescheduled onto more appropriate nodes. If the pod is a virtual machine, the pod eviction causes the virtual machine to be live migrated to another node.
Descheduler eviction for virtual machines is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
7.13.12.1. Descheduler profiles
						Use the Technology Preview DevPreviewLongLifecycle profile to enable the descheduler on a virtual machine. This is the only descheduler profile currently available for OpenShift Virtualization. To ensure proper scheduling, create VMs with CPU and memory requests for the expected load.
					
- DevPreviewLongLifecycle
- This profile balances resource usage between nodes and enables the following strategies: - 
											RemovePodsHavingTooManyRestarts: removes pods whose containers have been restarted too many times and pods where the sum of restarts over all containers (including Init Containers) is more than 100. Restarting the VM guest operating system does not increase this count.
- LowNodeUtilization: evicts pods from overutilized nodes when there are any underutilized nodes. The destination node for the evicted pod will be determined by the scheduler.- A node is considered underutilized if its usage is below 20% for all thresholds (CPU, memory, and number of pods).
- A node is considered overutilized if its usage is above 50% for any of the thresholds (CPU, memory, and number of pods).
 
 
- 
											
7.13.12.2. Installing the descheduler
The descheduler is not available by default. To enable the descheduler, you must install the Kube Descheduler Operator from OperatorHub and enable one or more descheduler profiles.
By default, the descheduler runs in predictive mode, which means that it only simulates pod evictions. You must change the mode to automatic for the descheduler to perform the pod evictions.
							If you have enabled hosted control planes in your cluster, set a custom priority threshold to lower the chance that pods in the hosted control plane namespaces are evicted. Set the priority threshold class name to hypershift-control-plane, because it has the lowest priority value (100000000) of the hosted control plane priority classes.
						
Prerequisites
- 
								You are logged in to OpenShift Container Platform as a user with the cluster-adminrole.
- Access to the OpenShift Container Platform web console.
Procedure
- Log in to the OpenShift Container Platform web console.
- Create the required namespace for the Kube Descheduler Operator. - 
										Navigate to Administration Namespaces and click Create Namespace. 
- 
										Enter openshift-kube-descheduler-operatorin the Name field, enteropenshift.io/cluster-monitoring=truein the Labels field to enable descheduler metrics, and click Create.
 
- 
										Navigate to Administration 
- Install the Kube Descheduler Operator. - 
										Navigate to Operators OperatorHub. 
- Type Kube Descheduler Operator into the filter box.
- Select the Kube Descheduler Operator and click Install.
- On the Install Operator page, select A specific namespace on the cluster. Select openshift-kube-descheduler-operator from the drop-down menu.
- Adjust the values for the Update Channel and Approval Strategy to the desired values.
- Click Install.
 
- 
										Navigate to Operators 
- Create a descheduler instance. - 
										From the Operators Installed Operators page, click the Kube Descheduler Operator. 
- Select the Kube Descheduler tab and click Create KubeDescheduler.
- Edit the settings as necessary. - To evict pods instead of simulating the evictions, change the Mode field to Automatic.
- Expand the Profiles section and select - DevPreviewLongLifecycle. The- AffinityAndTaintsprofile is enabled by default.Important- The only profile currently available for OpenShift Virtualization is - DevPreviewLongLifecycle.
 
 
- 
										From the Operators 
						You can also configure the profiles and settings for the descheduler later using the OpenShift CLI (oc).
					
7.13.12.3. Enabling descheduler evictions on a virtual machine (VM)
						After the descheduler is installed, you can enable descheduler evictions on your VM by adding an annotation to the VirtualMachine custom resource (CR).
					
Prerequisites
- 
								Install the descheduler in the OpenShift Container Platform web console or OpenShift CLI (oc).
- Ensure that the VM is not running.
Procedure
- Before starting the VM, add the - descheduler.alpha.kubernetes.io/evictannotation to the- VirtualMachineCR:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If you did not already set the - DevPreviewLongLifecycleprofile in the web console during installation, specify the- DevPreviewLongLifecyclein the- spec.profilesection of the- KubeDeschedulerobject:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- By default, the descheduler does not evict pods. To evict pods, setmodetoAutomatic.
 
The descheduler is now enabled on the VM.
7.13.13. About high availability for virtual machines
You can enable high availability for virtual machines (VMs) by manually deleting a failed node to trigger VM failover or by configuring remediating nodes.
Manually deleting a failed node
						If a node fails and machine health checks are not deployed on your cluster, virtual machines with runStrategy: Always configured are not automatically relocated to healthy nodes. To trigger VM failover, you must manually delete the Node object.
					
See Deleting a failed node to trigger virtual machine failover.
Configuring remediating nodes
You can configure remediating nodes by installing the Self Node Remediation Operator or the Fence Agents Remediation Operator from the OperatorHub and enabling machine health checks or node remediation checks.
For more information on remediation, fencing, and maintaining nodes, see the Workload Availability for Red Hat OpenShift documentation.
7.13.14. Virtual machine control plane tuning
OpenShift Virtualization offers the following tuning options at the control-plane level:
- 
							The highBurstprofile, which uses fixedQPSandburstrates, to create hundreds of virtual machines (VMs) in one batch
- Migration setting adjustment based on workload type
7.13.14.1. Configuring a highBurst profile
						Use the highBurst profile to create and maintain a large number of virtual machines (VMs) in one cluster.
					
Procedure
- Apply the following patch to enable the - highBursttuning policy profile:- oc patch hyperconverged kubevirt-hyperconverged -n openshift-cnv \ --type=json -p='[{"op": "add", "path": "/spec/tuningPolicy", \ "value": "highBurst"}]'- $ oc patch hyperconverged kubevirt-hyperconverged -n openshift-cnv \ --type=json -p='[{"op": "add", "path": "/spec/tuningPolicy", \ "value": "highBurst"}]'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Run the following command to verify the - highBursttuning policy profile is enabled:- oc get kubevirt.kubevirt.io/kubevirt-kubevirt-hyperconverged \ -n openshift-cnv -o go-template --template='{{range $config, \ $value := .spec.configuration}} {{if eq $config "apiConfiguration" \ "webhookConfiguration" "controllerConfiguration" "handlerConfiguration"}} \ {{"\n"}} {{$config}} = {{$value}} {{end}} {{end}} {{"\n"}}- $ oc get kubevirt.kubevirt.io/kubevirt-kubevirt-hyperconverged \ -n openshift-cnv -o go-template --template='{{range $config, \ $value := .spec.configuration}} {{if eq $config "apiConfiguration" \ "webhookConfiguration" "controllerConfiguration" "handlerConfiguration"}} \ {{"\n"}} {{$config}} = {{$value}} {{end}} {{end}} {{"\n"}}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.13.15. Assigning compute resources
In OpenShift Virtualization, compute resources assigned to virtual machines (VMs) are backed by either guaranteed CPUs or time-sliced CPU shares.
Guaranteed CPUs, also known as CPU reservation, dedicate CPU cores or threads to a specific workload, which makes them unavailable to any other workload. Assigning guaranteed CPUs to a VM ensures that the VM will have sole access to a reserved physical CPU. Enable dedicated resources for VMs to use a guaranteed CPU.
Time-sliced CPUs dedicate a slice of time on a shared physical CPU to each workload. You can specify the size of the slice during VM creation, or when the VM is offline. By default, each vCPU receives 100 milliseconds, or 1/10 of a second, of physical CPU time.
The type of CPU reservation depends on the instance type or VM configuration.
7.13.15.1. Overcommitting CPU resources
Time-slicing allows multiple virtual CPUs (vCPUs) to share a single physical CPU. This is known as CPU overcommitment. Guaranteed VMs can not be overcommitted.
Configure CPU overcommitment to prioritize VM density over performance when assigning CPUs to VMs. With a higher CPU over-commitment of vCPUs, more VMs fit onto a given node.
7.13.15.2. Setting the CPU allocation ratio
The CPU Allocation Ratio specifies the degree of overcommitment by mapping vCPUs to time slices of physical CPUs.
For example, a mapping or ratio of 10:1 maps 10 virtual CPUs to 1 physical CPU by using time slices.
						To change the default number of vCPUs mapped to each physical CPU, set the vmiCPUAllocationRatio value in the HyperConverged CR. The pod CPU request is calculated by multiplying the number of vCPUs by the reciprocal of the CPU allocation ratio. For example, if vmiCPUAllocationRatio is set to 10, OpenShift Virtualization will request 10 times fewer CPUs on the pod for that VM.
					
Procedure
							Set the vmiCPUAllocationRatio value in the HyperConverged CR to define a node CPU allocation ratio.
						
- Open the - HyperConvergedCR in your default editor by running the following command:- oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv - $ oc edit hyperconverged kubevirt-hyperconverged -n openshift-cnv- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - vmiCPUAllocationRatio:- ... spec: resourceRequirements: vmiCPUAllocationRatio: 1 # ...- ... spec: resourceRequirements: vmiCPUAllocationRatio: 1- 1 - # ...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- WhenvmiCPUAllocationRatiois set to1, the maximum amount of vCPUs are requested for the pod.
 
7.14. VM disks
7.14.1. Hot-plugging VM disks
You can add or remove virtual disks without stopping your virtual machine (VM) or virtual machine instance (VMI).
Only data volumes and persistent volume claims (PVCs) can be hot plugged and hot-unplugged. You cannot hot plug or hot-unplug container disks.
A hot plugged disk remains attached to the VM even after reboot. You must detach the disk to remove it from the VM.
You can make a hot plugged disk persistent so that it is permanently mounted on the VM.
						Each VM has a virtio-scsi controller so that hot plugged disks can use the scsi bus. The virtio-scsi controller overcomes the limitations of virtio while retaining its performance advantages. It is highly scalable and supports hot plugging over 4 million disks.
					
						Regular virtio is not available for hot plugged disks because it is not scalable. Each virtio disk uses one of the limited PCI Express (PCIe) slots in the VM. PCIe slots are also used by other devices and must be reserved in advance. Therefore, slots might not be available on demand.
					
7.14.1.1. Hot plugging and hot unplugging a disk by using the web console
You can hot plug a disk by attaching it to a virtual machine (VM) while the VM is running by using the OpenShift Container Platform web console.
The hot plugged disk remains attached to the VM until you unplug it.
You can make a hot plugged disk persistent so that it is permanently mounted on the VM.
Prerequisites
- You must have a data volume or persistent volume claim (PVC) available for hot plugging.
Procedure
- 
								Navigate to Virtualization VirtualMachines in the web console. 
- Select a running VM to view its details.
- 
								On the VirtualMachine details page, click Configuration Disks. 
- Add a hot plugged disk: - Click Add disk.
- In the Add disk (hot plugged) window, select the disk from the Source list and click Save.
 
- Optional: Unplug a hot plugged disk: - 
										Click the options menu 
										 beside the disk and select Detach. beside the disk and select Detach.
- Click Detach.
 
- 
										Click the options menu 
										
- Optional: Make a hot plugged disk persistent: - 
										Click the options menu 
										 beside the disk and select Make persistent. beside the disk and select Make persistent.
- Reboot the VM to apply the change.
 
- 
										Click the options menu 
										
7.14.1.2. Hot plugging and hot unplugging a disk by using the command line
You can hot plug and hot unplug a disk while a virtual machine (VM) is running by using the command line.
You can make a hot plugged disk persistent so that it is permanently mounted on the VM.
Prerequisites
- You must have at least one data volume or persistent volume claim (PVC) available for hot plugging.
Procedure
- Hot plug a disk by running the following command: - virtctl addvolume <virtual-machine|virtual-machine-instance> \ --volume-name=<datavolume|PVC> \ [--persist] [--serial=<label-name>] - $ virtctl addvolume <virtual-machine|virtual-machine-instance> \ --volume-name=<datavolume|PVC> \ [--persist] [--serial=<label-name>]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 
										Use the optional --persistflag to add the hot plugged disk to the virtual machine specification as a permanently mounted virtual disk. Stop, restart, or reboot the virtual machine to permanently mount the virtual disk. After specifying the--persistflag, you can no longer hot plug or hot unplug the virtual disk. The--persistflag applies to virtual machines, not virtual machine instances.
- 
										The optional --serialflag allows you to add an alphanumeric string label of your choice. This helps you to identify the hot plugged disk in a guest virtual machine. If you do not specify this option, the label defaults to the name of the hot plugged data volume or PVC.
 
- 
										Use the optional 
- Hot unplug a disk by running the following command: - virtctl removevolume <virtual-machine|virtual-machine-instance> \ --volume-name=<datavolume|PVC> - $ virtctl removevolume <virtual-machine|virtual-machine-instance> \ --volume-name=<datavolume|PVC>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
7.14.2. Expanding virtual machine disks
You can increase the size of a virtual machine (VM) disk by expanding the persistent volume claim (PVC) of the disk.
If your storage provider does not support volume expansion, you can expand the available virtual storage of a VM by adding blank data volumes.
You cannot reduce the size of a VM disk.
7.14.2.1. Expanding a VM disk PVC
You can increase the size of a virtual machine (VM) disk by expanding the persistent volume claim (PVC) of the disk.
If the PVC uses the file system volume mode, the disk image file expands to the available size while reserving some space for file system overhead.
Procedure
- Edit the - PersistentVolumeClaimmanifest of the VM disk that you want to expand:- oc edit pvc <pvc_name> - $ oc edit pvc <pvc_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Update the disk size: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the new disk size.
 
7.14.2.2. Expanding available virtual storage by adding blank data volumes
You can expand the available storage of a virtual machine (VM) by adding blank data volumes.
Prerequisites
- You must have at least one persistent volume.
Procedure
- Create a - DataVolumemanifest as shown in the following example:- Example - DataVolumemanifest- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the data volume by running the following command: - oc create -f <blank-image-datavolume>.yaml - $ oc create -f <blank-image-datavolume>.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow