$ export COMPRESSED_VHD_URL=$(openshift-install coreos print-stream-json | jq -r '.architectures.x86_64.artifacts.azurestack.formats."vhd.gz".disk.location')In OKD version 4.19, you can install a cluster on Microsoft Azure Stack Hub with an installer-provisioned infrastructure. However, you must manually configure the install-config.yaml file to specify values that are specific to Azure Stack Hub.
| While you can select  | 
You reviewed details about the OKD installation and update processes.
You read the documentation on selecting a cluster installation method and preparing it for users.
You have installed Azure Stack Hub version 2008 or later.
You configured an Azure Stack Hub account to host the cluster.
If you use a firewall, you configured it to allow the sites that your cluster requires access to.
You verified that you have approximately 16 GB of local disk space. Installing the cluster requires that you download the FCOS virtual hard drive (VHD) cluster image and upload it to your Azure Stack Hub environment so that it is accessible during deployment. Decompressing the VHD files requires this amount of local disk space.
You must download the FCOS virtual hard disk (VHD) cluster image and upload it to your Azure Stack Hub environment so that it is accessible during deployment.
Generate the Ignition config files for your cluster.
Obtain the FCOS VHD cluster image:
Export the URL of the FCOS VHD to an environment variable.
$ export COMPRESSED_VHD_URL=$(openshift-install coreos print-stream-json | jq -r '.architectures.x86_64.artifacts.azurestack.formats."vhd.gz".disk.location')Download the compressed FCOS VHD file locally.
$ curl -O -L ${COMPRESSED_VHD_URL}Decompress the VHD file.
| The decompressed VHD file is approximately 16 GB, so be sure that your host system has 16 GB of free space available. The VHD file can be deleted once you have uploaded it. | 
Upload the local VHD to the Azure Stack Hub environment, making sure that the blob is publicly available. For example, you can upload the VHD to a blob using the az cli or the web portal.
Installing the cluster requires that you manually create the installation configuration file.
You have an SSH public key on your local machine for use with the installation program. You can use the key for SSH authentication onto your cluster nodes for debugging and disaster recovery.
You have obtained the OKD installation program and the pull secret for your cluster.
Create an installation directory to store your required installation assets in:
$ mkdir <installation_directory>| You must create a directory. Some installation assets, such as bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OKD version. | 
Customize the provided sample install-config.yaml file template and save the file in the <installation_directory>.
| You must name this configuration file  | 
Make the following modifications:
Specify the required installation parameters.
Update the platform.azure section to specify the parameters that are specific to Azure Stack Hub.
Optional: Update one or more of the default configuration parameters to customize the installation.
For more information about the parameters, see "Installation configuration parameters".
Back up the install-config.yaml file so that you can use it to install many clusters.
| Back up the  | 
You can customize the install-config.yaml file to specify more details about your OKD cluster’s platform or modify the values of the required parameters.
| This sample YAML file is provided for reference only. Use it as a resource to enter parameter values into the installation configuration file that you created manually. | 
apiVersion: v1
baseDomain: example.com (1)
credentialsMode: Manual
controlPlane:  (2) (3)
  name: master
  platform:
    azure:
      osDisk:
        diskSizeGB: 1024 (4)
        diskType: premium_LRS
  replicas: 3
compute: (2)
- name: worker
  platform:
    azure:
      osDisk:
        diskSizeGB: 512 (4)
        diskType: premium_LRS
  replicas: 3
metadata:
  name: test-cluster  (1) (5)
networking:
  clusterNetwork:
  - cidr: 10.128.0.0/14
    hostPrefix: 23
  machineNetwork:
  - cidr: 10.0.0.0/16
  networkType: OVNKubernetes (6)
  serviceNetwork:
  - 172.30.0.0/16
platform:
  azure:
    armEndpoint: azurestack_arm_endpoint  (1) (7)
    baseDomainResourceGroupName: resource_group  (1) (8)
    region: azure_stack_local_region  (1) (9)
    resourceGroupName: existing_resource_group (10)
    outboundType: Loadbalancer
    cloudName: AzureStackCloud (1)
    clusterOSimage: https://vhdsa.blob.example.example.com/vhd/rhcos-410.84.202112040202-0-azurestack.x86_64.vhd  (1) (11)
pullSecret: '{"auths": ...}'  (1) (12)
sshKey: ssh-ed25519 AAAA...(13)
additionalTrustBundle: | (14)
    -----BEGIN CERTIFICATE-----
    <MY_TRUSTED_CA_CERT>
    -----END CERTIFICATE-----| 1 | Required. | ||
| 2 | If you do not provide these parameters and values, the installation program provides the default value. | ||
| 3 | The controlPlanesection is a single mapping, but thecomputesection is a sequence of mappings. To meet the requirements of the different data structures, the first line of thecomputesection must begin with a hyphen,-, and the first line of thecontrolPlanesection must not. Although both sections currently define a single machine pool, it is possible that future versions of OKD will support defining multiple compute pools during installation. Only one control plane pool is used. | ||
| 4 | You can specify the size of the disk to use in GB. Minimum recommendation for control plane nodes is 1024 GB. | ||
| 5 | The name of the cluster. | ||
| 6 | The cluster network plugin to install. The default value OVNKubernetesis the only supported value. | ||
| 7 | The Azure Resource Manager endpoint that your Azure Stack Hub operator provides. | ||
| 8 | The name of the resource group that contains the DNS zone for your base domain. | ||
| 9 | The name of your Azure Stack Hub local region. | ||
| 10 | The name of an existing resource group to install your cluster to. If undefined, a new resource group is created for the cluster. | ||
| 11 | The URL of a storage blob in the Azure Stack environment that contains an FCOS VHD. | ||
| 12 | The pull secret required to authenticate your cluster. | ||
| 13 | You can optionally provide the sshKeyvalue that you use to access the machines in your cluster.
 | ||
| 14 | If the Azure Stack Hub environment is using an internal Certificate Authority (CA), adding the CA certificate is required. | 
The Cloud Credential Operator (CCO) only supports your cloud provider in manual mode. As a result, you must specify the identity and access management (IAM) secrets for your cloud provider.
If you have not previously created installation manifest files, do so by running the following command:
$ openshift-install create manifests --dir <installation_directory>where <installation_directory> is the directory in which the installation program creates files.
Set a $RELEASE_IMAGE variable with the release image from your installation file by running the following command:
$ RELEASE_IMAGE=$(./openshift-install version | awk '/release image/ {print $3}')Extract the list of CredentialsRequest custom resources (CRs) from the OKD release image by running the following command:
$ oc adm release extract \
  --from=$RELEASE_IMAGE \
  --credentials-requests \
  --included \(1)
  --install-config=<path_to_directory_with_installation_configuration>/install-config.yaml \(2)
  --to=<path_to_directory_for_credentials_requests> (3)| 1 | The --includedparameter includes only the manifests that your specific cluster configuration requires. | 
| 2 | Specify the location of the install-config.yamlfile. | 
| 3 | Specify the path to the directory where you want to store the CredentialsRequestobjects. If the specified directory does not exist, this command creates it. | 
This command creates a YAML file for each CredentialsRequest object.
CredentialsRequest objectapiVersion: cloudcredential.openshift.io/v1
kind: CredentialsRequest
metadata:
  name: <component_credentials_request>
  namespace: openshift-cloud-credential-operator
  ...
spec:
  providerSpec:
    apiVersion: cloudcredential.openshift.io/v1
    kind: AzureProviderSpec
    roleBindings:
    - role: Contributor
  ...Create YAML files for secrets in the openshift-install manifests directory that you generated previously. The secrets must be stored using the namespace and secret name defined in the spec.secretRef for each CredentialsRequest object.
CredentialsRequest object with secretsapiVersion: cloudcredential.openshift.io/v1
kind: CredentialsRequest
metadata:
  name: <component_credentials_request>
  namespace: openshift-cloud-credential-operator
  ...
spec:
  providerSpec:
    apiVersion: cloudcredential.openshift.io/v1
    kind: AzureProviderSpec
    roleBindings:
    - role: Contributor
      ...
  secretRef:
    name: <component_secret>
    namespace: <component_namespace>
  ...Secret objectapiVersion: v1
kind: Secret
metadata:
  name: <component_secret>
  namespace: <component_namespace>
data:
  azure_subscription_id: <base64_encoded_azure_subscription_id>
  azure_client_id: <base64_encoded_azure_client_id>
  azure_client_secret: <base64_encoded_azure_client_secret>
  azure_tenant_id: <base64_encoded_azure_tenant_id>
  azure_resource_prefix: <base64_encoded_azure_resource_prefix>
  azure_resourcegroup: <base64_encoded_azure_resourcegroup>
  azure_region: <base64_encoded_azure_region>| Before upgrading a cluster that uses manually maintained credentials, you must ensure that the CCO is in an upgradeable state. | 
If the Azure Stack Hub environment is using an internal Certificate Authority (CA), update the cluster-proxy-01-config.yaml file to configure the cluster to use the internal CA.
Create the install-config.yaml file and specify the certificate trust bundle in .pem format.
Create the cluster manifests.
From the directory in which the installation program creates files, go to the manifests directory.
Add user-ca-bundle to  the spec.trustedCA.name field.
cluster-proxy-01-config.yaml fileapiVersion: config.openshift.io/v1
kind: Proxy
metadata:
  creationTimestamp: null
  name: cluster
spec:
  trustedCA:
    name: user-ca-bundle
status: {}Optional: Back up the manifests/ cluster-proxy-01-config.yaml file. The installation program consumes the manifests/ directory when you deploy the cluster.
You can install OKD on a compatible cloud platform.
| You can run the  | 
You have configured an account with the cloud platform that hosts your cluster.
You have the OKD installation program and the pull secret for your cluster.
You have verified that the cloud provider account on your host has the correct permissions to deploy the cluster. An account with incorrect permissions causes the installation process to fail with an error message that displays the missing permissions.
In the directory that contains the installation program, initialize the cluster deployment by running the following command:
$ ./openshift-install create cluster --dir <installation_directory> \ (1)
    --log-level=info (2)
| 1 | For <installation_directory>, specify the
location of your customized./install-config.yamlfile. | 
| 2 | To view different installation details, specify warn,debug, orerrorinstead ofinfo. | 
When the cluster deployment completes successfully:
The terminal displays directions for accessing your cluster, including a link to the web console and credentials for the kubeadmin user.
Credential information also outputs to <installation_directory>/.openshift_install.log.
| Do not delete the installation program or the files that the installation program creates. Both are required to delete the cluster. | 
...
INFO Install complete!
INFO To access the cluster as the system:admin user when using 'oc', run 'export KUBECONFIG=/home/myuser/install_dir/auth/kubeconfig'
INFO Access the OpenShift web-console here: https://console-openshift-console.apps.mycluster.example.com
INFO Login to the console with user: "kubeadmin", and password: "password"
INFO Time elapsed: 36m22s| 
 | 
You can log in to your cluster as a default system user by exporting the cluster kubeconfig file.
The kubeconfig file contains information about the cluster that is used by the CLI to connect a client to the correct cluster and API server.
The file is specific to a cluster and is created during OKD installation.
You deployed an OKD cluster.
You installed the OpenShift CLI (oc).
Export the kubeadmin credentials by running the following command:
$ export KUBECONFIG=<installation_directory>/auth/kubeconfig (1)| 1 | For <installation_directory>, specify the path to the directory that you stored
the installation files in. | 
Verify you can run oc commands successfully using the exported configuration by running the following command:
$ oc whoamisystem:adminThe kubeadmin user exists by default after an OKD installation. You can log in to your cluster as the kubeadmin user by using the OKD web console.
You have access to the installation host.
You completed a cluster installation and all cluster Operators are available.
Obtain the password for the kubeadmin user from the kubeadmin-password file on the installation host:
$ cat <installation_directory>/auth/kubeadmin-password| Alternatively, you can obtain the  | 
List the OKD web console route:
$ oc get routes -n openshift-console | grep 'console-openshift'| Alternatively, you can obtain the OKD route from the  | 
console     console-openshift-console.apps.<cluster_name>.<base_domain>            console     https   reencrypt/Redirect   NoneNavigate to the route detailed in the output of the preceding command in a web browser and log in as the kubeadmin user.