StateFulSets で既存の NFS を使用しようとしています。
の作成は、PresistentVolumeClaim
を使用して自動的に行われるようvolumeClaimTemplates
です。
問題:
しかし、PresistentVolumeClaim
全体を主張しているのでPresistentVolume
。PresistentVolume
すべてのレプリカを手動で作成する必要があります。Kubernetes で NFS 永続ボリュームを動的にプロビジョニングする方法はありますか?
注: NFS サーバー自体は静的です。NFS サーバー自体ではなく、K8s でボリュームを動的に作成する必要があるだけです。
私はmongoステートフルセットの例を使用しています:
---
apiVersion: v1
kind: Service
metadata:
name: mongo
labels:
name: mongo
spec:
ports:
- port: 27017
targetPort: 27017
clusterIP: None
selector:
role: mongo
---
apiVersion: apps/v1beta1
kind: StatefulSet
metadata:
name: mongo
spec:
serviceName: "mongo"
replicas: 3
template:
metadata:
labels:
role: mongo
spec:
terminationGracePeriodSeconds: 10
containers:
- name: mongo
image: mongo
command:
- mongod
- "--replSet"
- rs0
- "--smallfiles"
- "--noprealloc"
ports:
- containerPort: 27017
volumeMounts:
- name: mongo-data
mountPath: /data/db
- name: mongo-sidecar
image: cvallance/mongo-k8s-sidecar
env:
- name: MONGO_SIDECAR_POD_LABELS
value: "role=mongo"
volumeClaimTemplates:
- metadata:
name: data
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 5Gi
selector:
matchLabels:
type: nfs
3 が必要なPresistentVolumeClaim
ので、使用するには 3 を作成する必要がありPV
ます。aws-ebs などの他の動的プロビジョナーと同様に、これを NFS に動的に追加できますか
これは NFS Persistent Volume で StatefulSet を取得する適切な方法ですか?