Creating a Cassandra data store on Linux x86_64

You can install the Cassandra operator and set up the data store.

Before you begin

Make sure that you prepared your online and offline host to pull images from the external repository. Also, ensure that the correct Helm repo is added.

For more information, see Preparing for data store installation.

Cassandra operator versions and image tags for deployment

The following images are needed for the pinned Helm chart or operator versions.

Table 1. Cassandra operator versions and image tags
Platform Operator versions Helm chart version Image with tag
Linux® x86_64 1.18.2 0.45.2 artifact-public.instana.io/self-hosted-images/3rd-party/operator/cass-operator:1.18.2_v0.12.0

artifact-public.instana.io/self-hosted-images/3rd-party/datastore/system-logger:1.18.2_v0.3.0

artifact-public.instana.io/self-hosted-images/3rd-party/datastore/k8ssandra-client:0.2.2_v0.3.0

artifact-public.instana.io/self-hosted-images/3rd-party/datastore/cassandra:4.1.4_v0.17.0

Installing Cassandra online

To install the Cassandra operator in an online environment, complete the steps for your platform.

Create Security Context Constraints

If you are using a Red Hat® OpenShift® cluster, create Security Context Constraints (SCC) before you deploy the Cassandra Operator.

To create SCC, complete the following steps:

  1. Create a file, such as cassandra-scc.yaml, as follows:

    apiVersion: security.openshift.io/v1
    kind: SecurityContextConstraints
    metadata:
      name: cassandra-scc
    runAsUser:
      type: MustRunAs
      uid: 999
    seLinuxContext:
      type: RunAsAny
    fsGroup:
      type: RunAsAny
    allowHostDirVolumePlugin: false
    allowHostNetwork: true
    allowHostPorts: true
    allowPrivilegedContainer: false
    allowHostIPC: true
    allowHostPID: true
    readOnlyRootFilesystem: false
    users:
      - system:serviceaccount:instana-cassandra:cass-operator
      - system:serviceaccount:instana-cassandra:default
    
  2. Apply the file by running the following command:

    kubectl apply -f cassandra-scc.yaml
    

Install Cassandra data store

Complete these steps to install the Cassandra data store.

  1. Create the instana-cassandra namespace.

    kubectl create namespace instana-cassandra
    
  2. Create image pull secrets. Update the <download_key> value with your own download key.

    kubectl create secret docker-registry instana-registry --namespace instana-cassandra \
    --docker-username=_ \
    --docker-password=<download_key> \
    --docker-server=artifact-public.instana.io
    
  3. Install the Cassandra operator.

    helm install cass-operator instana/cass-operator -n instana-cassandra --version=0.45.2 --set securityContext.runAsGroup=999 --set securityContext.runAsUser=999 --set image.registry=artifact-public.instana.io --set image.repository=self-hosted-images/3rd-party/operator/cass-operator --set image.tag=1.18.2_v0.12.0 --set imagePullSecrets[0].name=instana-registry --set appVersion=1.18.2 --set imageConfig.systemLogger=artifact-public.instana.io/self-hosted-images/3rd-party/datastore/system-logger:1.18.2_v0.3.0 --set imageConfig.k8ssandraClient=artifact-public.instana.io/self-hosted-images/3rd-party/datastore/k8ssandra-client:0.2.2_v0.3.0
    
  4. Create a YAML file, for example cassandra.yaml, with the Cassandra configuration.

    apiVersion: cassandra.datastax.com/v1beta1
    kind: CassandraDatacenter
    metadata:
      name: cassandra
    spec:
      clusterName: instana
      serverType: cassandra
      serverImage: artifact-public.instana.io/self-hosted-images/3rd-party/datastore/cassandra:4.1.4_v0.17.0
      systemLoggerImage: artifact-public.instana.io/self-hosted-images/3rd-party/datastore/system-logger:1.18.2_v0.3.0
      k8ssandraClientImage: artifact-public.instana.io/self-hosted-images/3rd-party/datastore/k8ssandra-client:0.2.2_v0.3.0
      serverVersion: "4.1.4"
      imagePullPolicy: Always
      podTemplateSpec:
        spec:
          imagePullSecrets:
          - name: instana-registry
          containers:
          - name: cassandra
      managementApiAuth:
        insecure: {}
      size: 3
      allowMultipleNodesPerWorker: false
      resources:
        requests:
          cpu: 2000m
          memory: 8Gi
        limits:
          cpu: 4000m
          memory: 16Gi
      storageConfig:
        cassandraDataVolumeClaimSpec:
          accessModes:
            - ReadWriteOnce
          resources:
            requests:
              storage: 100Gi
      config:
        jvm-server-options:
          initial_heap_size: "4G"
          max_heap_size: "8G"
          additional-jvm-opts:
            - -Dcassandra.allow_unsafe_aggressive_sstable_expiration=true
        cassandra-yaml:
          authenticator: org.apache.cassandra.auth.PasswordAuthenticator
          authorizer: org.apache.cassandra.auth.CassandraAuthorizer
          role_manager: org.apache.cassandra.auth.CassandraRoleManager
          memtable_flush_writers: 8
          auto_snapshot: false
          gc_warn_threshold_in_ms: 10000
          otc_coalescing_strategy: DISABLED
          memtable_allocation_type: offheap_objects
          num_tokens: 256
          drop_compact_storage_enabled: true
    
  5. Complete the steps in Deploying and verifying Cassandra (online and offline).

Installing Cassandra offline

To install the Cassandra operator in an offline environment, complete the following steps:

If you didn't yet pull the Cassandra images from the external registry when you prepared for installation, you can pull them now. Run the following commands on your bastion host. Then, copy the images to your Instana host that is in your air-gapped environment.

docker pull artifact-public.instana.io/self-hosted-images/3rd-party/operator/cass-operator:1.18.2_v0.12.0
docker pull artifact-public.instana.io/self-hosted-images/3rd-party/datastore/system-logger:1.18.2_v0.3.0
docker pull artifact-public.instana.io/self-hosted-images/3rd-party/datastore/k8ssandra-client:0.2.2_v0.3.0
docker pull artifact-public.instana.io/self-hosted-images/3rd-party/datastore/cassandra:4.1.4_v0.17.0

Complete the following steps on your Instana host.

  1. Retag the images to your internal image registry.

    docker tag artifact-public.instana.io/self-hosted-images/3rd-party/operator/cass-operator:1.18.2_v0.12.0 <internal-image-registry>/operator/cass-operator:1.18.2_v0.12.0
    docker tag artifact-public.instana.io/self-hosted-images/3rd-party/datastore/system-logger:1.18.2_v0.3.0 <internal-image-registry>/datastore/system-logger:1.18.2_v0.3.0
    docker tag artifact-public.instana.io/self-hosted-images/3rd-party/datastore/k8ssandra-client:0.2.2_v0.3.0 <internal-image-registry>/datastore/k8ssandra-client:0.2.2_v0.3.0
    docker tag artifact-public.instana.io/self-hosted-images/3rd-party/datastore/cassandra:4.1.4_v0.17.0 <internal-image-registry>/datastore/cassandra:4.1.4_v0.17.0
    
  2. Push the images to your internal image registry on your bastion host.

    docker push <internal-image-registry>/operator/cass-operator:1.18.2_v0.12.0
    docker push <internal-image-registry>/datastore/system-logger:1.18.2_v0.3.0
    docker push <internal-image-registry>/datastore/k8ssandra-client:0.2.2_v0.3.0
    docker push <internal-image-registry>/datastore/cassandra:4.1.4_v0.17.0
    
  3. Create the instana-cassandra namespace.

    kubectl create namespace instana-cassandra
    
  4. Optional: Create an image pull secret if your internal image registry needs authentication.

    kubectl create secret docker-registry <secret_name> --namespace instana-cassandra \
    --docker-username=<registry_username> \
    --docker-password=<registry_password> \
    --docker-server=<internal-image-registry>:<internal-image-registry-port>
    --docker-email=<registry_email>
    
  5. Install the Cassandra operator.

    helm install cass-operator cass-operator-0.45.2.tgz -n instana-cassandra --version=0.45.2 --set securityContext.runAsGroup=999 --set securityContext.runAsUser=999 --set image.registry=<internal-image-registry> --set image.repository=operator/cass-operator --set image.tag=1.18.2_v0.12.0 --set appVersion=1.18.2 --set imageConfig.systemLogger=<internal-image-registry>/datastore/system-logger:1.18.2_v0.3.0 --set imageConfig.k8ssandraClient=<internal-image-registry>/datastore/k8ssandra-client:0.2.2_v0.3.0
    
  6. Create a YAML file, for example cassandra.yaml, with the Cassandra configuration.

    apiVersion: cassandra.datastax.com/v1beta1
    kind: CassandraDatacenter
    metadata:
      name: cassandra
    spec:
      clusterName: instana
      serverType: cassandra
      serverImage: <internal-image-registry>/datastore/cassandra:4.1.4_v0.17.0
      systemLoggerImage: <internal-image-registry>/datastore/system-logger:1.18.2_v0.3.0
      k8ssandraClientImage: <internal-image-registry>/datastore/k8ssandra-client:0.2.2_v0.3.0
      serverVersion: "4.1.4"
      imagePullPolicy: Always
      podTemplateSpec:
        spec:
          imagePullSecrets:
          - name: instana-registry
          containers:
          - name: cassandra
      managementApiAuth:
        insecure: {}
      size: 3
      allowMultipleNodesPerWorker: false
      resources:
        requests:
          cpu: 2000m
          memory: 8Gi
        limits:
          cpu: 4000m
          memory: 16Gi
      storageConfig:
        cassandraDataVolumeClaimSpec:
          accessModes:
            - ReadWriteOnce
          resources:
            requests:
              storage: 100Gi
      config:
        jvm-server-options:
          initial_heap_size: "4G"
          max_heap_size: "8G"
          additional-jvm-opts:
            - -Dcassandra.allow_unsafe_aggressive_sstable_expiration=true
        cassandra-yaml:
          authenticator: org.apache.cassandra.auth.PasswordAuthenticator
          authorizer: org.apache.cassandra.auth.CassandraAuthorizer
          role_manager: org.apache.cassandra.auth.CassandraRoleManager
          memtable_flush_writers: 8
          auto_snapshot: false
          gc_warn_threshold_in_ms: 10000
          otc_coalescing_strategy: DISABLED
          memtable_allocation_type: offheap_objects
          num_tokens: 256
          drop_compact_storage_enabled: true
    
  7. Complete the steps in Deploying and verifying Cassandra (online and offline).

Deploying and verifying Cassandra (online and offline)

When you deploy Cassandra, the CassandraDatacenter by default creates a superuser, for example <clustername>-superuser. The <clustername> is the value that is specified in .spec.clusterName section in the cassandra.yaml file. In the following commands, the secret name instana-superuser is used as an example.

To deploy the Cassandra instance and create the data store, complete the following steps:

  1. Deploy Cassandra by running the following command.

    kubectl apply -f cassandra.yaml --namespace=instana-cassandra
    
  2. Retrieve the password of the instana-superuser.

    kubectl get secret instana-superuser -n instana-cassandra --template='{{index .data.password | base64decode}}' && echo
    
  3. Store the password in the config.yaml file. Replace <RETRIEVED_FROM_SECRET> with the password that you got in the previous step.

    datastoreConfigs:
      ...
      cassandraConfigs:
        - user: instana-superuser
          password: <RETRIEVED_FROM_SECRET>
          adminUser: instana-superuser
          adminPassword: <RETRIEVED_FROM_SECRET>
      ...
    
  4. Verify the deployment of the Cassandra data store.

    kubectl get all -n instana-cassandra
    
  5. If the Cassandra data store is deployed successfully, then the result of the command might be as the following output:

    NAME                                  READY   STATUS    RESTARTS   AGE
    pod/cass-operator-57dcc8884f-92knc    1/1     Running   0          36m
    pod/instana-cassandra-default-sts-0   2/2     Running   0          26m
    pod/instana-cassandra-default-sts-1   2/2     Running   0          26m
    pod/instana-cassandra-default-sts-2   2/2     Running   0          26m
    
    NAME                                                TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)                                        AGE
    service/cass-operator-webhook-service               ClusterIP   192.168.1.55   <none>        443/TCP                                        36m
    service/instana-cassandra-additional-seed-service   ClusterIP   None           <none>        <none>                                         26m
    service/instana-cassandra-all-pods-service          ClusterIP   None           <none>        9042/TCP,8080/TCP,9103/TCP,9000/TCP            26m
    service/instana-cassandra-service                   ClusterIP   None           <none>        9042/TCP,9142/TCP,8080/TCP,9103/TCP,9000/TCP   26m
    service/instana-seed-service                        ClusterIP   None           <none>        <none>                                         26m
    
    NAME                            READY   UP-TO-DATE   AVAILABLE   AGE
    deployment.apps/cass-operator   1/1     1            1           36m
    
    NAME                                       DESIRED   CURRENT   READY   AGE
    replicaset.apps/cass-operator-57dcc8884f   1         1         1       36m
    
    NAME                                             READY   AGE
    statefulset.apps/instana-cassandra-default-sts   3/3     26m