As there’s no way to restore single files or folders, you first have to restore your backup to a new Filestore instance and copy the files manually. I’ll use /filestore_restore as share name and 192.0.2.69 as the instances IPv4 address. Furthermore I’ll use the folder important-folder as the example restore.

Then, you have to create a PV and a PVC to consume the share:

---
apiVersion: v1
kind: PersistentVolume
metadata:
  name: filestore-restore-nfs
spec:
  capacity:
    storage: 1Gi
  accessModes:

    - ReadOnlyMany
  nfs:
    path: /filestore_restore
    server: 192.0.2.69
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: filestore-restore-nfs
spec:
  accessModes:
    - ReadOnlyMany
  resources:
    requests:
      storage: 1Gi
  storageClassName: ""
  volumeName: filestore-restore-nfs

Afterwards, you can create a Pod which mounts this volume (or edit an existing Deployment to directly copy from backup to the original share). E.g. like this:

---
apiVersion: v1
kind: Pod
metadata:
  name: filestore-restore
spec:
  containers:

    - name: debian
      image: debian:latest
      volumeMounts:
        - name: filestore-restore
          mountPath: /tmp/restore
      args:
        - -c
        - sleep 10000h
      command:
        - /bin/sh
  volumes:
    - name: filestore-restore
      persistentVolumeClaim:
        claimName: filestore-restore-nfs

Then you can either use kubectl cp for easy copying or kubectl exec with tar to preserve permissions, symlinks, etc. I prefer to use tar as that’s safest:

kubectl exec filestore-restore -- tar cf - /tmp/restore/important-folder | kubectl exec -n <NAMESPACE>-c <CONTAINER> -i <ORIGINALPODNAME> -- tar xf - -C /original/data/path --strip-components=<amount of preceding path components to be stripped>

If everything has been restored as expected, don’t forget to delete PV, PVC, Pod and the filestore instance the backup was restored to.


Last update : December 9, 2024
Created : June 6, 2024