Chapter 4. Configuring for the Bare Metal Service After Deployment
This section describes the steps necessary to configure your overcloud after deployment.
4.1. Configuring OpenStack Networking
Configure OpenStack Networking to communicate with the Bare Metal service for DHCP, PXE boot, and other requirements. You can configure the bare metal network in two ways:
- Use a flat bare metal network for Ironic Conductor services. This network must route to the Ironic services on the control plane network.
- Use a custom composable network to implement Ironic services in the overcloud.
Follow the procedures in this section to configure OpenStack Networking for a single flat network for provisioning onto bare metal, or to configure a new composable network that does not rely on an unused isolated network or a flat network. The configuration uses the ML2 plug-in and the Open vSwitch agent.
Perform all steps in the following procedure on the server that hosts the OpenStack Networking service, while logged in as the root user.
4.1.1. Configuring OpenStack Networking to Communicate with the Bare Metal Service on a flat Bare Metal Network
- Configure the shell to access Identity as the administrative user: - source ~/overcloudrc - $ source ~/overcloudrc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the flat network over which to provision bare metal instances: - openstack network create \ --provider-network-type flat \ --provider-physical-network baremetal \ --share NETWORK_NAME - $ openstack network create \ --provider-network-type flat \ --provider-physical-network baremetal \ --share NETWORK_NAME- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace NETWORK_NAME with a name for this network. To avoid erroneous reconfiguration in when you perform node cleaning, set this value to - provisioning. The name of the physical network over which the virtual network is implemented, (in this case- baremetal), was set earlier in- ~/templates/network-environment.yaml, with the parameter- NeutronBridgeMappings.
- Create the subnet on the flat network: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace the following values: - Replace SUBNET_NAME with a name for the subnet.
- Replace NETWORK_NAME with the name of the provisioning network you created in the previous step.
- Replace NETWORK_CIDR with the Classless Inter-Domain Routing (CIDR) representation of the block of IP addresses the subnet represents. The block of IP addresses specified by the range started by START_IP and ended by END_IP must fall within the block of IP addresses specified by NETWORK_CIDR.
- Replace GATEWAY_IP with the IP address or host name of the router interface that will act as the gateway for the new subnet. This address must be within the block of IP addresses specified by NETWORK_CIDR, but outside of the block of IP addresses specified by the range started by START_IP and ended by END_IP.
- Replace START_IP with the IP address that denotes the start of the range of IP addresses within the new subnet from which floating IP addresses will be allocated.
- Replace END_IP with the IP address that denotes the end of the range of IP addresses within the new subnet from which floating IP addresses will be allocated.
 
- Create a router for the network and subnet to ensure that the OpenStack Networking Service serves metadata requests: - openstack router create ROUTER_NAME - $ openstack router create ROUTER_NAME- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace - ROUTER_NAMEwith a name for the router.
- Attach the network to the new router: - openstack router add network ROUTER_NAME NETWORK - $ openstack router add network ROUTER_NAME NETWORK- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace ROUTER_NAME with the name of your router, and replace NETWORK with the ID or name of the network that you created previously. 
- Attach the subnet to the new router: - openstack router add subnet ROUTER_NAME BAREMETAL_SUBNET - $ openstack router add subnet ROUTER_NAME BAREMETAL_SUBNET- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace ROUTER_NAME with the name of your router and BAREMETAL_SUBNET with the ID or name of the subnet that you created previously. This allows the metadata requests from - cloud-initto be served and the node configured.
4.1.2. Configuring OpenStack Networking to Communicate with the Bare Metal Service on a Custom Composable Bare Metal Network
- Create a vlan network with a VlanID that matches the - OcProvisioningnetwork that you create during deployment. Name the new network- provisioningto match the default name of the cleaning network.- openstack network create \ --share \ --provider-network-type vlan \ --provider-physical-network datacentre \ --provider-segment 205 provisioning - (overcloud) [stack@host01 ~]$ openstack network create \ --share \ --provider-network-type vlan \ --provider-physical-network datacentre \ --provider-segment 205 provisioning- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If the name of the overcloud network is not - provisioning, log onto the controller and run the following commands to rename and restart the network:- heat-admin@overcloud-controller-0 ~]$ sudo vi /var/lib/config-data/puppet-generated/ironic/etc/ironic/ironic.conf - heat-admin@overcloud-controller-0 ~]$ sudo vi /var/lib/config-data/puppet-generated/ironic/etc/ironic/ironic.conf- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - heat-admin@overcloud-controller-0 ~]$ sudo docker restart ironic_conductor - heat-admin@overcloud-controller-0 ~]$ sudo docker restart ironic_conductor- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.2. Configuring Node Cleaning
				By default, the Bare Metal service is set to use a network named provisioning for node cleaning. However, network names are not unique in OpenStack Networking, so it is possible for a tenant to create a network with the same name, causing a conflict with the Bare Metal service. Therefore, it is recommended to use the network UUID instead.
			
- Configure cleaning by providing the provider network UUID on the controller running the Bare Metal Service: - ~/templates/ironic.yaml- parameter_defaults: IronicCleaningNetwork: UUID- parameter_defaults: IronicCleaningNetwork: UUID- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace UUID with the UUID of the bare metal network created in the previous steps. - You can find the UUID using - openstack network show:- openstack network show NETWORK_NAME -f value -c id - openstack network show NETWORK_NAME -f value -c id- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- This configuration must be done after the initial overcloud deployment, because the UUID for the network is not available beforehand. 
- 
						Apply the changes by redeploying the overcloud with the openstack overcloud deploycommand as described in Section 3.4, “Deploying the Overcloud”. Redeploying the overcloud withopenstack overcloud deployreverts any manual changes, so make sure you have added the cleaning configuration to~/templates/ironic.yaml(described in the previous step) before the next time you useopenstack overcloud deploy.
- You can also apply the change manually, without using director. Configure the cleaning network: - crudini --set /var/lib/config-data/puppet-generated/ironic/etc/ironic/ironic.conf neutron cleaning_network - crudini --set /var/lib/config-data/puppet-generated/ironic/etc/ironic/ironic.conf neutron cleaning_network- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Restart the Bare Metal Provisioning service: - docker restart ironic_conductor - # docker restart ironic_conductor- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.2.1. Manual Node Cleaning
					To manually initiate node cleaning, the node must be in the manageable state.
				
Node cleaning has two modes:
Metadata only clean - Removes partitions from all disks on a given node. This is a faster clean cycle, but less secure since it only erases partition tables. Only use this mode on trusted tenant environments.
Full clean - Removes all data from all disks, using either ATA secure erase or by shredding. This can take several hours to complete.
					To initiate a metadata clean:
				
openstack baremetal node clean _UUID_ \
    --clean-steps '[{"interface": "deploy", "step": "erase_devices_metadata"}]'
$ openstack baremetal node clean _UUID_ \
    --clean-steps '[{"interface": "deploy", "step": "erase_devices_metadata"}]'
					To initiate a full clean:
				
openstack baremetal node clean _UUID_ \
    --clean-steps '[{"interface": "deploy", "step": "erase_devices"}]'
$ openstack baremetal node clean _UUID_ \
    --clean-steps '[{"interface": "deploy", "step": "erase_devices"}]'Replace UUID with the UUID of the node you would like cleaned.
					After a successful cleaning, the node state returns to manageable. If the state is clean failed, check the last_error field for the cause of failure.
				
4.3. Creating the Bare Metal Flavor
You need to create a flavor to use as a part of the deployment. The specifications (memory, CPU, and disk) of this flavor must be equal to or less than what your bare metal node provides.
- Set up the shell to access Identity as the administrative user: - source ~/overcloudrc - $ source ~/overcloudrc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- List existing flavors: - openstack flavor list - $ openstack flavor list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a new flavor for the Bare Metal service: - openstack flavor create \ --id auto --ram RAM \ --vcpus VCPU --disk DISK \ --property baremetal=true \ --public baremetal - $ openstack flavor create \ --id auto --ram RAM \ --vcpus VCPU --disk DISK \ --property baremetal=true \ --public baremetal- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace - RAMwith the amount of memory,- VCPUwith the number of vCPUs and- DISKwith the disk storage value. The property- baremetalis used to distinguish bare metal from virtual instances.
- Verify that the new flavor is created with the respective values: - openstack flavor list - $ openstack flavor list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.4. Creating the Bare Metal Images
The deployment requires two sets of images:
- 
						The deploy image is used by the Bare Metal service to boot the bare metal node and copy a user image onto the bare metal node. The deploy image consists of the kernelimage and theramdiskimage.
- The user image is the image deployed onto the bare metal node. The user image also has a - kernelimage and- ramdiskimage, but additionally, the user image contains a- mainimage. The main image is either a root partition, or a whole-disk image.- A whole-disk image is an image that contains the partition table and boot loader. The Bare Metal service does not control the subsequent reboot of a node deployed with a whole-disk image as the node supports localboot.
- A root partition image only contains the root partition of the operating system. If using a root partition, after the deploy image is loaded into the Image service, you can set the deploy image as the node’s boot image in the node’s properties. A subsequent reboot of the node uses netboot to pull down the user image.
 
The examples in this section use a root partition image to provision bare metal nodes.
4.4.1. Preparing the Deploy Images
You do not have to create the deploy image as it was already used when the overcloud was deployed by the undercloud. The deploy image consists of two images - the kernel image and the ramdisk image as follows:
/tftpboot/agent.kernel /tftpboot/agent.ramdisk
/tftpboot/agent.kernel
/tftpboot/agent.ramdisk
					These images are often in the home directory, unless you have deleted them, or unpacked them elsewhere. If they are not in the home directory, and you still have the rhosp-director-images-ipa package installed, these images will be in the /usr/share/rhosp-director-images/ironic-python-agent*.tar file.
				
Extract the images and upload them to the Image service:
4.4.2. Preparing the User Image
The final image that you need is the user image that will be deployed on the bare metal node. User images also have a kernel and ramdisk, along with a main image. To download and install these packages, you must first configure whole disk image environment variables to suit your requirements.
4.4.2.1. Disk Image Environment Variables
As a part of the disk image building process, the director requires a base image and registration details to obtain packages for the new overcloud image. You define these aspects using Linux environment variables.
The image building process temporarily registers the image with a Red Hat subscription and unregisters the system once the image building process completes.
To build a disk image, set Linux environment variables that suit your environment and requirements:
- DIB_LOCAL_IMAGE
- Sets the local image to use as your basis.
- REG_ACTIVATION_KEY
- Use an activation key instead as part of the registration process.
- REG_AUTO_ATTACH
- Defines whether or not to automatically attach the most compatible subscription.
- REG_BASE_URL
- 
									The base URL of the content delivery server to pull packages. The default Customer Portal Subscription Management process uses https://cdn.redhat.com. If using a Red Hat Satellite 6 server, this parameter should use the base URL of your Satellite server.
- REG_ENVIRONMENT
- Registers to an environment within an organization.
- REG_METHOD
- 
									Sets the method of registration. Use portalto register a system to the Red Hat Customer Portal. Usesatelliteto register a system with Red Hat Satellite 6.
- REG_ORG
- The organization to register the images.
- REG_POOL_ID
- The pool ID of the product subscription information.
- REG_PASSWORD
- Gives the password for the user account registering the image.
- REG_REPOS
- 
									A string of repository names separated with commas (no spaces). Each repository in this string is enabled through subscription-manager.
- REG_SAT_URL
- The base URL of the Satellite server to register Overcloud nodes. Use the Satellite’s HTTP URL and not the HTTPS URL for this parameter. For example, use http://satellite.example.com and not https://satellite.example.com.
- REG_SERVER_URL
- 
									Gives the hostname of the subscription service to use. The default is for the Red Hat Customer Portal at subscription.rhn.redhat.com. If using a Red Hat Satellite 6 server, this parameter should use the hostname of your Satellite server.
- REG_USER
- Gives the user name for the account registering the image.
4.4.3. Installing the User Image
- Download the Red Hat Enterprise Linux KVM guest image from the Customer Portal (requires login).
- Define DIB_LOCAL_IMAGE as the downloaded image: - export DIB_LOCAL_IMAGE=rhel-server-7.4-x86_64-kvm.qcow2 - $ export DIB_LOCAL_IMAGE=rhel-server-7.4-x86_64-kvm.qcow2- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set your registration information. If you use Red Hat Customer Portal, you must configure the following information: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If you use Red Hat Satellite, you must configure the following information: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If you have any offline repositories, you can define DIB_YUM_REPO_CONF as local repository configuration: - export DIB_YUM_REPO_CONF=<path-to-local-repository-config-file> - $ export DIB_YUM_REPO_CONF=<path-to-local-repository-config-file>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the user images using the - diskimage-buildertool:- disk-image-create rhel7 baremetal -o rhel-image - $ disk-image-create rhel7 baremetal -o rhel-image- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This extracts the kernel as - rhel-image.vmlinuzand initial ramdisk as- rhel-image.initrd.
- Upload the images to the Image service: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.5. Adding Physical Machines as Bare Metal Nodes
There are two methods to enroll a bare metal node:
- Prepare an inventory file with the node details, import the file into the Bare Metal service, then make the nodes available.
- Register a physical machine as a bare metal node, then manually add its hardware details and create ports for each of its Ethernet MAC addresses. These steps can be performed on any node which has your overcloudrc file.
Both methods are detailed in this section.
				After enrolling the physical machines, Compute is not immediately notified of new resources, because Compute’s resource tracker synchronizes periodically. Changes will be visible after the next periodic task is run. This value, scheduler_driver_task_period, can be updated in /etc/nova/nova.conf. The default period is 60 seconds.
			
4.5.1. Enrolling a Bare Metal Node With an Inventory File
- Create a file - overcloud-nodes.yaml, including the node details. Multiple nodes can be enrolled with one file.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace the following values: - 
									<IPMI_IP>with the address of the Bare Metal controller.
- 
									<USER>with your username.
- 
									<PASSWORD>with your password.
- 
									<CPU_COUNT>with the number of CPUs.
- 
									<CPU_ARCHITECTURE>with the type of architecture of the CPUs.
- 
									<MEMORY>with the amount of memory in MiB.
- 
									<ROOT_DISK>with the size of the root disk in GiB.
- <PXE_NIC_MAC>with the MAC address of the NIC used to PXE boot.- You only need to include - root_deviceif the machine has multiple disks. Replace- <SERIAL>with the serial number of the disk you would like used for deployment.
 
- 
									
- Set up the shell to use Identity as the administrative user: - source ~/overcloudrc - $ source ~/overcloudrc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Import the inventory file into ironic: - openstack baremetal create overcloud-nodes.yaml - $ openstack baremetal create overcloud-nodes.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							The nodes are now in the enrollstate.
- Specify the deploy kernel and deploy ramdisk on each node: - openstack baremetal node set NODE_UUID \ --driver-info deploy_kernel=KERNEL_UUID \ --driver-info deploy_ramdisk=INITRAMFS_UUID - $ openstack baremetal node set NODE_UUID \ --driver-info deploy_kernel=KERNEL_UUID \ --driver-info deploy_ramdisk=INITRAMFS_UUID- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace the following values: - Replace NODE_UUID with the unique identifier for the node. Alternatively, use the node’s logical name.
- Replace KERNEL_UUID with the unique identifier for the kernel deploy image that was uploaded to the Image service. Find this value with: - openstack image show bm-deploy-kernel -f value -c id - $ openstack image show bm-deploy-kernel -f value -c id- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Replace INITRAMFS_UUID with the unique identifier for the ramdisk image that was uploaded to the Image service. Find this value with: - openstack image show bm-deploy-ramdisk -f value -c id - $ openstack image show bm-deploy-ramdisk -f value -c id- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Set the node’s provisioning state to - available:- openstack baremetal node manage NODE_UUID openstack baremetal node provide NODE_UUID - $ openstack baremetal node manage NODE_UUID $ openstack baremetal node provide NODE_UUID- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The bare metal service cleans the node if you enabled node cleaning, 
- Set the local boot option on the node: - openstack baremetal node set _NODE_UUID_ --property capabilities="boot_option:local" - $ openstack baremetal node set _NODE_UUID_ --property capabilities="boot_option:local"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check that the nodes were successfully enrolled: - openstack baremetal node list - $ openstack baremetal node list- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - There may be a delay between enrolling a node and its state being shown. 
4.5.2. Enrolling a Bare Metal Node Manually
- Set up the shell to use Identity as the administrative user: - source ~/overcloudrc - $ source ~/overcloudrc- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add a new node: - openstack baremetal node create --driver pxe_ipmitool --name NAME - $ openstack baremetal node create --driver pxe_ipmitool --name NAME- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - To create a node you must specify the driver name. This example uses - pxe_impitool. To use a different driver, you must enable it by setting the- IronicEnabledDriversparameter. For more information on supported drivers, see Appendix A, Bare Metal Drivers.Important- Note the unique identifier for the node. 
- Update the node driver information to allow the Bare Metal service to manage the node: - openstack baremetal node set NODE_UUID \ --driver_info PROPERTY=VALUE \ --driver_info PROPERTY=VALUE - $ openstack baremetal node set NODE_UUID \ --driver_info PROPERTY=VALUE \ --driver_info PROPERTY=VALUE- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace the following values: - Replace NODE_UUID with the unique identifier for the node. Alternatively, use the node’s logical name.
- Replace PROPERTY with a required property returned by the ironic driver-properties command.
- Replace VALUE with a valid value for that property.
 
- Specify the deploy kernel and deploy ramdisk for the node driver: - openstack baremetal node set NODE_UUID \ --driver-info deploy_kernel=KERNEL_UUID \ --driver-info deploy_ramdisk=INITRAMFS_UUID - $ openstack baremetal node set NODE_UUID \ --driver-info deploy_kernel=KERNEL_UUID \ --driver-info deploy_ramdisk=INITRAMFS_UUID- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace the following values: - Replace NODE_UUID with the unique identifier for the node. Alternatively, use the node’s logical name.
- Replace KERNEL_UUID with the unique identifier for the .kernel image that was uploaded to the Image service.
- Replace INITRAMFS_UUID with the unique identifier for the .initramfs image that was uploaded to the Image service.
 
- Update the node’s properties to match the hardware specifications on the node: - openstack baremetal node set NODE_UUID \ --property cpus=CPU \ --property memory_mb=RAM_MB \ --property local_gb=DISK_GB \ --property cpu_arch=ARCH - $ openstack baremetal node set NODE_UUID \ --property cpus=CPU \ --property memory_mb=RAM_MB \ --property local_gb=DISK_GB \ --property cpu_arch=ARCH- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace the following values: - Replace NODE_UUID with the unique identifier for the node. Alternatively, use the node’s logical name.
- Replace CPU with the number of CPUs.
- Replace RAM_MB with the RAM (in MB).
- Replace DISK_GB with the disk size (in GB).
- Replace ARCH with the architecture type.
 
- OPTIONAL: Configure the node to reboot after initial deployment from a local boot loader installed on the node’s disk, instead of using PXE from - ironic-conductor. The local boot capability must also be set on the flavor used to provision the node. To enable local boot, the image used to deploy the node must contain grub2. Configure local boot:- openstack baremetal node set NODE_UUID \ --property capabilities="boot_option:local" - $ openstack baremetal node set NODE_UUID \ --property capabilities="boot_option:local"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace NODE_UUID with the unique identifier for the node. Alternatively, use the node’s logical name. 
- Inform the Bare Metal service of the node’s network card by creating a port with the MAC address of the NIC on the provisioning network: - openstack baremetal port create --node NODE_UUID MAC_ADDRESS - $ openstack baremetal port create --node NODE_UUID MAC_ADDRESS- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace NODE_UUID with the unique identifier for the node. Replace MAC_ADDRESS with the MAC address of the NIC used to PXE boot. 
- If you have multiple disks, set the root device hints. This informs the deploy ramdisk which disk it should use for deployment. - openstack baremetal node set NODE_UUID \ --property root_device={"PROPERTY": "VALUE"}- $ openstack baremetal node set NODE_UUID \ --property root_device={"PROPERTY": "VALUE"}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace with the following values: - Replace NODE_UUID with the unique identifier for the node. Alternatively, use the node’s logical name.
- Replace PROPERTY and VALUE with details about the disk you want used for deployment, for example - root_device='{"size": 128}'- The following properties are supported: - 
											model(String): Device identifier.
- 
											vendor(String): Device vendor.
- 
											serial(String): Disk serial number.
- 
											hctl(String): Host:Channel:Target:Lun for SCSI.
- 
											size(Integer): Size of the device in GB.
- 
											wwn(String): Unique storage identifier.
- 
											wwn_with_extension(String): Unique storage identifier with the vendor extension appended.
- 
											wwn_vendor_extension(String): Unique vendor storage identifier.
- 
											rotational(Boolean): True for a rotational device (HDD), otherwise false (SSD).
- name(String): The name of the device, for example: /dev/sdb1 Only use this for devices with persistent names.Note- If you specify more than one property, the device must match all of those properties. 
 
- 
											
 
- Validate the node’s setup: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Replace NODE_UUID with the unique identifier for the node. Alternatively, use the node’s logical name. The output of the command above should report either - Trueor- Nonefor each interface. Interfaces marked- Noneare those that you have not configured, or those that are not supported for your driver.Note- Interfaces may fail validation due to missing 'ramdisk', 'kernel', and 'image_source' parameters. This result is fine, because the Compute service populates those missing parameters at the beginning of the deployment process. 
4.6. Using Host Aggregates to Separate Physical and Virtual Machine Provisioning
OpenStack Compute uses host aggregates to partition availability zones, and group together nodes with specific shared properties. When an instance is provisioned, Compute’s scheduler compares properties on the flavor with the properties assigned to host aggregates, and ensures that the instance is provisioned in the correct aggregate and on the correct host: either on a physical machine or as a virtual machine.
The procedure below describes how to do the following:
- 
						Add the property baremetalto your flavors, setting it to eithertrueorfalse.
- 
						Create separate host aggregates for bare metal hosts and compute nodes with a matching baremetalproperty. Nodes grouped into an aggregate inherit this property.
Creating a Host Aggregate
- Set the - baremetalproperty to- trueon the baremetal flavor.- openstack flavor set baremetal --property baremetal=true - $ openstack flavor set baremetal --property baremetal=true- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - baremetalproperty to- falseon the flavors used for virtual instances.- openstack flavor set FLAVOR_NAME --property baremetal=false - $ openstack flavor set FLAVOR_NAME --property baremetal=false- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a host aggregate called - baremetal-hosts:- openstack aggregate create --property baremetal=true baremetal-hosts - $ openstack aggregate create --property baremetal=true baremetal-hosts- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add each controller node to the - baremetal-hostsaggregate:- openstack aggregate add host baremetal-hosts HOSTNAME - $ openstack aggregate add host baremetal-hosts HOSTNAME- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- If you have created a composable role with the - NovaIronicservice, add all the nodes with this service to the- baremetal-hostsaggregate. By default, only the controller nodes have the- NovaIronicservice.
- Create a host aggregate called - virtual-hosts:- openstack aggregate create --property baremetal=false virtual-hosts - $ openstack aggregate create --property baremetal=false virtual-hosts- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add each compute node to the - virtual-hostsaggregate:- openstack aggregate add host virtual-hosts HOSTNAME - $ openstack aggregate add host virtual-hosts HOSTNAME- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- If you did not add the following Compute filter scheduler when deploying the overcloud, add it now to the existing list under - scheduler_default_filtersin /etc/nova/nova.conf:- AggregateInstanceExtraSpecsFilter - AggregateInstanceExtraSpecsFilter- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow