Upgrading Instana backend on Kubernetes/OpenShift

To upgrade the operator-based Instana setup, follow these steps:

Prerequisites

Make sure that the following prerequisites are met before you upgrade Instana:

  • The cluster has adequate capacity. If the cluster is nearing its request capacity, add an extra node to avoid the pods stuck in Pending status.
  • The data store versions are compatible with the Instana version that you want to upgrade to. For data store versions, see Installing third-party data store operators.

Upgrade procedure

The Instana kubectl plug-in and the Instana Enterprise operator are always released together. The Instana backend updates are independent of the Instana Enterprise operator releases.

You can use the Instana kubectl plug-in to check the supported Instana backend versions and update the backend as required. After up to 4 Instana backend releases, a new version of the Instana Enterprise operator is released.

Upgrading the operator

When a new version of the Instana Enterprise operator is released, you can upgrade the operator by using the following steps:

  1. Install the target version of the Instana kubectl plug-in. For more information, see Installing the Instana kubectl plug-in.

  2. Upgrade the operator by using either of the following methods, where the new operator is applied with a default Instana backend version:

    Notes:

    • Make sure that you apply or generate new YAML manifests. Don't update the image version in the existing YAML manifests directly. If you update the image version in the existing YAML manifests, then you might miss the CustomResourceDefinition (CRD) updates or other changes that can lead to unpredictable errors.

    • To upgrade to a specific version, you might require to do some extra actions. Refer to the Upgrade notes section. When you skip a release, make sure that you consider the upgrade notes (including upgrade notes for the skipped version and the target version).

Upgrading the backend

Build 1.0.0 (279) onwards, you can upgrade the Instana backend when new versions are released.

  1. Check whether a new backend version is available by using the following command:

    kubectl instana --versions
    

    The command lists all the available backend versions that are compatible with your Instana Enterprise operator version.

    If your operator is on the latest release, you do not need to upgrade the backend.

  2. To upgrade to a higher Instana backend version, you can use the following subcommands of the versions command. All commands have an optional --download-key flag. If you do not specify the flag, the download key of the existing installation is used.

    • The identify subcommand provides a list of currently available Instana backend versions that are compatible with the installed Custom Edition (Kubernetes or OpenShift Container Platform).
    • The list-images subcommand prints a list of images of the Instana Kubernetes operator and all Instana components. You can use the --instana-version flag to specify the operator version. If you do not use the flag, all available operator versions are listed, and you can then select a version.
    • The update command upgrades an existing installation to a new version. You can specify the upgrade version by using the --instana-version flag. Otherwise, all supported upgrade versions are displayed. You can then select a version. Alternatively, you can configure the backend version that you want to upgrade to in the core spec and apply the spec. See the following sample code.
      ...
      spec:
        imageConfig:
          tag: 3.xxx.xxx-0
      ...
      
  3. Verify the Instana backend upgrade by completing the following steps:

    • Check whether the Instana kubectl plug-in version is updated by running the following command:
      kubectl instana --version
      
    • Check whether the Instana backend version is updated by running the following commands:
      kubectl get core -n instana-core
      
      kubectl get units -n instana-units
      

Upgrade notes

See the following notes for release-specific requirements.

Upgrading to release 1.0.0 (279)

The general upgrade notes and the versions schema are changed. But, for the Instana backend updates for Build 1.0.0 (279), no special steps are needed.

Upgrading to release 277

If you are upgrading from release 273 or earlier, follow the steps in Upgrading to release 275. No special steps are needed to upgrade from release 275 onwards.

Upgrading to release 275

Starting from Instana release 275, a new table is introduced to the ClickHouse logs database that uses the ClickHouse TTL mechanism to automatically move data to cold storage over time and then expire it as needed.

The ClickHouse data store configuration needs to be updated for release-275 migrations to be applied.

Proceed with the following steps:

  1. Set your Instana backend into maintenance mode by updating the Core spec:
kubectl patch core <core_name> -n <core_namespace> --type='merge' -p='{"spec": {"operationMode": "maintenance"}}'
  1. Add the following configurations to your ClickHouseInstallation resource:

    • Define a new cold_disk in <disks>, create a new policy called logs_policy_v4 and reference the cold_disk in the new policy:

      config.d/storage.xml: |
         <clickhouse>
           <storage_configuration>
             <disks>
               <default/>
               <cold_disk>
                 <path>/var/lib/clickhouse-cold/</path>
               </cold_disk>
             </disks>
             <policies>
               <logs_policy>
                 <volumes>
                   <data>
                     <disk>default</disk>
                   </data>
                   <cold>
                     <disk>cold_disk</disk>
                   </cold>
                 </volumes>
               </logs_policy>
               <logs_policy_v4>
                 <volumes>
                   <tier1>
                     <disk>default</disk>
                   </tier1>
                   <tier2>
                     <disk>cold_disk</disk>
                   </tier2>
                 </volumes>
               </logs_policy_v4>
             </policies>
           </storage_configuration>
        </clickhouse>
      
    • Define a new volumeClaimTemplate that ClickHouse can use to create an additional PVC for the cold_disk:

      volumeClaimTemplates:
        ...
        ...
        - name: instana-clickhouse-data-cold-volume
          spec:
            accessModes:
               - ReadWriteOnce
            resources:
               requests:
               storage: 100Gi
            # storageClassName: <lower_or_cheaper_tier_storageclassname>
      
    • Finally, mount the new volume in the ClickHouse Pod by defining volumeMounts in the podTemplates:

      containers:
        - name: instana-clickhouse
          ...
          ...
          volumeMounts:
            - mountPath: /var/lib/clickhouse-cold/
              name: instana-clickhouse-data-cold-volume
      

      For the full ClickHouseInstallation resource YAML, see:

    • Before you proceed with the upgrade to release-275, make sure ClickHouse shows a status of Completed after you apply the new changes. Use the following command:

      % kubectl get clickhouseinstallation -n instana-clickhouse
      
      NAME      CLUSTERS   HOSTS   STATUS      AGE
      instana   1          2       Completed   4d1h
      
  2. Set your Instana backend back to normal mode by updating the Core spec:

kubectl patch core <core_name> -n <core_namespace> --type='merge' -p='{"spec": {"operationMode": "normal"}}'
  1. Upgrade to Instana 275 by following the Upgrade procedure.

Upgrading to release 273

The upgrade does not require any special steps.