Use Rancher projects with ClusterPair for asynchronous DR in OCP on bare metal
If you are not using Rancher, skip to the Schedule your migration section.
Rancher has a concept of Projects that allow grouping of resources and namespaces. Depending on the resource and how it is created, Rancher adds the following label or annotation:
field.cattle.io/projectID: <project-short-UUID>
The ClusterPair with these project mappings will ensure that Rancher projects are effectively managed and associated during the migration process.
The projectID uniquely identifies the project, and the annotation or label on the OpenShift object provides a way to tie a object back to a Rancher project.
Stork allows you to map projects from the source cluster to the destination cluster during migration. It will ensure that the following are transformed when migrating resources to a destination cluster:
- Labels and annotations for projectID field.cattle.io/projectIDon any resource on the source cluster are transformed to their respective projectIDs on the destination cluster.
- The transformation of Namespace Selectors on a NetworkPolicy object that reference the field.cattle.io/projectIDlabel to use the correct projectIDs on the destination cluster.
- The transformation of Namespace Selectors on a Pod object (Kubernetes version 1.24 or newer) that reference the field.cattle.io/projectIDlabel to the correct projectIDs on the destination cluster.
Prerequisites
- Stork version 2.11.2 or newer.
- All the Rancher projects are created on both the source and the destination cluster.
Create project mapping
While creating the ClusterPair, use the argument --project-mappings to indicate how projectIDs on the source cluster should map to projectIDs on the destination cluster. Project mappings are provided as comma-separated key-value pairs.
For example:
storkctl generate clusterpair -n <migrationnamespace> <remotecluster> --project-mappings  <projectID-A1>=<projectID-A2>,<projectID-B1>: <projectID-B2>
In this example, projectID-A1 on source cluster maps to projectID-A2 on the destination cluster, while projectID-B1 on the source cluster maps to projectID-B2 on the destination cluster.
Include ClusterIDs in project mappings (Optional)
For the projectIDs, you can also include clusterID prefixes in project mappings. Including clusterID prefixes ensures precise mapping, especially in scenarios with multiple clusters.
For example:
storkctl generate clusterpair \
-n <migrationnamespace> <remotecluster> \
--project-mappings \
p-58q4n=p-jjk2q c-m-wthc7l5q:p-58q4n=c-m-5sftdjns:p-jjk2q 
In the above example, there are following two mappings:
- A mapping with clusterIDs: c-m-wthc7l5q:p-58q4ncontaining the source clusterIDc-m-wthc7l5qwill map toc-m-5sftdjns:p-jjk2qcontaining the destination clusterIDc-m-5sftdjns.
- A mapping without the clusterIDs: p-58q4nwill map top-jjk2q.
To view the information, click on the respective tabs, which provide details on how the projectIDs on the source cluster correlate with projectIDs on the destination cluster during resource migration.
- Source to destination
- Destination to source
spec:
 platformOptions:
  rancher:
    projectMappings:
        c-m-wthc7l5q:p-58q4n: c-m-5sftdjns:p-jjk2q
        c-m-wthc7l5q:p-dmx28: c-m-5sftdjns:p-6nk5r
        c-m-wthc7l5q:p-hvxqm: c-m-5sftdjns:p-7cx4c
        c-m-wthc7l5q:p-fkth5: c-m-5sftdjns:p-w5z2s
        p-58q4n: p-jjk2q
        p-dmx28: p-6nk5r
        p-hvxqm: p-7cx4c
        p-xz4pd: p-fg5sd
spec:
 platformOptions:
  rancher:
    projectMappings:
        c-m-5sftdjns:p-jjk2q: c-m-wthc7l5q:p-58q4n
        c-m-5sftdjns:p-6nk5r: c-m-wthc7l5q:p-dmx28
        c-m-5sftdjns:p-7cx4c: c-m-wthc7l5q:p-hvxqm
        c-m-5sftdjns:p-w5z2s: c-m-wthc7l5q:p-fkth5
        p-jjk2q: p-58q4n
        p-6nk5r: p-dmx28
        p-7cx4c: p-hvxqm
        p-fg5sd: p-xz4pd