The API version for the install-config.yaml content. The current version is v1. The installation program might also support older API versions.
Value: String
Before you deploy an OKD cluster on Azure Stack Hub, you provide a customized install-config.yaml installation configuration file that describes the details for your environment.
The following tables specify the required, optional, and Azure Stack Hub-specific installation configuration parameters that you can set as part of the installation process.
| After installation, you cannot change these parameters in the  | 
Required installation configuration parameters are described in the following table:
| Parameter | Description | 
|---|---|
| apiVersion: | The API version for the  Value: String | 
| baseDomain: | The base domain of your cloud provider. The base domain is used to create routes to your OKD cluster components. The full DNS name for your cluster is a combination of the  Value: A fully-qualified domain or subdomain name, such as  | 
| metadata: | Kubernetes resource  Value: Object | 
| metadata: name: | The name of the cluster. DNS records for the cluster are all subdomains of  Value: String of lowercase letters, hyphens ( | 
| platform: | The configuration for the specific platform upon which to perform the installation:  Value: Object | 
You can customize your installation configuration based on the requirements of your existing network infrastructure. For example, you can expand the IP address block for the cluster network or configure different IP address blocks than the defaults.
Only IPv4 addresses are supported.
| Parameter | Description | ||
|---|---|---|---|
| networking: | The configuration for the cluster network. Value: Object 
 | ||
| networking: networkType: | The Red Hat OpenShift Networking network plugin to install. Value:
 | ||
| networking: clusterNetwork: | The IP address blocks for pods. The default value is  If you specify multiple IP address blocks, the blocks must not overlap. Value: An array of objects. For example:  | ||
| networking:
  clusterNetwork:
    cidr: | Required if you use  An IPv4 network. Value: An IP address block in Classless Inter-Domain Routing (CIDR) notation. The prefix length for an IPv4 block is between  | ||
| networking:
  clusterNetwork:
    hostPrefix: | The subnet prefix length to assign to each individual node. For example, if  Value: A subnet prefix. The default value is  | ||
| networking: serviceNetwork: | The IP address block for services. The default value is  The OVN-Kubernetes network plugins supports only a single IP address block for the service network. Value: An array with an IP address block in CIDR format. For example:  | ||
| networking: machineNetwork: | The IP address blocks for machines. If you specify multiple IP address blocks, the blocks must not overlap. Value: An array of objects. For example:  | ||
| networking:
  machineNetwork:
    cidr: | Required if you use  Value: An IP network block in CIDR notation. For example,  
 | ||
| networking:
  ovnKubernetesConfig:
    ipv4:
      internalJoinSubnet: | Configures the IPv4 join subnet that is used internally by  Value: An IP network block in CIDR notation. The default value is  | 
Optional installation configuration parameters are described in the following table:
| Parameter | Description | ||
|---|---|---|---|
| additionalTrustBundle: | A PEM-encoded X.509 certificate bundle that is added to the nodes' trusted certificate store. This trust bundle might also be used when a proxy has been configured. Value: String | ||
| capabilities: | Controls the installation of optional core cluster components. You can reduce the footprint of your OKD cluster by disabling optional components. For more information, see the "Cluster capabilities" page in Installing. Value: String array | ||
| capabilities: baselineCapabilitySet: | Selects an initial set of optional capabilities to enable. Valid values are  Value: String | ||
| capabilities: additionalEnabledCapabilities: | Extends the set of optional capabilities beyond what you specify in  Value: String array | ||
| cpuPartitioningMode: | Enables workload partitioning, which isolates OKD services, cluster management workloads, and infrastructure pods to run on a reserved set of CPUs. You can only enable workload partitioning during installation. You cannot disable it after installation. While this field enables workload partitioning, it does not configure workloads to use specific CPUs. For more information, see the Workload partitioning page in the Scalability and Performance section. Value:  | ||
| compute: | The configuration for the machines that comprise the compute nodes. Value: Array of  | ||
| compute: architecture: | Determines the instruction set architecture of the machines in the pool. Currently, clusters with varied architectures are not supported. All pools must specify the same architecture. The valid value is the default:  Value: String | ||
| compute: hyperthreading: | Whether to enable or disable simultaneous multithreading, or  
 Value:  | ||
| compute: name: | Required if you use  Value:  | ||
| compute: platform: | Required if you use  Value:
 | ||
| compute: replicas: | The number of compute machines, which are also known as worker machines, to provision. Value: A positive integer greater than or equal to  | ||
| featureSet: | Enables the cluster for a feature set. A feature set is a collection of OKD features that are not enabled by default. For more information about enabling a feature set during installation, see "Enabling features using feature gates". Value: String. The name of the feature set to enable, such as  | ||
| controlPlane: | The configuration for the machines that form the control plane. Value: Array of  | ||
| controlPlane: architecture: | Determines the instruction set architecture of the machines in the pool. Currently, clusters with varied architectures are not supported. All pools must specify the same architecture. The valid value is  Value: String | ||
| controlPlane: hyperthreading: | Whether to enable or disable simultaneous multithreading, or  
 Value:  | ||
| controlPlane: name: | Required if you use  Value:  | ||
| controlPlane: platform: | Required if you use  Value:
 | ||
| controlPlane: replicas: | The number of control plane machines to provision. Value:
Supported values are  | ||
| arbiter:
    name: arbiter | The OKD cluster requires a name for arbiter nodes. For example,  | ||
| arbiter:
    replicas: 1 | The  | ||
| credentialsMode: | The Cloud Credential Operator (CCO) mode. If no mode is specified, the CCO dynamically tries to determine the capabilities of the provided credentials, with a preference for mint mode on the platforms where multiple modes are supported. 
 Value:  | ||
| imageContentSources: | Sources and repositories for the release-image content. Value: Array of objects. Includes a  | ||
| imageContentSources: source: | Required if you use  Value: String | ||
| imageContentSources: mirrors: | Specify one or more repositories that might also contain the same images. Value: Array of strings | ||
| publish: | How to publish or expose the user-facing endpoints of your cluster, such as the Kubernetes API, OpenShift routes. Value:
 Setting this field to  
 | ||
| sshKey: | The SSH key to authenticate access to your cluster machines. 
 Value: For example,  | 
Additional Azure configuration parameters are described in the following table:
| Parameter | Description | 
|---|---|
| compute:
  platform:
    azure:
      osDisk:
        diskSizeGB: | The Azure disk size for the VM. Value: Integer that represents the size of the disk in GB. The default is  | 
| compute:
  platform:
    azure:
      osDisk:
        diskType: | Defines the type of disk. Value:  | 
| compute:
  platform:
    azure:
      type: | Defines the azure instance type for compute machines. Value: String | 
| controlPlane:
  platform:
    azure:
      osDisk:
        diskSizeGB: | The Azure disk size for the VM. Value: Integer that represents the size of the disk in GB. The default is  | 
| controlPlane:
  platform:
    azure:
      osDisk:
        diskType: | Defines the type of disk. Value:  | 
| controlPlane:
  platform:
    azure:
      type: | Defines the azure instance type for control plane machines. Value: String | 
| platform:
  azure:
    defaultMachinePlatform:
      osDisk:
        diskSizeGB: | The Azure disk size for the VM. Value: Integer that represents the size of the disk in GB. The default is  | 
| platform:
  azure:
    defaultMachinePlatform:
      osDisk:
        diskType: | Defines the type of disk. Value:  | 
| platform:
  azure:
    defaultMachinePlatform:
      type: | The Azure instance type for control plane and compute machines. Value: The Azure instance type. | 
| platform:
  azure:
    armEndpoint: | The URL of the Azure Resource Manager endpoint that your Azure Stack Hub operator provides. Value: String | 
| platform:
  azure:
    baseDomainResourceGroupName: | The name of the resource group that contains the DNS zone for your base domain. Value: String, for example  | 
| platform:
  azure:
    region: | The name of your Azure Stack Hub local region. Value: String | 
| platform:
  azure:
    resourceGroupName: | The name of an already existing resource group to install your cluster to. This resource group must be empty and only used for this specific cluster; the cluster components assume ownership of all resources in the resource group. If you limit the service principal scope of the installation program to this resource group, you must ensure all other resources used by the installation program in your environment have the necessary permissions, such as the public DNS zone and virtual network. Destroying the cluster by using the installation program deletes this resource group. Value: String, for example  | 
| platform:
  azure:
    outboundType: | The outbound routing strategy used to connect your cluster to the internet. If you are using user-defined routing, you must have pre-existing networking available. The outbound routing must be configured before installing a cluster. The installation program does not configure user-defined routing. Value:  | 
| platform:
  azure:
    cloudName: | The name of the Azure cloud environment that is used to configure the Azure SDK with the appropriate Azure API endpoints. Value:  | 
| clusterOSImage: | The URL of a storage blob in the Azure Stack environment that contains an FCOS VHD. Value: String, for example, https://vhdsa.blob.example.example.com/vhd/rhcos-410.84.202112040202-0-azurestack.x86_64.vhd |