Chapter 12. Provisioning cloud instances on Red Hat OpenStack Services on OpenShift
Red Hat OpenStack Services on OpenShift provides the foundation to build a private or public Infrastructure-as-a-Service (IaaS) cloud. It offers a massively scalable, fault-tolerant platform for the development of cloud-enabled workloads. In Satellite, you can interact with Red Hat OpenStack Services on OpenShift REST API to create cloud instances and control their power management states.
Prerequisites
- You can use synchronized content repositories for Red Hat Enterprise Linux. For more information, see Syncing Repositories in Managing content.
- Provide an activation key for host registration. For more information, see Creating An Activation Key in Managing content.
- A Capsule Server managing a network in your OpenStack environment. For more information, see Preparing networking in Provisioning hosts.
- An image added to OpenStack Image Storage (glance) service for image-based provisioning. For more information, see the Red Hat OpenStack Services on OpenShift Instances and Images Guide.
Additional resources
- You can configure Satellite to remove the associated virtual machine when you delete a host. For more information, see Section 2.22, “Removing a virtual machine upon host deletion”.
12.1. Adding a Red Hat OpenStack Services on OpenShift connection to Satellite Server
You can add Red Hat OpenStack Services on OpenShift as a compute resource in Satellite. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Infrastructure > Compute Resources.
- Click Create Compute Resource.
- In the Name field, enter a name for the new compute resource.
- From the Provider list, select RHEL OpenStack Platform.
- Optional: In the Description field, enter a description for the compute resource.
- 
						In the URL field, enter the URL for the OpenStack Authentication keystone service’s API at the tokensresource, such ashttp://openstack.example.com:5000/v2.0/tokensorhttp://openstack.example.com:5000/v3/auth/tokens.
- In the Username and Password fields, enter the user authentication for Satellite to access the environment.
- Optional: In the Project (Tenant) name field, enter the name of your tenant (v2) or project (v3) for Satellite Server to manage.
- In the User domain field, enter the user domain for v3 authentication.
- In the Project domain name field, enter the project domain name for v3 authentication.
- In the Project domain ID field, enter the project domain ID for v3 authentication.
- Optional: Select Allow external network as main network to use external networks as primary networks for hosts.
- Optional: Click Test Connection to verify that Satellite can connect to your compute resource.
- Click the Locations and Organizations tabs and verify that the location and organization that you want to use are set to your current context. Add any additional contexts that you want to these tabs.
- Click Submit to save the Red Hat OpenStack Services on OpenShift connection.
CLI procedure
- To create a compute resource, enter the - hammer compute-resource createcommand:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
12.2. Adding Red Hat OpenStack Services on OpenShift images to Satellite Server
To create hosts using image-based provisioning, you must add information about the image, such as access details and the image location, to your Satellite Server.
To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Infrastructure > Compute Resources and click the name of the Red Hat OpenStack Services on OpenShift connection.
- Click Create Image.
- In the Name field, enter a name for the image.
- From the Operating System list, select the base operating system of the image.
- From the Architecture list, select the operating system architecture.
- 
						In the Username field, enter the SSH user name for image access. This is normally the rootuser.
- In the Password field, enter the SSH password for image access.
- From the Image list, select an image from the Red Hat OpenStack Services on OpenShift compute resource.
- 
						Optional: Select the User Data checkbox if the image supports user data input, such as cloud-initdata.
- Click Submit to save the image details.
CLI procedure
- Create the image with the - hammer compute-resource image createcommand. Use the- --uuidfield to store the full path of the image location on the Red Hat OpenStack Services on OpenShift server.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
12.3. Adding Red Hat OpenStack Services on OpenShift details to a compute profile
Use this procedure to add Red Hat OpenStack Services on OpenShift hardware settings to a compute profile. When you create a host on Red Hat OpenStack Services on OpenShift using this compute profile, these settings are automatically populated.
Procedure
- In the Satellite web UI, navigate to Infrastructure > Compute Profiles.
- In the Compute Profiles window, click the name of an existing compute profile, or click Create Compute Profile, enter a Name, and click Submit.
- Click the name of the Red Hat OpenStack Services on OpenShift compute resource.
- From the Flavor list, select the hardware profile on Red Hat OpenStack Services on OpenShift to use for the host.
- From the Availability zone list, select the target cluster to use within the Red Hat OpenStack Services on OpenShift environment.
- From the Image list, select the image to use for image-based provisioning.
- From the Tenant list, select the tenant or project for the Red Hat OpenStack Services on OpenShift instance.
- From the Security Group list, select the cloud-based access rules for ports and IP addresses.
- From the Internal network, select the private networks for the host to join.
- From the Floating IP network, select the external networks for the host to join and assign a floating IP address.
- From the Boot from volume, select whether a volume is created from the image. If not selected, the instance boots the image directly.
- In the New boot volume size (GB) field, enter the size, in GB, of the new boot volume.
- Click Submit to save the compute profile.
CLI procedure
- Set Red Hat OpenStack Services on OpenShift details to a compute profile: - hammer compute-profile values create - $ hammer compute-profile values create --compute-resource "My_Laptop" \ --compute-profile "My_Compute_Profile" \ --compute-attributes "availability_zone=My_Zone,image_ref=My_Image,flavor_ref=m1.small,tenant_id=openstack,security_groups=default,network=My_Network,boot_from_volume=false"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
12.4. Creating image-based hosts on Red Hat OpenStack Services on OpenShift
In Satellite, you can use Red Hat OpenStack Services on OpenShift provisioning to create hosts from an existing image. The new host entry triggers the Red Hat OpenStack Services on OpenShift server to create the instance using the pre-existing image as a basis for the new volume.
To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Hosts > Create Host.
- In the Name field, enter a name for the host.
- Optional: Click the Organization tab and change the organization context to match your requirement.
- Optional: Click the Location tab and change the location context to match your requirement.
- From the Host Group list, select a host group that you want to assign your host to. That host group will populate the form.
- From the Deploy on list, select the Red Hat OpenStack Services on OpenShift connection.
- From the Compute Profile list, select a profile to use to automatically populate virtual machine settings.
- From the Lifecycle Environment list, select the environment.
- Click the Interfaces tab, and on the interface of the host, click Edit.
- Verify that the fields are populated with values. Note in particular: - Satellite automatically assigns an IP address for the new host.
- Ensure that the MAC address field is blank. Red Hat OpenStack Services on OpenShift assigns a MAC address to the host during provisioning.
- The Name from the Host tab becomes the DNS name.
- Ensure that Satellite automatically selects the Managed, Primary, and Provision options for the first interface on the host. If not, select them.
 
- Click OK to save. To add another interface, click Add Interface. You can select only one interface for Provision and Primary.
- Click the Operating System tab, and confirm that all fields automatically contain values.
- If you want to change the image that populates automatically from your compute profile, from the Images list, select a different image to base the new host’s root volume on.
- Click Resolve in Provisioning templates to check the new host can identify the right provisioning templates to use.
- Click the Virtual Machine tab and confirm that these settings are populated with details from the host group and compute profile. Modify these settings to suit your needs.
- 
						On the Parameters tab, click Add parameter. Add a parameter named kt_activation_keys, select the string type, and enter the name of the activation key as the value. The activation key has to belong to the same organization as your host. You can also enter a comma-separated list of multiple activation keys.
- Click Submit to save the host entry.
CLI procedure
- Create the host with the - hammer host createcommand and include- --provision-method image. Replace the values in the following example with the appropriate values for your environment.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
				For more information about additional host creation parameters for this compute resource, enter the hammer host create --help command.