Learn about configuring the workspace’s container entrypoint script so that fuse-overlayfs is used for all workspaces using that container.
The Universal Developer Image (UDI) already contains the necessary configuration by default.
However, you must configure the script manually if you use custom images due to Podman 5.x requiring the /home/user/.config
folder to be owned by the current user.
-
For OpenShift versions 4.14 and lower, the administration-guide:enabling-access-to-dev-fuse-for-openshift.adoc section has been completed.
-
An active
{orch-cli}
session with administrative permissions to the destination OpenShift cluster. See {orch-cli-link}.
-
Set the necessary annotation in the
spec.devEnvironments.workspacesPodAnnotations
field of the CheCluster custom resource.kind: CheCluster apiVersion: org.eclipse.che/v2 spec: devEnvironments: workspacesPodAnnotations: io.kubernetes.cri-o.Devices: /dev/fuse
NoteFor OpenShift versions 4.14 and lower, the
io.openshift.podman-fuse: ""
annotation is also required. -
[OPTIONAL] If you are using a custom image for the workspace container, create the
/home/user/.config
folder and configure thestorage.conf
file on runtime via the entrypoint. To do this, add the following to the workspace container image’s entrypoint script before building the image. Creating the/home/user/.config
folder in the entrypoint results in the folder being owned by the current user which is not known at image build time.# Configure container builds to use vfs or fuse-overlayfs if [ ! -d "${HOME}/.config/containers" ]; then mkdir -p ${HOME}/.config/containers if [ -c "/dev/fuse" ] && [ -f "/usr/bin/fuse-overlayfs" ]; then (echo '[storage]';echo 'driver = "overlay"';echo '[storage.options.overlay]';echo 'mount_program = "/usr/bin/fuse-overlayfs"') > ${HOME}/.config/containers/storage.conf else (echo '[storage]';echo 'driver = "vfs"') > "${HOME}"/.config/containers/storage.conf fi fi
This ensures that if the
/home/user/.config
doesn’t already exist, the folder is created and owned byuser
. The/home/user/.config
may already exist for example, if it was stored in a persistent volume. -
Start a workspace and verify that the owner for
/home/user/.config
isuser
.$ ls -la /home/user
Example output:
... drwxrwsr-x. 3 user 1000660000 24 Dec 24 15:40 .config
-
Verify that the storage driver is
overlay
.$ podman info | grep overlay
Example output:
graphDriverName: overlay overlay.mount_program: Executable: /usr/bin/fuse-overlayfs Package: fuse-overlayfs-1.14-1.el9.x86_64 fuse-overlayfs: version 1.13-dev Backing Filesystem: overlayfs
NoteThe following error might occur for existing workspaces:
ERRO[0000] User-selected graph driver "overlay" overwritten by graph driver "vfs" from database - delete libpod local files ("/home/user/.local/share/containers/storage") to resolve. May prevent use of images created by other tools
In this case, delete the libpod local files as mentioned in the error message.