如何在Kubernetes部署中使用相同的EFS装载多个目录
我试图找到一个解决方案,利用相同的AmazonEFS在Kubernetes部署中挂载多个目录。这是我的用例如何在Kubernetes部署中使用相同的EFS装载多个目录,kubernetes,persistent-volumes,file-storage,efs,Kubernetes,Persistent Volumes,File Storage,Efs,我试图找到一个解决方案,利用相同的AmazonEFS在Kubernetes部署中挂载多个目录。这是我的用例 我有一个名为app1的应用程序,它需要将名为“/opt/templates”的目录持久化到EFS 我有另一个名为app2的应用程序,它需要将名为“/var/logs”的目录持久化到EFS 我们将应用程序作为Kubernetes吊舱部署在Amazon EKS集群中。如果我对上述两个装载使用相同的EFS,我可以看到目录“/opt/templates”和“/var/logs”中的所有文件,就
- 我有一个名为app1的应用程序,它需要将名为“/opt/templates”的目录持久化到EFS
- 我有另一个名为app2的应用程序,它需要将名为“/var/logs”的目录持久化到EFS
----
apiVersion: v1
kind: PersistentVolume
metadata:
name: efs-pv-1
spec:
capacity:
storage: 2Gi
volumeMode: Filesystem
accessModes:
- ReadWriteMany
persistentVolumeReclaimPolicy: Retain
storageClassName: efs-sc-report
csi:
driver: efs.csi.aws.com
volumeHandle: fs-XXXXX
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: efs-pvc-1
spec:
accessModes:
- ReadWriteMany
storageClassName: efs-sc
resources:
requests:
storage: 2Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: deploy1
spec:
replicas: 1
selector:
matchLabels:
app: deploy1
template:
metadata:
labels:
app: deploy1
spec:
containers:
- name: app1
image: imageXXXX
ports:
- containerPort: 6455
volumeMounts:
- name: temp-data
mountPath: /opt/templates/
volumes:
- name: shared-data
emptyDir: {}
- name: temp-data
persistentVolumeClaim:
claimName: efs-pvc-1
看起来你能做到 EFS的子目录可以安装在容器内。这使群集操作员能够灵活地限制从EFS上不同容器访问的数据量 例如:
volumeHandle: [FileSystemId]:[Path]
我认为您需要创建两个单独的PV和PV,一个用于/opt/templates,另一个用于/var/logs,每个都指向EFS上的不同路径。谢谢您的回答。我有一个单独的光伏和PVC的应用。我甚至尝试按照您在此处建议的方式添加路径,但我收到了一个错误,如事件:templates Pod templates-559775f8b7-rzb5w dev MountVolume.SetUp为卷“efs-pv-1”添加失败:kubernetes.io/csi:mounter.SetUp失败:rpc错误:code=Internal desc=无法在安装“fs XXXX:/etc/fstab/templates”“/var/lib/kubelet/pods/XXXXXXXXX/volumes/kubernetes.io~csi/efs pv report dev/mount”:装载失败:退出状态32看起来我需要在设置efs时创建一个子目录,然后我需要将子目录路径添加到卷句柄:[FileSystemId]:[path]。