Air-Gapped Upgrade with KubeKey

    • You need to have a KubeSphere cluster running v3.1.x. If your KubeSphere version is v3.0.0 or earlier, upgrade to v3.1.x first.
    • Your Kubernetes version must be v1.19.x or later.
    • Read Release Notes for 3.2.0 carefully.
    • Back up any important component beforehand.
    • A Docker registry. You need to have a Harbor or other Docker registries. For more information, see .
    • Make sure every node can push and pull images from the Docker Registry.

    Upgrade KubeSphere and Kubernetes

    Upgrading steps are different for single-node clusters (all-in-one) and multi-node clusters.

    Info

    KubeKey upgrades Kubernetes from one MINOR version to the next MINOR version until the target version. For example, you may see the upgrading process going from 1.16 to 1.17 and to 1.18, instead of directly jumping to 1.18 from 1.16.

    Note

    uses as the default directory where all Docker related files, including images, are stored. It is recommended you add additional storage volumes with at least 100G mounted to /var/lib/docker and /mnt/registry respectively. See fdisk command for reference.

    Step 1: Download KubeKey

    Similar to installing KubeSphere on Linux in an online environment, you need to download KubeKey v1.2.0 first. Download the tar.gz file, and transfer it to your local machine which serves as the taskbox for installation. After you uncompress the file, execute the following command to make kk executable:

    As you install KubeSphere and Kubernetes on Linux, you need to prepare an image package containing all the necessary images and download the Kubernetes binary file in advance.

    1. Download the image list file images-list.txt from a machine that has access to Internet through the following command:

      1. curl -L -O https://github.com/kubesphere/ks-installer/releases/download/v3.2.0/images-list.txt

      Note

      This file lists images under ##+modulename based on different modules. You can add your own images to this file following the same rule. To view the complete file, see .

    2. Download offline-installation-tool.sh.

      1. curl -L -O https://github.com/kubesphere/ks-installer/releases/download/v3.2.0/offline-installation-tool.sh
    3. You can execute the command ./offline-installation-tool.sh -h to see how to use the script:

      1. [email protected]:/home/ubuntu# ./offline-installation-tool.sh -h
      2. Usage:
      3. ./offline-installation-tool.sh [-l IMAGES-LIST] [-d IMAGES-DIR] [-r PRIVATE-REGISTRY] [-v KUBERNETES-VERSION ]
      4. Description:
      5. -b : save kubernetes' binaries.
      6. -d IMAGES-DIR : the dir of files (tar.gz) which generated by `docker save`. default: /home/ubuntu/kubesphere-images
      7. -l IMAGES-LIST : text file with list of images.
      8. -r PRIVATE-REGISTRY : target private registry:port.
      9. -s : save model will be applied. Pull the images in the IMAGES-LIST and save images as a tar.gz file.
      10. -v KUBERNETES-VERSION : download kubernetes' binaries. default: v1.17.9
      11. -h : usage message
    4. Download the Kubernetes binary file.

      1. ./offline-installation-tool.sh -b -v v1.21.5

      If you cannot access the object storage service of Google, run the following command instead to add the environment variable to change the source.

      • You can change the Kubernetes version downloaded based on your needs. Recommended Kubernetes versions for KubeSphere 3.2.0 are v1.19.x, v1.20.x, v1.21.x, and v1.22.x (experimental). If you do not specify a Kubernetes version, KubeKey will install Kubernetes v1.21.5 by default. For more information about supported Kubernetes versions, see Support Matrix.

      • You can upgrade Kubernetes from v1.16.13 to v1.17.9 by downloading the v1.17.9 Kubernetes binary file, but for cross-version upgrades, all intermediate versions need to be downloaded in advance. For example, if you want to upgrade Kubernetes from v1.15.12 to v1.18.6, you need to download Kubernetes v1.16.13 and v1.17.9, and the v1.18.6 binary file.

      • After you run the script, a folder is automatically created. Note that this file and kk must be placed in the same directory when you create the cluster later.

    5. Pull images in offline-installation-tool.sh.

      1. ./offline-installation-tool.sh -s -l images-list.txt -d ./kubesphere-images

      Note

      You can choose to pull images as needed. For example, you can delete ##k8s-images and related images under it in images-list.text if you already have a Kubernetes cluster.

    Step 3: Push images to your private registry

    Transfer your packaged image file to your local machine and execute the following command to push it to the registry.

    1. ./offline-installation-tool.sh -l images-list.txt -d ./kubesphere-images -r dockerhub.kubekey.local

    Note

    The domain name is dockerhub.kubekey.local in the command. Make sure you use your own registry address.

    Example machines

    Versions

    Upgrade a cluster

    In this example, KubeSphere is installed on a single node, and you need to specify a configuration file to add host information. Besides, for air-gapped installation, pay special attention to .spec.registry.privateRegistry, which must be set to your own registry address. For more information, see the following sections.

    Create an example configuration file

    Execute the following command to generate an example configuration file for installation:

    1. ./kk create config [--with-kubernetes version] [--with-kubesphere version] [(-f | --file) path]

    For example:

    1. ./kk create config --with-kubernetes v1.21.5 --with-kubesphere v3.2.0 -f config-sample.yaml

    Note

    Make sure the Kubernetes version is the one you downloaded.

    Edit the configuration file

    Edit the configuration file config-sample.yaml. Here is .

    For air-gapped installation, you must specify privateRegistry, which is dockerhub.kubekey.local in this example.

    Set hosts of your config-sample.yaml file:

    1. hosts:
    2. - {name: ks.master, address: 192.168.1.1, internalAddress: 192.168.1.1, user: root, password: [email protected]}
    3. roleGroups:
    4. etcd:
    5. - ks.master
    6. - ks.master
    7. worker:
    8. - ks.master

    Set privateRegistry of your config-sample.yaml file:

    Upgrade your single-node cluster to KubeSphere 3.2.0 and Kubernetes v1.21.5

    To upgrade Kubernetes to a specific version, explicitly provide the version after the flag --with-kubernetes. Available versions are:

    • v1.19.x
    • v1.20.x
    • v.21.x
    • v1.22.x (experimental)

    Air-gapped upgrade for multi-node clusters

    Example machines

    Versions

    Upgrade a cluster

    In this example, KubeSphere is installed on multiple nodes, so you need to specify a configuration file to add host information. Besides, for air-gapped installation, pay special attention to .spec.registry.privateRegistry, which must be set to your own registry address. For more information, see the following sections.

    Create an example configuration file

    Execute the following command to generate an example configuration file for installation:

    1. ./kk create config [--with-kubernetes version] [--with-kubesphere version] [(-f | --file) path]

    For example:

    1. ./kk create config --with-kubernetes v1.21.5 --with-kubesphere v3.2.0 -f config-sample.yaml

    Note

    Make sure the Kubernetes version is the one you downloaded.

    Edit the configuration file

    Edit the configuration file config-sample.yaml. Here is .

    Warning

    For air-gapped installation, you must specify privateRegistry, which is dockerhub.kubekey.local in this example.

    Set hosts of your config-sample.yaml file:

    1. hosts:
    2. - {name: ks.master, address: 192.168.1.1, internalAddress: 192.168.1.1, user: root, password: [email protected]}
    3. - {name: ks.slave1, address: 192.168.1.2, internalAddress: 192.168.1.2, user: root, privateKeyPath: "/root/.ssh/kp-qingcloud"}
    4. - {name: ks.slave2, address: 192.168.1.3, internalAddress: 192.168.1.3, user: root, privateKeyPath: "/root/.ssh/kp-qingcloud"}
    5. roleGroups:
    6. etcd:
    7. - ks.master
    8. master:
    9. - ks.master
    10. worker:
    11. - ks.slave1
    12. - ks.slave2

    Set privateRegistry of your config-sample.yaml file:

    1. registry:
    2. registryMirrors: []
    3. insecureRegistries: []

    Upgrade your multi-node cluster to KubeSphere 3.2.0 and Kubernetes v1.21.5

    To upgrade Kubernetes to a specific version, explicitly provide the version after the flag --with-kubernetes. Available versions are:

    • v1.19.x
    • v1.20.x
    • v1.21.x
    • v1.22.x (experimental)