Mirroring images with a bastion host
If your cluster is not connected to the internet, you can mirror images to a registry in your network-restricted environment by using a bastion host. This task must be performed by a Red Hat OpenShift administrator.
A bastion host is a device that has access to both the public internet and the network-restricted environment where a local registry and Red Hat OpenShift Container Platform clusters reside. Using the bastion host, you can mirror your images directly to the local registry.
The process for mirroring images involves the following steps:
1. Set up your mirroring environment
Before you install any IBM Cloud Pak® on an air-gapped environment, you must set up a host that can be connected to the internet to complete configuring your mirroring environment. To set up your mirroring environment, complete the following steps:
1.1 Prerequisites
A Docker V2 registry that is available and accessible from the OpenShift Container Platform cluster nodes.
The following sites and ports must be accessible:
icr.io:443
for entitled registryquay.io:443
for Cloud Pak for Integrationgithub.com
for CASEs and toolsredhat.com
for Red Hat OpenShift Container Platform upgrades
Storage is available and configured on your cluster.
1.2 Prepare a host for mirroring the images
You must be able to connect your bastion host to the internet and to the restricted network environment (with access to the OpenShift Container Platform cluster and the local registry) at the same time. Your host must be on a Linux® x86_64 or Mac platform with any operating system that the OpenShift Container Platform CLI supports.
The following table provides the software requirements for installing Cloud Pak for Integration in an air-gapped environment:
Software requirements and purpose
Software | Purpose |
---|---|
Docker | Container management |
Podman | Container management |
oc |
Red Hat OpenShift Container Platform administration |
oc ibm-pak |
oc IBM Catalog Management Plug-in for IBM Cloud Paks |
Complete the following steps on your host:
Install Docker or Podman.
To install Docker (for example, on Red Hat® Enterprise Linux®), run the following commands:
yum check-update yum install docker
To install Podman, see Podman installation instructions.
Install the
oc
OpenShift Container Platform CLI tool.Follow the procedure for Getting started with the OpenShift CLI.
Download the IBM Catalog Management plug-in version 1.1.0 or later from GitHub. This plug-in allows you to run
oc ibm-pak
commands against the cluster.To confirm that
ibm-pak
is installed, run the following command:oc ibm-pak --help
This should return the
oc ibm-pak
usage.
1.3. Set up local image registry and access
Use a local Docker registry to store images in your network restricted environment. If you already have one or more centralized, corporate registry servers that store production container images, you can use those for this purpose. If a registry is not already available, install and configure a production-grade registry.
User access: To access your registries during the mirroring process, you need user credentials that can write to the target local registry and create repositories. To access your registries during runtime, you need user credentials that can read all repositories from the target local registry (these credentials are used by the OpenShift Container Platform cluster).
The local registry must meet the following requirements:
Supports multi-architecture images through Docker Manifest V2, Schema 2. For details, see Docker Manifest V2, Schema 2.
Sufficient storage to hold all the software.
Accessible from the OpenShift Container Platform cluster nodes.
Allows path separators in the image name.
Supports auto-repository creation.
2. Set environment variables and download CASE files
Before mirroring your images, you need to set the environment variables on your mirroring device. You also need to connect to the internet, so that you can download the corresponding CASE files. To finish preparing your host, complete the following steps:
Prerequisites (if you are applying fix packs prior to an upgrade):
Confirm that your operators are running properly.
If there are any pending operator updates that require manual approval, approve those before starting this procedure. For more information about why manual approval should not be configured for operator installs, see "Restricting automatic updates with an approval strategy" in Installing the operators by using the Red Hat OpenShift console.
Create the following environment variables with the installer image name and the image inventory on your host.
The table at the end of this section provides the export commands for all operators.
export CASE_NAME=ibm-integration-platform-navigator export CASE_VERSION=1.7.20
You need to separately mirror each component of Cloud Pak for Integration that you intend to use. CASE files for capabilities can be found in the IBM CASE repository.
Connect your host to the internet. It does not need to be connected to the network-restricted environment at this time.
Download the CASE to your host. If you do not specify the CASE version, it downloads the latest version.
oc ibm-pak get $CASE_NAME --version $CASE_VERSION
Repeat the process for each CASE you are mirroring.
Your host is now configured and you are ready to mirror your images.
Export commands for all operators:
Copy and run the codeblock content under the Export commands column to set the environment variables for a given operator:
Operator | Export commands |
---|---|
IBM Cloud Pak for Integration | export CASE_NAME=ibm-integration-platform-navigator && export CASE_VERSION=1.7.20 |
IBM Automation foundation assets | export CASE_NAME=ibm-integration-asset-repository && export CASE_VERSION=1.5.20 |
IBM Cloud Pak for Integration Operations Dashboard | export CASE_NAME=ibm-integration-operations-dashboard && export CASE_VERSION=2.6.26 |
IBM API Connect (1) | export CASE_NAME=ibm-apiconnect && export CASE_VERSION=4.0.9 |
IBM App Connect | export CASE_NAME=ibm-appconnect && export CASE_VERSION=5.0.21 |
IBM MQ | export CASE_NAME=ibm-mq && export CASE_VERSION=2.0.26 |
IBM Event Streams | export CASE_NAME=ibm-eventstreams && export CASE_VERSION=3.3.2 |
IBM DataPower Gateway (2) | export CASE_NAME=ibm-datapower-operator && export CASE_VERSION=1.6.16 |
IBM Aspera HSTS | export CASE_NAME=ibm-aspera-hsts-operator && export CASE_VERSION=1.5.13 |
IBM Cloud Pak foundational services | export CASE_NAME=ibm-cp-common-services && export CASE_VERSION=1.15.22 |
(1) The IBM API Connect CASE also mirrors the IBM DataPower Gateway CASE using the Cloud Pak for Integration image group.
(2) The IBM DataPower Gateway CASE contains multiple image groups. To mirror images for Cloud Pak for Integration, use the
ibmdpCp4i
image group.
3. Mirror the images
The process of mirroring images pulls the image from the internet and pushes it to your local registry. After mirroring your images, you can configure your cluster and complete the air-gapped installation.
Complete the following steps to mirror the images from your host to your air-gapped environment:
3.1. Generate mirror manifests
A mirror manifest is a YAML file that directs the ibm-pak
tool what images to mirror, and where to mirror them.
Define the environment variable $TARGET_REGISTRY by running the following command:
export TARGET_REGISTRY=<target-registry>
The
<target-registry>
refers to the registry (hostname and port) where your images are mirrored to and accessed by theoc
cluster. For example:172.16.0.10:5000
.If you want the images to use a specific namespace in the target registry, you can specify it here, for example:
registry.private/cp4i
.Generate mirror manifests by running the following command:
oc ibm-pak generate mirror-manifests $CASE_NAME --version $CASE_VERSION $TARGET_REGISTRY
If you need to filter for a specific image group add the parameter
--filter <image_group>
to this command.
This generates the following files at ~/.ibm-pak/data/mirror/$CASE_NAME/$CASE_VERSION
:
catalog-sources.yaml
catalog-sources-linux-<arch>.yaml (if there are arch specific catalog sources)
image-content-source-policy.yaml
images-mapping.txt
Repeat the process for each CASE you are mirroring.
3.2. Authenticate the entitled registry
You must authenticate to the entitled registry to mirror the required images.
Export the path to the file which stores the auth credentials that are generated from
podman login
ordocker login
. The authentication file is typically located at$HOME/.docker/config.json
on Linux or%USERPROFILE%/.docker/config.json
on Windows:export REGISTRY_AUTH_FILE=$HOME/.docker/config.json
Login to the
cp.icr.io
registry with podman or docker:podman login cp.icr.io
See Finding and applying your entitlement key (online installation) for how to obtain your entitlement key.
3.3. Authenticate the local registry
You must authenticate to the local registry to mirror the required images.
Login to the local registry with podman or docker:
podman login $TARGET_REGISTRY
Use an account that can write images to the local registry.
3.4. Mirror the images
Run the following command to copy the images to the local registry. Your device must be connected to both the internet and the restricted network environment that contains the local registry.
oc image mirror \
-f ~/.ibm-pak/data/mirror/$CASE_NAME/$CASE_VERSION/images-mapping.txt \
-a $REGISTRY_AUTH_FILE \
--filter-by-os '.*' \
--skip-multiple-scopes \
--max-per-registry=1
The oc image mirror
command starts by planning what images and layers need to be transferred. It can take a couple of minutes before you start seeing output.
If the local registry is not secured by TLS, or the certificate presented by the local registry is not trusted by your device, add the --insecure
option to the command.
Repeat the process for each CASE you are mirroring.
3.5. Configure the cluster
Log in to your Red Hat OpenShift Container Platform using the
oc
CLI.Update the global image pull secret for your Red Hat OpenShift cluster.
Follow the procedure in Updating the global cluster pull secret. These steps enable your cluster to have proper authentication credentials in place so that it can pull images from your
TARGET_REGISTRY
(as specified in theimage-content-source-policy.yaml
).Create the
ImageContentSourcePolicy
resource:oc apply -f ~/.ibm-pak/data/mirror/$CASE_NAME/$CASE_VERSION/image-content-source-policy.yaml
Verify that the
ImageContentSourcePolicy
resource is created:oc get imageContentSourcePolicy
Verify your cluster node status and wait for all nodes to be updated before proceeding:
oc get MachineConfigPool -w
Next steps
Now that you have mirrored images for the air-gapped environment, add the catalog sources. See Adding catalog sources to a cluster and follow the steps in the "Apply the catalog sources" section.