此内容没有您所选择的语言版本。
Chapter 9. Configuring Real-Time Compute
In some use-cases, you might need instances on your Compute nodes to adhere to low-latency policies and perform real-time processing. Real-time Compute nodes include a real-time capable kernel, specific virtualization modules, and optimized deployment parameters, to facilitate real-time processing requirements and minimize latency.
The process to enable Real-time Compute includes:
- configuring the BIOS settings of the Compute nodes
- building a real-time image with real-time kernel and Real-Time KVM (RT-KVM) kernel module
- 
					assigning the ComputeRealTimerole to the Compute nodes
For a use-case example of Real-time Compute deployment for NFV workloads, see the Example: Configuring OVS-DPDK with ODL and VXLAN tunnelling section in the Network Functions Virtualization Planning and Configuration Guide.
9.1. Preparing Your Compute Nodes for Real-Time
Real-time Compute nodes are supported only with Red Hat Enterprise Linux version 7.5 or later.
Before you can deploy Real-time Compute in your overcloud, you must enable Red Hat Enterprise Linux Real-Time KVM (RT-KVM), configure your BIOS to support real-time, and build the real-time image.
Prerequisites
- You must use Red Hat certified servers for your RT-KVM Compute nodes. See Red Hat Enterprise Linux for Real Time 7 certified servers for details.
- You must enable the - rhel-8-for-x86_64-nfv-rpmsrepository for RT-KVM to build the real-time image.Note- You need a separate subscription to Red Hat OpenStack Platform for Real Time before you can access this repository. For details on managing repositories and subscriptions for your undercloud, see the Registering and updating your undercloud section in the Director Installation and Usage guide. - To check which packages will be installed from the repository, run the following command: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Building the real-time image
To build the overcloud image for Real-time Compute nodes:
- Install the - libguestfs-toolspackage on the undercloud to get the- virt-customizetool:- sudo dnf install libguestfs-tools - (undercloud) [stack@undercloud-0 ~]$ sudo dnf install libguestfs-tools- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Important- If you install the - libguestfs-toolspackage on the undercloud, disable- iscsid.socketto avoid port conflicts with the- tripleo_iscsidservice on the undercloud:- sudo systemctl disable --now iscsid.socket - $ sudo systemctl disable --now iscsid.socket- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Extract the images: - tar -xf /usr/share/rhosp-director-images/overcloud-full.tar tar -xf /usr/share/rhosp-director-images/ironic-python-agent.tar - (undercloud) [stack@undercloud-0 ~]$ tar -xf /usr/share/rhosp-director-images/overcloud-full.tar (undercloud) [stack@undercloud-0 ~]$ tar -xf /usr/share/rhosp-director-images/ironic-python-agent.tar- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Copy the default image: - cp overcloud-full.qcow2 overcloud-realtime-compute.qcow2 - (undercloud) [stack@undercloud-0 ~]$ cp overcloud-full.qcow2 overcloud-realtime-compute.qcow2- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Register the image and configure the required subscriptions: - virt-customize -a overcloud-realtime-compute.qcow2 --run-command 'subscription-manager register --username=[username] --password=[password]' - (undercloud) [stack@undercloud-0 ~]$ virt-customize -a overcloud-realtime-compute.qcow2 --run-command 'subscription-manager register --username=[username] --password=[password]' [ 0.0] Examining the guest ... [ 10.0] Setting a random seed [ 10.0] Running: subscription-manager register --username=[username] --password=[password] [ 24.0] Finishing off- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace the - usernameand- passwordvalues with your Red Hat customer account details. For general information about building a Real-time overcloud image, see the Modifying the Red Hat Enterprise Linux OpenStack Platform Overcloud Image with virt-customize knowledgebase article.
- Find the SKU of the Red Hat OpenStack Platform for Real Time subscription. The SKU might be located on a system that is already registered to the Red Hat Subscription Manager with the same account and credentials. For example: - sudo subscription-manager list - $ sudo subscription-manager list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Attach the Red Hat OpenStack Platform for Real Time subscription to the image: - virt-customize -a overcloud-realtime-compute.qcow2 --run-command 'subscription-manager attach --pool [subscription-pool]' - (undercloud) [stack@undercloud-0 ~]$ virt-customize -a overcloud-realtime-compute.qcow2 --run-command 'subscription-manager attach --pool [subscription-pool]'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a script to configure - rton the image:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the script to configure the real-time image: - virt-customize -a overcloud-realtime-compute.qcow2 -v --run rt.sh 2>&1 | tee virt-customize.log - (undercloud) [stack@undercloud-0 ~]$ virt-customize -a overcloud-realtime-compute.qcow2 -v --run rt.sh 2>&1 | tee virt-customize.log- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Re-label SELinux: - virt-customize -a overcloud-realtime-compute.qcow2 --selinux-relabel - (undercloud) [stack@undercloud-0 ~]$ virt-customize -a overcloud-realtime-compute.qcow2 --selinux-relabel- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Extract - vmlinuzand- initrd. For example:- mkdir image guestmount -a overcloud-realtime-compute.qcow2 -i --ro image cp image/boot/vmlinuz-4.18.0-80.7.1.rt9.153.el8_0.x86_64 ./overcloud-realtime-compute.vmlinuz cp image/boot/initramfs-4.18.0-80.7.1.rt9.153.el8_0.x86_64.img ./overcloud-realtime-compute.initrd guestunmount image - (undercloud) [stack@undercloud-0 ~]$ mkdir image (undercloud) [stack@undercloud-0 ~]$ guestmount -a overcloud-realtime-compute.qcow2 -i --ro image (undercloud) [stack@undercloud-0 ~]$ cp image/boot/vmlinuz-4.18.0-80.7.1.rt9.153.el8_0.x86_64 ./overcloud-realtime-compute.vmlinuz (undercloud) [stack@undercloud-0 ~]$ cp image/boot/initramfs-4.18.0-80.7.1.rt9.153.el8_0.x86_64.img ./overcloud-realtime-compute.initrd (undercloud) [stack@undercloud-0 ~]$ guestunmount image- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- The software version in the - vmlinuzand- initramfsfilenames vary with the kernel version.
- Upload the image: - openstack overcloud image upload --update-existing --os-image-name overcloud-realtime-compute.qcow2 - (undercloud) [stack@undercloud-0 ~]$ openstack overcloud image upload --update-existing --os-image-name overcloud-realtime-compute.qcow2- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
				You now have a real-time image you can use with the ComputeRealTime composable role on select Compute nodes.
			
Modifying BIOS settings on Real-time Compute nodes
To reduce latency on your Real-time Compute nodes, you must modify the BIOS settings in the Compute nodes. You should disable all options for the following components in your Compute node BIOS settings:
- Power Management
- Hyper-Threading
- CPU sleep states
- Logical processors
See Setting BIOS parameters for descriptions of these settings and the impact of disabling them. See your hardware manufacturer documentation for complete details on how to change BIOS settings.
9.2. Deploying the Real-time Compute Role
				Red Hat OpenStack Platform director provides the template for the ComputeRealTime role, which you can use to deploy real-time Compute nodes. You must perform additional steps to designate Compute nodes for real-time.
			
Procedure
- Based on the /usr/share/openstack-tripleo-heat-templates/environments/compute-real-time-example.yaml file, create a compute-real-time.yaml environment file that sets the parameters for the - ComputeRealTimerole.- cp /usr/share/openstack-tripleo-heat-templates/environments/compute-real-time-example.yaml /home/stack/templates/compute-real-time.yaml - cp /usr/share/openstack-tripleo-heat-templates/environments/compute-real-time-example.yaml /home/stack/templates/compute-real-time.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The file must include values for the following parameters: - 
								IsolCpusListandNovaComputeCpuDedicatedSet: List of isolated CPU cores and virtual CPU pins to reserve for real-time workloads. This value depends on the CPU hardware of your real-time Compute nodes.
- 
								NovaComputeCpuSharedSet: List of host CPUs to reserve for emulator threads.
- 
								KernelArgs: Arguments to pass to the kernel of the Real-time Compute nodes. For example, you can usedefault_hugepagesz=1G hugepagesz=1G hugepages=<number_of_1G_pages_to_reserve> hugepagesz=2M hugepages=<number_of_2M_pages>to define the memory requirements of guests that have huge pages with multiple sizes. In this example, the default size is 1GB but you can also reserve 2M huge pages.
 
- 
								
- Add the - ComputeRealTimerole to your roles data file and regenerate the file. For example:- openstack overcloud roles generate -o /home/stack/templates/rt_roles_data.yaml Controller Compute ComputeRealTime - $ openstack overcloud roles generate -o /home/stack/templates/rt_roles_data.yaml Controller Compute ComputeRealTime- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This command generates a - ComputeRealTimerole with contents similar to the following example, and also sets the- ImageDefaultoption to- overcloud-realtime-compute.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For general information about custom roles and about the roles-data.yaml, see the Roles section. 
- Create the - compute-realtimeflavor to tag nodes that you want to designate for real-time workloads. For example:- source ~/stackrc openstack flavor create --id auto --ram 6144 --disk 40 --vcpus 4 compute-realtime openstack flavor set --property "cpu_arch"="x86_64" --property "capabilities:boot_option"="local" --property "capabilities:profile"="compute-realtime" compute-realtime - $ source ~/stackrc $ openstack flavor create --id auto --ram 6144 --disk 40 --vcpus 4 compute-realtime $ openstack flavor set --property "cpu_arch"="x86_64" --property "capabilities:boot_option"="local" --property "capabilities:profile"="compute-realtime" compute-realtime- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Tag each node that you want to designate for real-time workloads with the - compute-realtimeprofile.- openstack baremetal node set --property capabilities='profile:compute-realtime,boot_option:local' <NODE UUID> - $ openstack baremetal node set --property capabilities='profile:compute-realtime,boot_option:local' <NODE UUID>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Map the - ComputeRealTimerole to the- compute-realtimeflavor by creating an environment file with the following content:- parameter_defaults: OvercloudComputeRealTimeFlavor: compute-realtime - parameter_defaults: OvercloudComputeRealTimeFlavor: compute-realtime- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Run the - openstack overcloud deploycommand with the- -eoption and specify all the environment files that you created, as well as the new roles file. For example:- openstack overcloud deploy -r /home/stack/templates/rt~/my_roles_data.yaml -e home/stack/templates/compute-real-time.yaml <FLAVOR_ENV_FILE> - $ openstack overcloud deploy -r /home/stack/templates/rt~/my_roles_data.yaml -e home/stack/templates/compute-real-time.yaml <FLAVOR_ENV_FILE>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
9.3. Sample Deployment and Testing Scenario
The following example procedure uses a simple single-node deployment to test that the environment variables and other supporting configuration is set up correctly. Actual performance results might vary, depending on the number of nodes and guests that you deploy in your cloud.
- Create the - compute-real-time.yamlfile with the following parameters:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a new - rt_roles_data.yamlfile with the- ComputeRealTimerole:- openstack overcloud roles generate -o ~/rt_roles_data.yaml Controller ComputeRealTime - $ openstack overcloud roles generate -o ~/rt_roles_data.yaml Controller ComputeRealTime- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Deploy the overcloud, adding both your new real-time roles data file and your real-time environment file to the stack along with your other environment files: - (undercloud) $ openstack overcloud deploy --templates \ -r /home/stack/rt_roles_data.yaml -e [your environment files] -e /home/stack/templates/compute-real-time.yaml - (undercloud) $ openstack overcloud deploy --templates \ -r /home/stack/rt_roles_data.yaml -e [your environment files] -e /home/stack/templates/compute-real-time.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This command deploys one Controller node and one Real-time Compute node. 
- Log into the Real-time Compute node and check the following parameters. Replace - <...>with the values of the relevant parameters from the- compute-real-time.yaml.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
9.4. Launching and Tuning Real-Time Instances
After you deploy and configure Real-time Compute nodes, you can launch real-time instances on those nodes. You can further configure these real-time instances with CPU pinning, NUMA topology filters, and huge pages.
Launching a real-time instance
- 
						Make sure that the compute-realtimeflavor exists on the overcloud, as described in the Deploying the Real-time Compute Role section.
- Launch the real-time instance. - openstack server create --image <rhel> --flavor r1.small --nic net-id=<dpdk-net> test-rt - # openstack server create --image <rhel> --flavor r1.small --nic net-id=<dpdk-net> test-rt- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optionally, verify that the instance uses the assigned emulator threads. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Pinning CPUs and setting emulator thread policy
To ensure that there are enough CPUs on each Real-time Compute node for real-time workloads, you need to pin at least one virtual CPU (vCPU) for an instance to a physical CPU (pCPUs) on the host. The emulator threads for that vCPU then remain dedicated to that pCPU.
				Configure your flavor to use a dedicated CPU policy. To do so, set the hw:cpu_policy parameter to dedicated on the flavor. For example:
			
openstack flavor set --property hw:cpu_policy=dedicated 99
# openstack flavor set --property hw:cpu_policy=dedicated 99Make sure that your resources quota has enough pCPUs for the Real-time Compute nodes to consume.
Optimizing your network configuration
Depending on the needs of your deployment, you might need to set parameters in the network-environment.yaml file to tune your network for certain real-time workloads.
To review an example configuration optimized for OVS-DPDK, see the Configuring the OVS-DPDK parameters section of the Network Functions Virtualization Planning and Configuration Guide.
Configuring huge pages
It is recommended to set the default huge pages size to 1GB. Otherwise, TLB flushes might create jitter in the vCPU execution. For general information about using huge pages, see the Running DPDK applications web page.
Disabling Performance Monitoring Unit (PMU) emulation
Instances can provide PMU metrics by specifying an image or flavor with a vPMU. Providing PMU metrics introduces latency.
					The vPMU defaults to enabled when cpu_mode=host-passthrough.
				
If you do not need PMU metrics, then disable the vPMU to reduce latency by setting the PMU property to "False" in the image or flavor used to create the instance:
- 
						Image: hw_pmu=False
- 
						Flavor: hw:pmu=False