Mount
Mount allows developers to locally mount cluster volumes in their local workstation so that their local code can read or write to these volumes.
Use Case
Developers need to have access to persistent volumes that workloads mount so that they can easily see data that the code is using remotely. Seeing this data is quite difficult because the data is only visible from within running pods.
Codezero resolves visibility of persistent volume data by allowing developers to mount them as local drives.
Overview
Mount is complimentary to Teleport in that your local code may need to read from or write to volumes that a workload has in a cluster in addition to talking to that workload. Without Mount, you would need to stub out or synthesize storage read or write operations in your code to make it run properly. With Mount, there's no need to do this, you can access these remote volumes locally.
Mount works by creating a lightweight NFS server in-cluster that mounts and shares all the volumes of a workload that you choose. Via the NFS server, your local system then mounts these volumes locally for you to access.
How it Works
- If you don't have an existing Teleport session into your cluster then one will be automatically started; however, if there is an existing Teleport session, and it isn't based on the same namespace and workload, then you will need to stop that Teleport session first.
- Start a Mount session for the specified namespace and workload.
- An NFS server deployment is started with a single pod, which mounts all the volumes referenced by that workload.
- Local mounts are created that point to each of the remote NFS server volumes.
Under the Hood
Mount works as follows:
- If you don't have an existing Teleport session into your cluster then one will be automatically started; however, if there is an existing Teleport session, but it isn't based on the same namespace and workload then you will need to stop that Teleport session first
- Start a Mount session for the specified namespace and workload
- An NFS server deployment is started with a single pod, which mounts all of the volumes referenced by that workload
- Local mounts are created that point to each of the remote NFS server volumes
Root Permissions
On Linux, Mount requires permission to mount volumes locally, which can only be done with elevated root access. Therefore, to run mount, you must first initialize the CLI using:
czctl start
[!EXPERT] Root access is only required once. During
startthe permissions of the tunneler binary elevate to always run as root (See Set-UID for more details), so subsequent mount calls can be run via the current user.
Residue and Cleanup
If any mounts remain after running Mount with the --clean parameter (or session close command), you can see them:
mount
...
nfs-server-deployment-nfsserviceproxy:/volumes/volume1 on .../folder-name/volume1 (nfs)
nfs-server-deployment-nfsserviceproxy:/volumes/volume2 on .../folder-name/volume2 (nfs)
Then you can go ahead and unmount using:
umount folder-name/volume1
umount folder-name/volume2
Be sure to first unmount all cluster volume first before ending your Teleport session; otherwise, your system will be unable to unmount the volumes properly.
Closing Mount
Run czctl session close to end the Mount session or reissue the same command with a --close flag. The session close command will clean up all the residue added to the Kubernetes cluster and remove your local mount points.
Command Reference
See the Mount command reference for more information.