建议将Pod的数据放入某个持久卷中,以便即便Pod终止后也能够使用这些数据。在Kubernetes(k8s)中,能够在Pod中使用基于NFS的持久卷。在本文中,咱们将学习如何配置持久卷和持久卷声明,而后咱们将讨论如何经过k8s pod中的声明名称使用持久卷。html
我假设咱们有一个功能正常的k8s集群和NFS Server。如下是实验室设置的详细信息:linux
注意: 确保能够从worker节点访问NFS服务器,并尝试在每一个worker节点上安装nfs共享以进行测试。nginx
在nfs共享中建立一个index.html文件,由于咱们将在本文后面的nginx pod中挂载该共享。vim
[kadmin@k8s-master ~]$ echo "Hello, NFS Storage NGINX" > /opt/k8s-pods/data/index.html
要在K8s中建立基于NFS的持久卷,请在主节点上使用如下内容建立yaml文件:api
[kadmin@k8s-master ~]$ vim nfs-pv.yaml apiVersion: v1 kind: PersistentVolume metadata: name: nfs-pv spec: capacity: storage: 10Gi volumeMode: Filesystem accessModes: - ReadWriteMany persistentVolumeReclaimPolicy: Recycle storageClassName: nfs mountOptions: - hard - nfsvers=4.1 nfs: path: /opt/k8s-pods/data server: 192.168.1.40
保存并退出文件服务器
如今使用上面建立的yaml文件建立持久卷,运行:curl
[kadmin@k8s-master ~]$ kubectl create -f nfs-pv.yaml persistentvolume/nfs-pv created [kadmin@k8s-master ~]$
运行如下kubectl命令以验证持久卷的状态:ide
[kadmin@k8s-master ~]$ kubectl get pv NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE nfs-pv 10Gi RWX Recycle Available nfs 20s [kadmin@k8s-master ~]$
以上输出确认PV已成功建立而且可用。学习
要在Pod内挂载持久卷,咱们必须指定其持久卷声明。所以,让咱们使用如下YAML文件建立持久卷声明:测试
[kadmin@k8s-master ~]$ vi nfs-pvc.yaml apiVersion: v1 kind: PersistentVolumeClaim metadata: name: nfs-pvc spec: storageClassName: nfs accessModes: - ReadWriteMany resources: requests: storage: 10Gi
保存并退出文件。
运行下面的kubectl命令以使用上面的yaml文件建立pvc:
[kadmin@k8s-master ~]$ kubectl create -f nfs-pvc.yaml persistentvolumeclaim/nfs-pvc created [kadmin@k8s-master ~]$
执行完上述操做后,控制平面将使用相同的存储类名称查找知足声明要求的持久卷,而后将声明绑定到持久卷,示例以下所示:
[kadmin@k8s-master ~]$ kubectl get pvc nfs-pvc NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE nfs-pvc Bound nfs-pv 10Gi RWX nfs 3m54s [kadmin@k8s-master ~]$ [kadmin@k8s-master ~]$ kubectl get pv nfs-pv NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE nfs-pv 10Gi RWX Recycle Bound default/nfs-pvc nfs 18m [kadmin@k8s-master ~]$
以上输出确认声明(nfs-pvc)与持久卷(nfs-pv)绑定。
如今咱们准备在pod旁边使用基于nfs的持久卷。
在yaml文件下面建立一个nginx pod,它将在/usr/share/nginx/html
上挂载持久卷声明。
[kadmin@k8s-master ~]$ vi nfs-pv-pod apiVersion: v1 kind: Pod metadata: name: nginx-pv-pod spec: volumes: - name: nginx-pv-storage persistentVolumeClaim: claimName: nfs-pvc containers: - name: nginx image: nginx ports: - containerPort: 80 name: "nginx-server" volumeMounts: - mountPath: "/usr/share/nginx/html" name: nginx-pv-storage
保存并关闭文件。
如今使用上面的yaml文件建立pod,运行:
[kadmin@k8s-master ~]$ kubectl create -f nfs-pv-pod.yaml pod/nginx-pv-pod created [kadmin@k8s-master ~]$ [kadmin@k8s-master ~]$ kubectl get pod nginx-pv-pod -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx-pv-pod 1/1 Running 0 66s 172.16.140.28 k8s-worker-2 <none> <none> [kadmin@k8s-master ~]$
注意:要获取有关pod的更多详细信息,可以使用 kubectl describe pod <pod-name>
命令。
以上命令输出确认已成功建立容器。如今尝试使用curl命令访问nginx页面:
[kadmin@k8s-master ~]$ curl http://172.16.140.28 Hello, NFS Storage NGINX [kadmin@k8s-master ~]$
完美,上面curl
命令的输出确认了持久卷已正确挂载到pod中,由于咱们能够获取NFS共享上index.html
文件的内容。
做者:Pradeep Kumar 译者:Yue Yong
原文来自:https://www.linuxtechi.com/configure-nfs-persistent-volume-kubernetes