This write up shows detailed steps of how to setup a nfs server as a storage backend and make use of it in POD's persistent volume via persistent volume claim. These have been tested to work with kubernetes v1.19.3 and nfs v4.2 version ubuntu Ubuntu 18.04.5 LTS.
Set up nfs server:
Following commands would set up the server for storage backend:
apt update && apt install nfs-kernel-server -y
Create a directory called /mnt/nfs-share and provide all permission to clients. We may need to re-consider what permissions are allowed based on requirements.
mkdir -p /mnt/nfs-share/ && chmod -R 777 /mnt/nfs-share
We also, change the ownership of the shared directory next.
chown -R nobody:nogroup /mnt/nfs_share/
We need to edit the /etc/exports file to grant access to clients. Here we are specifically granting access to couple of machines.
vi /etc/exports
Execute the following commands to complete the server setup process:
exportfs -a
systemctl restart nfs-kernel-server
Note: We might need to allow firewall access depending on whether firewall is active or not:
If firewall is active fire the following commands:
ufw allow from 10.148.0.12 to any port nfs
ufw allow from 10.148.0.13 to any port nfs
Set up a client and check that shared access is working:
Install nfs client in one of the boxes that would share kubernetes workloads :
root@worker-1:~# apt install nfs-common
Create a directory and mount the shared nfs server directory as shown below:
mount 10.148.0.10:/mnt/nfs_share /mnt/client_share
Writing something in the client's /mnt/client_share folder should reflect it on the server and other connected clients.
Create PV and PVC (Persistent volume & claim):
First we create PV definition on the kubernetes server:
Next, we create the PVC definition followed by the busybox pod definition as shown below:
kubectl get pv,pvc
The above command out should show the status of PV and PVC as BOUND at this point.
The POD definition:
The changes in index.html can be seen in server/mnt/nfs_share, client/mnt/client_share and inside the busybox container's /tmp/nfs directories.