Kubernetes : 永続ストレージの設定2020/08/19 |
Docker コンテナー単体利用時と同様、データの永続化には外部ストレージが必要になります。
当例では以下のように 三台のノードを使用して Kubernetes クラスターを構成しています。
例として、Master ノード上に NFS サーバーを起動し、Pod から外部ストレージとして利用できるよう設定します。
-----------+---------------------------+--------------------------+------------ | | | eth0|10.0.0.30 eth0|10.0.0.51 eth0|10.0.0.52 +----------+-----------+ +-----------+----------+ +-----------+----------+ | [ dlp.srv.world ] | | [ node01.srv.world ] | | [ node02.srv.world ] | | Master Node | | Worker Node | | Worker Node | +----------------------+ +----------------------+ +----------------------+ |
[1] |
こちらを参考に Master ノード上に NFS サーバーを稼働させておきます。
なお、当例では [/home/nfsshare] ディレクトリを共有ディレクトリとして設定します。 |
[2] | Master ノードで PV (Persistent Volume) オブジェクト および PVC (Persistent Volume Claim) オブジェクトを定義しておきます。 |
apiVersion: v1 kind: PersistentVolume metadata: # 任意の PV 名 name: nfs-pv spec: capacity: # ストレージのサイズ storage: 10Gi accessModes: # アクセスモード: # - ReadWriteMany (複数ノード RW) # - ReadWriteOnce (単一ノード RW) # - ReadOnlyMany (複数ノード R) - ReadWriteMany persistentVolumeReclaimPolicy: # Pod が終了した後もデータを残す Retain nfs: # NFS サーバーの定義 path: /home/nfsshare server: 10.0.0.30 readOnly: false kubectl apply -f nfs-pv.yml persistentvolume "nfs-pv" created root@dlp:~# kubectl get pv NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE nfs-pv 10Gi RWX Retain Available 4s
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
# 任意の PVC 名
name: nfs-pvc
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 10Gi
kubectl apply -f nfs-pvc.yml persistentvolumeclaim "nfs-pvc" created root@dlp:~# kubectl get pvc NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE nfs-pvc Bound nfs-pv 10Gi RWX 4s |
[3] | 定義済みの PVC を指定した Pod を作成して動作確認します。 |
root@dlp:~#
vi nginx-nfs.yml apiVersion: apps/v1 kind: Deployment metadata: # 任意の Deployment 名 name: nginx-nfs labels: name: nginx-nfs spec: replicas: 3 selector: matchLabels: app: nginx-nfs template: metadata: labels: app: nginx-nfs spec: containers: - name: nginx-nfs image: nginx ports: - name: web containerPort: 80 volumeMounts: - name: nfs-share # コンテナー内で NFS をマウントする場所 mountPath: /usr/share/nginx/html volumes: - name: nfs-share persistentVolumeClaim: # 事前に作成した PVC 名 claimName: nfs-pvc
root@dlp:~#
root@dlp:~# kubectl apply -f nginx-nfs.yml deployment.apps/nginx-nfs created kubectl get pods -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx-nfs-85754ccc84-7997c 1/1 Running 0 17s 10.244.2.4 node02.srv.world <none> <none> nginx-nfs-85754ccc84-l2mhf 1/1 Running 0 17s 10.244.1.6 node01.srv.world <none> <none> nginx-nfs-85754ccc84-xdrgd 1/1 Running 0 17s 10.244.1.7 node01.srv.world <none> <none>root@dlp:~# kubectl expose deployment nginx-nfs --type="NodePort" --port 80 service/nginx-nfs exposed root@dlp:~# kubectl get service nginx-nfs NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE nginx-nfs NodePort 10.100.149.182 <none> 80:32706/TCP 4s # 設定した NFS の共有領域にテストファイル作成 root@dlp:~# echo 'NFS Persistent Storage Test' > /home/nfsshare/index.html
# アクセス確認 root@dlp:~# curl 10.100.149.182 NFS Persistent Storage Test |
Sponsored Link |