Air-Gap Install
RKE2 can be installed in an air-gapped environment with two different methods. You can either deploy images via the rke2-airgap-images tarball release artifact or by using a private registry. It is also possible to use the embedded registry mirror as long as there is at least one cluster member that has access to the required images.
Prerequisites
If your node has NetworkManager installed and enabled, ensure that it is configured to ignore CNI-managed interfaces.
All files mentioned in the steps can be obtained from the assets of the desired released rke2 version here.
If running on an air-gapped node with SELinux enabled, you must manually install the necessary SELinux policy RPM before performing these steps. See our RPM Documentation to determine what you need.
If running on an air-gapped node with SELinux enabled, the following are required dependencies for SLES, CentOS, or RHEL 8 when doing an RPM install:
Installing dependencies: container-selinux iptables libnetfilter_conntrack libnfnetlink libnftnl policycoreutils-python-utils rke2-common rke2-selinux
All the steps listed on this document must be run as the root user or through sudo
.
If your nodes do not have an interface with a default route, a default route must be configured; even a black-hole route via a dummy interface will suffice. RKE2 requires a default route in order to auto-detect the node's primary IP, and for kube-proxy ClusterIP routing to function properly. To add a dummy route, do the following:
ip link add dummy0 type dummy
ip link set dummy0 up
ip addr add 203.0.113.254/31 dev dummy0
ip route add default via 203.0.113.255 dev dummy0 metric 1000
Tarball Method
- Download the airgap images tarballs from the RKE release artifacts list for the version and platform of RKE2 you are using.
- Use
rke2-images.linux-amd64.tar.zst
orrke2-images.linux-amd64.tar.gz
. Zstandard offers better compression ratios and faster decompression speeds compared to gzip. - If using the default Canal CNI (
--cni=canal
), you can use either therke2-image
legacy archive as described above, orrke2-images-core
andrke2-images-canal
archives. - If using the alternative Cilium CNI (
--cni=cilium
), you must download therke2-images-core
andrke2-images-cilium
archives instead. - If using your own CNI (
--cni=none
), you can download only therke2-images-core
archive. - If enabling the vSphere CPI/CSI charts (
--cloud-provider-name=rancher-vsphere
), you must also download therke2-images-vsphere
archive.
- Use
- Ensure that the
/var/lib/rancher/rke2/agent/images/
directory exists on the node. - Copy the compressed archive to
/var/lib/rancher/rke2/agent/images/
on the node, ensuring that the file extension is retained. - Install RKE2
Private Registry Method
Private registry support honors all settings from the containerd registry configuration. This includes endpoint override and transport protocol (HTTP/HTTPS), authentication, certificate verification, etc.
- Add all the required system images to your private registry. A list of images can be obtained from the
.txt
file corresponding to each tarball referenced above, or you maydocker load
the airgap image tarballs, then tag and push the loaded images. - Install RKE2 using the
system-default-registry
parameter, or use the containerd registry configuration to use your registry as a mirror for docker.io.
Embedded Registry Mirror
RKE2 includes an embedded distributed OCI-compliant registry mirror. When enabled and properly configured, images available in the containerd image store on any node can be pulled by other cluster members without access to an external image registry.
The mirrored images may be sourced from an upstream registry, registry mirror, or airgap image tarball. For more information on enabling the embedded distributed registry mirror, see the Embedded Registry Mirror documentation.
Install RKE2
The following options to install RKE2 should only be performed after completing one of either the Tarball Method or Private Registry Method.
RKE2 can be installed either by running the binary directly or by using the install.sh script.
RKE2 Binary Install
- Obtain the rke2 binary file
rke2.linux-amd64
. - Ensure the binary is named
rke2
and place it in/usr/local/bin
. Ensure it is executable. - Run the binary with the desired parameters. For example, if using the Private Registry Method, your config file would have the following:
system-default-registry: "registry.example.com:5000"
Note: The system-default-registry
parameter must specify only valid RFC 3986 URI authorities, i.e. a host and optional port.
RKE2 Install.sh Script Install
install.sh
may be used in an offline mode by setting the INSTALL_RKE2_ARTIFACT_PATH
variable to a path containing pre-downloaded artifacts. This will run though a normal install, including creating systemd units.
- Download the install script, rke2, rke2-images, and sha256sum archives from the release into a directory, as in the example below:
mkdir /root/rke2-artifacts && cd /root/rke2-artifacts/
curl -OLs https://github.com/rancher/rke2/releases/download/v1.26.10%2Brke2r2/rke2-images.linux-amd64.tar.zst
curl -OLs https://github.com/rancher/rke2/releases/download/v1.26.10%2Brke2r2/rke2.linux-amd64.tar.gz
curl -OLs https://github.com/rancher/rke2/releases/download/v1.26.10%2Brke2r2/sha256sum-amd64.txt
curl -sfL https://get.rke2.io --output install.sh
- Next, run install.sh using the directory, as in the example below:
INSTALL_RKE2_ARTIFACT_PATH=/root/rke2-artifacts sh install.sh
- Enable and run the service as outlined here.
Upgrading
Manual Upgrade Method
Upgrading an air-gap environment can be accomplished in the following manner:
- Download the new air-gap images (tar files) from the releases page for the version of RKE2 you will be upgrading to. Place the tar in the
/var/lib/rancher/rke2/agent/images/
directory on each node. Delete the old tar files. - Follow the steps of the manual upgrade method
Automated Upgrades Method
RKE2 supports automated upgrades. To enable this in air-gapped environments, you must ensure the required images are available in your private registry.
You will need the version of rancher/rke2-upgrade that corresponds to the version of RKE2 you intend to upgrade to. Note, the image tag replaces the +
in the RKE2 release with a -
because Docker images do not support +
.
You will also need the versions of system-upgrade-controller and kubectl that are specified in the system-upgrade-controller manifest YAML that you will deploy. Check for the latest release of the system-upgrade-controller here and download the system-upgrade-controller.yaml to determine the versions you need to push to your private registry. For example, in release v0.4.0 of the system-upgrade-controller, these images are specified in the manifest YAML:
rancher/system-upgrade-controller:v0.4.0
rancher/kubectl:v0.17.0
Once you have added the necessary rancher/rke2-upgrade, rancher/system-upgrade-controller, and rancher/kubectl images to your private registry, follow the automated upgrades guide.