Replication

Installation of CSM for Replication

Starting with Container Storage Module 1.12, all deployments will use images from quay.io by default. New release images will be available on Docker Hub until CSM 1.14 (May 2025), and existing releases will remain on Docker Hub.

The Container Storage Module Operator installs the Replication module for supported Dell CSI Drivers, deploying the Replication sidecar and Controller Manage.

Prerequisites

To configure Replication prior to installation via Container Storage Module Operator, you need:

  • a source cluster which is the main cluster
  • a target cluster which will serve as the disaster recovery cluster

NOTE: If using a single Kubernetes cluster in a stretched configuration, there will be only one cluster. The source cluster is also the target cluster.

  • (Optional) If Container Storage Module Replication is being deployed using two clusters in an environment where the DNS is not configured, and the cluster API endpoints are FQDNs, it is necessary to add the <FQDN>:<IP> mapping in the /etc/hosts file in order to resolve queries to the remote API server. This change will need to be made to the /etc/hosts file on:

    • The bastion node(s) (or wherever repctl is used).
    • Either the Container Storage Module Operator Deployment or ClusterServiceVersion custom resource if using an Operator Lifecycle Manager (such as with an OperatorHub install).
    • Both dell-replication-controller-manager deployments covered in Configuration Steps below.

    Update the ClusterServiceVersion before continuing. Execute the command below, replacing the fields for the remote cluster’s FQDN and IP.

    kubectl patch clusterserviceversions.operators.coreos.com -n <operator-namespace> dell-csm-operator-certified.v1.3.0 \
    --type=json -p='[{"op": "add", "path": "/spec/install/spec/deployments/0/spec/template/spec/hostAliases", "value": [{"ip":"<remote-IP>","hostnames":["<remote-FQDN>"]}]}]'
    

Cloning the GitHub Repository and Building repctl

The csm-replication GitHub repository is cloned to your source cluster as part of the installation. On your source cluster run the following to clone and build the repctl tool:

git clone -b v1.11.0 https://github.com/dell/csm-replication.git
cd csm-replication/repctl
make build

Alternately, you can download a pre-built repctl binary from our Releases page.

wget https://github.com/dell/csm-replication/releases/download/v1.11.0/repctl-linux-amd64
mv repctl-linux-amd64 repctl
chmod +x repctl

The rest of the instructions will assume that your current working directory is the csm-replication/repctl directory.

Configuration Steps

To configure Replication perform the following steps:

  1. On your main cluster collect the cluster admin configurations for each of the clusters. In the following example the source cluster, cluster-1 uses configuration /root/.kube/config-1 and the target cluster, cluster-2 uses the configuration /root/.config/config-2. Use repctl to add the clusters:
      ./repctl cluster add -f "/root/.kube/config-1","/root/.kube/config-2" -n "cluster-1","cluster-2"
    

NOTE: If using a single Kubernetes cluster in a stretched configuration there will be only one cluster.

  1. Install the replication controller CRDs:

    ./repctl create -f ../deploy/replicationcrds.all.yaml
    
  2. Inject the service account’s configuration into the clusters.

    ./repctl cluster inject
    

    NOTE: To inject the service account’s configuration for each cluster individually, use the following command:

      ./repctl cluster inject --custom-configs $HOME/.repctl/clusters/<config-name>
      Example: ./repctl cluster inject --custom-configs "/root/.repctl/clusters/config-1"
    
  3. Customize the examples/<storage>_example_values.yaml sample config. Set the values for sourceClusterID and targetClusterID to the same names used in step 1. For a stretched cluster set both fields to self:

  4. Create the replication storage classes using the modified configuration from step 4:

    ./repctl create sc --from-config ./examples/<storage>_example_values.yaml
    
  5. On the target cluster, configure the prerequisites for deploying the driver via Dell CSM Operator.

  6. Install the CSI driver for your chosen storage platform on the source cluster according to the instructions for installing the drivers using CSM Operator.

  7. (Optional) If CSM Replication is deployed using two clusters in an environment where the DNS is not configured, it is necessary to update the dell-replication-controller-manager Kubernetes deployment to map the API endpoint FQDN to an IP address by adding the hostAliases field and associated FQDN:IP mappings.

    To update the dell-replication-controller-manager deployment, execute the command below, replacing the fields for the remote cluster’s FQDN and IP. Make sure to update the deployment on both the primary and disaster recovery clusters.

    kubectl patch deployment -n dell-replication-controller dell-replication-controller-manager \
    -p '{"spec":{"template":{"spec":{"hostAliases":[{"hostnames":["<remote-FQDN>"],"ip":"<remote-IP>"}]}}}}'
    
  1. If installing replication via operator with the PowerMax driver on two clusters: you will need to create a Kubernetes service for the reverseproxy on the target cluster. Insert values from your deployment into this service.yaml file and then create it on the target cluster using kubectl create -f service.yaml.
    apiVersion: v1
    kind: Service
    metadata:
      name: csipowermax-reverseproxy
      namespace: <INSERT DRIVER NAMESPACE>
    spec:
      ports:
        - port: <INSERT X_CSI_REVPROXY_PORT FROM DRIVER SAMPLE FILE>
          protocol: TCP
          targetPort: 2222
      selector:
        app: <INSERT DRIVER DEPLOYMENT NAME>-controller
      type: ClusterIP