labels: rtf.mulesoft.com/synchronized: "true"
Using a Local Registry with Runtime Fabric on Self-Managed Kubernetes
Runtime Fabric uses its own registry to store the necessary Docker images for installing and managing Runtime Fabric and for running applications in Kubernetes. If your security policies require that you pull your Docker images from a registry under your control, you can set up a local registry to pull and store these Docker images.
Limitations on Local Registry Support
Review the following limitations on support for local registries:
-
Runtime Fabric supports local registries on Self-Managed Kubernetes only.
-
You must use Runtime Fabric command line utility (
rtfctl
) version 0.3.150 or later. -
You can use a local registry only if you create a new Runtime Fabric instance of version 1.12.0 or later.
If you set up a local registry, you can upgrade to a version later than 1.12.0 without reinstalling Runtime Fabric.
You cannot add a local registry to any version of an existing Runtime Fabric instance, even if you upgrade that installation to 1.12.0 or later.
-
If you create a Runtime Fabric instance to use with a local registry, you cannot later reconfigure it to use the
rtf-runtime-registry
endpoint. To use thertf-runtime-registry
endpoint, you must install a new Runtime Fabric instance using the standard installation procedure. -
You’re responsible for synchronization between your registry and the Runtime Fabric registry. MuleSoft doesn’t provide additional software to synchronize images between the registries. Push all the dependency images for your version to your local registry before you start the installation. See the Runtime Fabric release notes for the required dependencies for your Runtime Fabric version.
-
If you use a local registry that needs authentication, synchronization and propagation of a pull secret between different namespaces is your responsibility. Alternatively, Runtime Fabric can synchronize your pull secret across different namespaces if your secret uses the following label:
-
If you need to authenticate access to your local registry, ensure that the corresponding credentials are configured as a Kubernetes secret in the
rtf
namespace. You’ll need the name of the configured secret when you install Runtime Fabric. -
You also need to synchronize in your registry the Mule runtime versions you intend to use for application deployments. Refer to the Runtime Fabric Patch Update Release Notes for information about the latest Mule runtime patch versions. The location of the image will follow this format: rtf-runtime-registry.kqa.msap.io/mulesoft/poseidon-runtime-4.4.0:<tag>
Configure a Local Registry for Use with Runtime Fabric
To configure a local registry, you must gather and add the necessary credentials to synchronize the registries.
Before You Begin
Ensure that you’ve performed the following tasks:
-
Set up, configure, and test your private Docker image registry.
-
Synchronize to your local registry all the Docker images you need to install Runtime Fabric:
See the Runtime Fabric release notes for the required dependencies for your Runtime Fabric version.
Dependency versions are specific to the Runtime Fabric version. -
Download and install the
rtfctl
command line utility version 0.3.150 or higher. -
Create a Runtime Fabric using Runtime Manager, and gather the activation data.
Configure Your Local Registry and Install Runtime Fabric
-
Obtain
rtf-runtime-registry
credentials:# rtfctl get registry-credentials <activation-data>
This command sets
RTF_IMAGE_REGISTRY_ENDPOINT
,RTF_IMAGE_REGISTRY_USER
, andRTF_IMAGE_REGISTRY_PASSWORD
in the current shell environment. -
Run the following commands to verify that the Docker login to the
rtf-runtime-registry
succeeds:# eval $(rtfctl get docker-registry-login <activation-data>) # docker login $RTF_IMAGE_REGISTRY_ENDPOINT --username $RTF_IMAGE_REGISTRY_USER --password $RTF_IMAGE_REGISTRY_PASSWORD
You should see a message that the login was successful.
-
To pull and synchronize images, log in into your own private container registry and run the following command, replacing
<docker-server>
where appropriate:For the US control plane:
# docker pull rtf-runtime-registry.kprod.msap.io/mulesoft/rtf-agent:v1.12.0 # docker tag rtf-runtime-registry.kprod.msap.io/mulesoft/rtf-agent:v1.12.0 <docker-server>/mulesoft/rtf-agent:v1.12.0 # docker push <docker-server>/mulesoft/rtf-agent:v1.12.0
For the EU control plane:
# docker pull rtf-runtime-registry.kprod-eu.msap.io/mulesoft/rtf-agent:v1.12.0 # docker tag rtf-runtime-registry.kprod-eu.msap.io/mulesoft/rtf-agent:v1.12.0 <docker-server>/mulesoft/rtf-agent:v1.12.0 # docker push <docker-server>:5000/mulesoft/rtf-agent:v1.12.0
-
Repeat step 3 for all the other dependency images (resourceFetcher, clusterOps etc.) based on the versions published in the Runtime Fabric release notes.
-
If you use authentication to access your registry, create the required secret in the rtf namespace:
# kubectl create namespace rtf # kubectl create secret docker-registry regcred --namespace=rtf --docker-server=<docker_server> --docker-username=<docker_username> --docker-email=<docker_email> --docker-password=<docker_password> # kubectl label secret regcred rtf.mulesoft.com/synchronized=true -n rtf
-
Finalize the Runtime Fabric installation, and configure it to pull from your local registry:
# rtfctl install ‘<activation_data>’ --image-pull-registry <docker-server>
Alternatively, if you use authentication to access your registry, use the following command:
# rtfctl install ‘<activation_data>’ --image-pull-registry <docker-server> --image-pull-secret <your-local-reg-secret>
This command ensures that Runtime Fabric creates the necessary overrides for the local registry URL and
image-pull-secret
values so Runtime Fabric continues to pull images from the local registry even after an upgrade. -
If you use authentication to access your registry, after you complete the installation, you must recreate the pull secret in the RTF namespace and in any other namespaces where you will deploy applications.
-
Refer to the installation instructions for further steps, such as inserting the Mule license key.
The rtfctl uninstall
command deletes any pull secret you specify during installation.
When using rtfctl
to perform a backup and restore procedure, the backups point to your local registry URL and pull secret.