kubernetes - 在 GKE 上创建一个 Kubernetes Persistent Volume,连接到 GCE 上的外部 NFS 服务器
问题描述
我有一个 NFS 服务器在 GCE 的虚拟机上运行。NFS 服务器 /etc/exports 文件已配置为允许 K8s 集群挂载。我尝试创建持久卷 (PV) 和持久卷声明 (PVC),并添加了 spec.containers.volumeMounts 和 spec.volumes 条目。基本上,Google 会提供一个新磁盘,而不是连接到 NFS 服务器。
在我添加的部署文件中:
volumeMounts:
- name: nfs-pvc-data
mountPath: "/mnt/nfs"
volumes:
- name: nfs-pvc-data
persistentVolumeClaim:
claimName: nfs-pvc
nfs-pv.yaml
apiVersion: v1
kind: PersistentVolume
metadata:
name: nfs-pv
namespace: comms
labels:
volume: nfs-pv
spec:
capacity:
storage: 10G
#volumeMode: Filesystem
accessModes:
- ReadOnlyMany
mountOptions:
- hard
- nfsvers=4.2
nfs:
path: /
server: 10.xxx.xx.xx
readOnly: false
nfs-pvc.yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: nfs-pvc
namespace: comms
#spec: # The PVC is stuck on ready as long as spec.selector exists in the yaml
#selector:
#matchLabels:
#volume: nfs-pv
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1G
解决方案
我能够使用以下 PV 和 PVC YAML 将 NFS 服务器挂载到 Kubernetes 集群外部。
apiVersion: v1
kind: PersistentVolume
metadata:
name: gce-nfs
namespace: comms
spec:
capacity:
storage: 1Mi
accessModes:
- ReadWriteMany
nfs:
server: 10.xxx.xxx.xxx
path: "/"
---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: gce-nfs
spec:
accessModes:
- ReadWriteMany
storageClassName: ""
resources:
requests:
storage: 1Mi
然后在部署 YAML 中,我将以下内容添加到容器部分:
volumeMounts:
- name: nfs-pvc-data
mountPath: "/mnt/nfs"
volumes:
- name: nfs-pvc-data
persistentVolumeClaim:
claimName: gce-nfs
pod/container 将引导连接到外部 NFS 服务器。
推荐阅读
- postgresql - PostgreSQL 子查询案例顺序扫描
- windows - 如何使用 CSV 文件(BAT 文件)中的 URL 列表正确创建循环
- angular - 如何从 forkJoin 返回数据
- sql - SQL 嵌套选择语句。可以这样尝试吗?
- windows-installer - 将 .msi 转换为 .exe 的最佳工具包是什么?
- ios - 观看 OS 项目文件(处理不同目的的单独类)
- string - Haskell中的解析功能,制作地图功能时遇到麻烦
- android - 如何从android studio将参数发送到URL的html正文?
- python - Pyspark没有打开jupyter
- android - 为什么 MotionLayout 折叠动画不使用 NestedScrollView 自动完成?