k3s/examples/nfs
Sami Wagiaalla 63d8ce3a58 nfs example: Fix document root in comment
Signed-off-by: Sami Wagiaalla <swagiaal@redhat.com>
2015-06-12 14:03:23 -04:00
..
exporter Add e2e tests for Gluster and NFS tests. 2015-05-25 12:02:41 +02:00
nfs-data Add ga-beacon analytics to gendocs scripts 2015-05-15 18:56:38 -07:00
README.md add instructions on how to allow privileged containers 2015-06-11 10:33:29 -07:00
nfs-server-pod.yaml update example/nfs to v1 2015-06-10 16:04:53 -07:00
nfs-server-service.yaml update example/nfs to v1 2015-06-10 16:04:53 -07:00
nfs-web-pod.yaml nfs example: Fix document root in comment 2015-06-12 14:03:23 -04:00

README.md

Example of NFS volume

See nfs-web-pod.yaml for a quick example, how to use NFS volume in a pod.

Complete setup

The example below shows how to export a NFS share from a pod and import it into another one.

###Prerequisites The nfs server pod creates a privileged container, so if you are using a Salt based KUBERNETES_PROVIDER (gce, vagrant, aws), you have to enable the ability to create privileged containers by API.

#At the root of Kubernetes source code
$ vi cluster/saltbase/pillar/privilege.sls

# If true, allow privileged containers to be created by API
allow_privileged: true

Rebuild the Kubernetes and spin up a cluster using your preferred KUBERNETES_PROVIDER.

NFS server part

Define NFS server pod and NFS service:

$ kubectl create -f nfs-server-pod.yaml
$ kubectl create -f nfs-server-service.yaml

The server exports /mnt/data directory as / (fsid=0). The directory contains dummy index.html. Wait until the pod is running!

NFS client

WEB server pod uses the NFS share exported above as a NFS volume and runs simple web server on it. The pod assumes your DNS is configured and the NFS service is reachable as nfs-server.default.kube.local. Edit the yaml file to supply another name or directly its IP address (use kubectl get services to get it).

Define the pod:

$ kubectl create -f nfs-web-pod.yaml

Now the pod serves index.html from the NFS server:

$ curl http://<the container IP address>/
Hello World!

Analytics