CSI Volume Cloning

    The Volume Cloning feature adds support for specifying existing PVCs in the field to indicate a user would like to clone a .

    A Clone is defined as a duplicate of an existing Kubernetes Volume that can be consumed as any standard Volume would be. The only difference is that upon provisioning, rather than creating a “new” empty Volume, the back end device creates an exact duplicate of the specified Volume.

    Users need to be aware of the following when using this feature:

    • Cloning support is only available for dynamic provisioners.
    • CSI drivers may or may not have implemented the volume cloning functionality.
    • You can only clone a PVC when it exists in the same namespace as the destination PVC (source and destination must be in the same namespace).
    • Cloning can only be performed between two volumes that use the same VolumeMode setting (if you request a block mode volume, the source MUST also be block mode)

    Clones are provisioned like any other PVC with the exception of adding a dataSource that references an existing PVC in the same namespace.

    The result is a new PVC with the name that has the exact same content as the specified source .

    Upon availability of the new PVC, the cloned PVC is consumed the same as other PVC. It’s also expected at this point that the newly created PVC is an independent object. It can be consumed, cloned, snapshotted, or deleted independently and without consideration for it’s original dataSource PVC. This also implies that the source is not linked in any way to the newly created clone, it may also be modified or deleted without affecting the newly created clone.