Running Stackable in an air-gapped environment
The main challenge with running Stackable in an air-gapped environment is how to get the artifacts (container images and Helm charts) into the environment. There are a few ways to do this:
- 
Mirror our images and Helm charts into a registry in the air-gapped environment. You need to find out what images are relevant for your specific Stackable deployment and transfer them to the target registry. Feel free to browse through the images in our registry. 
- 
If possible, setup a reverse proxy to Stackable’s registry on a node with internet connection that is reachable from all nodes within your air-gapped environment. You could, for example, use distribution for this. Here’s a command to spin up a pull-through cache to docker.stackable.techon port 5001:docker run -d --name proxy-stackable -p 5001:5000 --restart=always -e REGISTRY_PROXY_REMOTEURL=https://docker.stackable.tech registry:2. The registry is now available on localhost:5001 via HTTP. Once an image has been loaded, it will be cached by the proxy.
- 
Download our images (e.g. using docker save) on a machine with internet access, copy them onto the nodes in your air-gapped environment and load them (e.g. usingctr images import). Then render the Helm charts using thehelm templatesubcommand, copy the rendered YAML files your air-gapped environment and apply them.
In the first two scenarios, you need to make sure that the nodes load the images from your local registry mirror. Again, there are a several ways to do this:
- 
Specify the image repository in the CRDs (see "Custom docker registry") and in the values of the Helm charts when installing the operators ( helm install --set image.repository="my.custom.registry/stackable/nifi-operator" …).
- 
If you use containerdas your container runtime, you can patch thecontainerdconfig on every node to use the mirrored registry instead ofdocker.stackable.tech.
 Example: Let’s assume you have a registry mirror running on10.7.228.12, reachable via HTTPS on port 443 using a self signed certificate. Now copy the certificate over to your Kubernetes node, in this example we’ll place it in the/etc/pki/tls/certsfolder. Create the file/etc/containerd/certs.d/docker.stackable.tech/hosts.tomlon the node, with the following contents:[host."10.7.228.12"] ca = "/etc/pki/tls/certs/mycert.crt" capabilities = ["pull", "resolve"]Since containerddefaults to using HTTPS on port 443, we don’t have to specify the protocol and port and can just provide the IP. Note that the certificate (mycert.crt) has to contain the IP (10.7.228.12) as SAN.
 Modify your containerd config (usually located at/etc/containerd/config.toml):[plugins."io.containerd.grpc.v1.cri".registry] config_path = "/etc/containerd/certs.d"Then restart the containerdservice. Nowcontainerdwill fetch all images that would normally be fetched fromdocker.stackable.techfrom10.7.228.12instead. The registry host name is determined by the pathhosts.tomlis located in, so other registry hosts are not affected. For further information, see "Registry configuration".
- 
Add an alias for docker.stackable.techto the/etc/hostsfile on every node (like10.7.228.12 docker.stackable.tech), issue a self-signed certificate fordocker.stackable.techto your registry and add the certificate to the trusted certificates on every node. Note that if you also want to enforce signature checks for Stackable’s images via a policy controller, you will need to add this host alias to the Pod of the policy controller as well (and make it trust the certificate).
If you want to know how to verify image signatures in an air-gapped environment, check out our documentation about image signature verification.