Kubernetes : बाह्य संग्रहण का उपयोग करें2024/06/07 |
Kubernetes क्लस्टर में स्थायी संग्रहण कॉन्फ़िगर करें। यह उदाहरण निम्न प्रकार के वातावरण पर आधारित है। +----------------------+ +----------------------+ | [ ctrl.srv.world ] | | [ dlp.srv.world ] | | Manager Node | | Control Plane | +-----------+----------+ +-----------+----------+ eth0|10.0.0.25 eth0|10.0.0.30 | | ------------+--------------------------+----------- | | eth0|10.0.0.51 eth0|10.0.0.52 +-----------+----------+ +-----------+----------+ | [ node01.srv.world ] | | [ node02.srv.world ] | | Worker Node#1 | | Worker Node#2 | +----------------------+ +----------------------+ |
उदाहरण के लिए, क्लस्टर को कॉन्फ़िगर करें कि पॉड NFS सर्वर [nfs.srv.world (10.0.0.35)] पर बाहरी भंडारण के रूप में NFS शेयर का उपयोग कर सकें। |
|
[1] |
NFS सर्वर कॉन्फ़िगर करें, यहां देखें। |
[2] | PV (स्थायी वॉल्यूम) ऑब्जेक्ट और PVC (स्थायी वॉल्यूम दावा) ऑब्जेक्ट बनाएँ। |
apiVersion: v1 kind: PersistentVolume metadata: # कोई भी PV नाम name: nfs-pv spec: capacity: # भंडारण आकार storage: 10Gi accessModes: # पहुँच मोड: # - ReadWriteMany (RW from multi nodes) # - ReadWriteOnce (RW from a node) # - ReadOnlyMany (R from multi nodes) - ReadWriteMany persistentVolumeReclaimPolicy: # पॉड्स समाप्त होने पर भी बनाए रखें Retain nfs: # NFS सर्वर परिभाषा path: /home/nfsshare server: 10.0.0.35 readOnly: false kubectl create -f nfs-pv.yml persistentvolume "nfs-pv" created root@ctrl:~# kubectl get pv NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS VOLUMEATTRIBUTESCLASS REASON AGE nfs-pv 10Gi RWX Retain Available <unset> 4s
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
# कोई भी PVC नाम
name: nfs-pvc
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 10Gi
kubectl create -f nfs-pvc.yml persistentvolumeclaim "nfs-pvc" created root@ctrl:~# kubectl get pvc NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS VOLUMEATTRIBUTESCLASS AGE nfs-pvc Bound nfs-pv 10Gi RWX <unset> 12s |
[3] | ऊपर PVC के साथ पॉड्स बनाएं। |
root@ctrl:~#
vi nginx-nfs.yml apiVersion: apps/v1 kind: Deployment metadata: # कोई भी परिनियोजन नाम 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 # कंटेनर में माउंट पॉइंट mountPath: /usr/share/nginx/html volumes: - name: nfs-share persistentVolumeClaim: # PVC नाम आपने बनाया claimName: nfs-pvc
root@ctrl:~#
root@ctrl:~# 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-75cd8b4bb5-7b6qw 1/1 Running 0 2m26s 192.168.40.197 node01.srv.world <none> <none> nginx-nfs-75cd8b4bb5-7gp7d 1/1 Running 0 2m26s 192.168.241.131 node02.srv.world <none> <none> nginx-nfs-75cd8b4bb5-zqgsh 1/1 Running 0 2m26s 192.168.241.132 node02.srv.world <none> <none>
root@ctrl:~#
kubectl expose deployment nginx-nfs --type="NodePort" --port 80 service/nginx-nfs exposed root@ctrl:~# kubectl port-forward service/nginx-nfs --address 0.0.0.0 80:80 &
# NFS शेयर के अंतर्गत एक परीक्षण फ़ाइल बनाएँ root@ctrl:~# kubectl exec nginx-nfs-75cd8b4bb5-7b6qw -- sh -c "echo 'NFS Persistent Storage Test' > /usr/share/nginx/html/index.html"
|
[4] | आवेदन तक पहुंच और चल रहा सत्यापन। |
Sponsored Link |
|