कुबेरनेट्स - वॉल्यूम

कुबेरनेट्स में, एक वॉल्यूम को एक निर्देशिका के रूप में सोचा जा सकता है जो एक फली में कंटेनरों के लिए सुलभ है। हमारे पास कुबेरनेट्स में विभिन्न प्रकार के वॉल्यूम हैं और प्रकार परिभाषित करता है कि वॉल्यूम कैसे बनाया गया है और इसकी सामग्री क्या है।

वॉल्यूम की अवधारणा डोकर के साथ मौजूद थी, हालांकि एकमात्र मुद्दा यह था कि यह मात्रा एक विशेष फली तक बहुत सीमित थी। जैसे ही एक फली का जीवन समाप्त हुआ, मात्रा भी खो गई।

दूसरी ओर, कुबेरनेट्स के माध्यम से जो वॉल्यूम बनाए जाते हैं, वे किसी भी कंटेनर तक सीमित नहीं हैं। यह कुबेरनेट्स की फली के अंदर तैनात किसी भी या सभी कंटेनरों का समर्थन करता है। कुबेरनेट्स की मात्रा का एक प्रमुख लाभ यह है कि यह विभिन्न प्रकार के भंडारण का समर्थन करता है जिसमें फली एक ही समय में उनमें से कई का उपयोग कर सकते हैं।

कुबेरनेट्स वॉल्यूम के प्रकार

यहां कुछ लोकप्रिय कुबेरनेट्स वॉल्यूम की एक सूची दी गई है -

  • emptyDir- यह एक प्रकार का वॉल्यूम है जो तब बनाया जाता है जब एक पॉड को पहली बार एक नोड को सौंपा जाता है। यह तब तक सक्रिय रहता है जब तक कि नोड उस नोड पर चल रहा होता है। वॉल्यूम शुरू में खाली होता है और पॉड में कंटेनर खाली डेयर वॉल्यूम में फाइलों को पढ़ और लिख सकते हैं। एक बार पॉड को नोड से हटा दिया जाता है, तो खाली डेटा में डेटा मिटा दिया जाता है।

  • hostPath - इस प्रकार का वॉल्यूम आपके नोड में होस्ट नोड के फाइल सिस्टम से एक फ़ाइल या निर्देशिका को मापता है।

  • gcePersistentDisk- इस प्रकार का वॉल्यूम आपके पॉड में Google कंप्यूट इंजन (GCE) परसेंट डिस्क को मापता है। में डेटाgcePersistentDisk जब पॉड नोड से हटा दिया जाता है तो बरकरार रहता है।

  • awsElasticBlockStore- इस प्रकार का वॉल्यूम आपके पॉड में अमेज़न वेब सर्विसेज (AWS) इलास्टिक ब्लॉक स्टोर की गणना करता है। बिलकुल इसके जैसाgcePersistentDiskमें डेटा awsElasticBlockStore जब पॉड नोड से हटा दिया जाता है तो बरकरार रहता है।

  • nfs - ए nfsवॉल्यूम एक मौजूदा NFS (नेटवर्क फ़ाइल सिस्टम) को आपके पॉड में माउंट करने की अनुमति देता है। ए में डेटाnfsजब पॉड को नोड से हटाया जाता है तो वॉल्यूम को मिटाया नहीं जाता है। वॉल्यूम केवल अनमाउंट है।

  • iscsi - ए iscsi वॉल्यूम एक मौजूदा iSCSI (IP पर SCSI) वॉल्यूम को आपके पॉड में माउंट करने की अनुमति देता है।

  • flocker- यह एक ओपन-सोर्स क्लस्टर्ड कंटेनर डेटा वॉल्यूम मैनेजर है। इसका उपयोग डेटा वॉल्यूम के प्रबंधन के लिए किया जाता है। एflockerवॉल्यूम फ़्लोकर डेटासेट को एक पॉड में माउंट करने की अनुमति देता है। यदि फ़्लिकर में डेटासेट मौजूद नहीं है, तो आपको पहले फ़्लॉकर एपीआई का उपयोग करके इसे बनाने की आवश्यकता है।

  • glusterfs- ग्लस्टरफ़ेट्स एक ओपन-सोर्स नेटवर्क्ड फाइलसिस्टम है। एक glusterfs मात्रा एक glusterfs वॉल्यूम को आपके पॉड में माउंट करने की अनुमति देती है।

  • rbd- आरबीडी का मतलब रेडोस ब्लॉक डिवाइस है। एकrbdवॉल्यूम एक रेडोस ब्लॉक डिवाइस वॉल्यूम को आपके पॉड में माउंट करने की अनुमति देता है। पॉड को नोड से हटाने के बाद डेटा संरक्षित रहता है।

  • cephfs - ए cephfsवॉल्यूम आपके मौजूदा पॉड वॉल्यूम को आपके पॉड में माउंट करने की अनुमति देता है। पॉड को नोड से हटाने के बाद डेटा बरकरार रहता है।

  • gitRepo - ए gitRepo वॉल्यूम एक खाली निर्देशिका और क्लोन ए git उपयोग करने के लिए अपनी फली के लिए इसमें भंडार।

  • secret - ए secret वॉल्यूम का उपयोग संवेदनशील जानकारी, जैसे पासवर्ड, पॉड्स में करने के लिए किया जाता है।

  • persistentVolumeClaim - ए persistentVolumeClaimवॉल्यूम को एक पॉड्स में एक PersistentVolume माउंट करने के लिए उपयोग किया जाता है। PersistentVolumes उपयोगकर्ताओं के लिए "क्लाउड" टिकाऊ भंडारण (जैसे कि GCE PersistentDisk या iSCSI वॉल्यूम) का दावा करने का एक तरीका है, जो विशेष क्लाउड वातावरण के विवरण को जाने बिना।

  • downwardAPI - ए downwardAPIवॉल्यूम का उपयोग डाउनवर्ड एपीआई डेटा को अनुप्रयोगों के लिए उपलब्ध कराने के लिए किया जाता है। यह एक निर्देशिका को मापता है और सादे पाठ फ़ाइलों में अनुरोधित डेटा लिखता है।

  • azureDiskVolume - ए AzureDiskVolume एक Microsoft Azure डेटा डिस्क को पॉड में माउंट करने के लिए उपयोग किया जाता है।

लगातार वॉल्यूम और लगातार वॉल्यूम का दावा

Persistent Volume (PV)- यह नेटवर्क भंडारण का एक टुकड़ा है जिसे व्यवस्थापक द्वारा प्रावधानित किया गया है। यह क्लस्टर में एक संसाधन है जो किसी भी व्यक्तिगत पॉड से स्वतंत्र है जो पीवी का उपयोग करता है।

Persistent Volume Claim (PVC)- इसकी फली के लिए कुबेरनेट्स द्वारा अनुरोधित भंडारण को पीवीसी के रूप में जाना जाता है। उपयोगकर्ता को अंतर्निहित प्रावधान को जानने की आवश्यकता नहीं है। दावों को उसी नामस्थान में बनाया जाना चाहिए जहाँ फली बनाई जाती है।

लगातार वॉल्यूम बनाना

kind: PersistentVolume ---------> 1
apiVersion: v1
metadata:
   name: pv0001 ------------------> 2
   labels:
      type: local
spec:
   capacity: -----------------------> 3
      storage: 10Gi ----------------------> 4
   accessModes:
      - ReadWriteOnce -------------------> 5
      hostPath:
         path: "/tmp/data01" --------------------------> 6

उपरोक्त कोड में, हमने परिभाषित किया है -

  • kind: PersistentVolume → हमने इस प्रकार को PersistentVolume के रूप में परिभाषित किया है जो kubernetes को बताता है कि जिस yaml फ़ाइल का उपयोग किया जा रहा है वह Persistent वॉल्यूम बनाने के लिए है।

  • name: pv0001 → PersistentVolume का नाम जो हम बना रहे हैं।

  • capacity: → यह कल्पना पीवी की क्षमता को परिभाषित करेगी जिसे हम बनाने की कोशिश कर रहे हैं।

  • storage: 10Gi → यह अंतर्निहित बुनियादी ढांचे को बताता है कि हम परिभाषित पथ पर 10Gi अंतरिक्ष का दावा करने की कोशिश कर रहे हैं।

  • ReadWriteOnce → यह उस वॉल्यूम के एक्सेस अधिकारों को बताता है जो हम बना रहे हैं।

  • path: "/tmp/data01" → यह परिभाषा उस मशीन को बताती है जिसे हम अंतर्निहित बुनियादी ढांचे पर इस पथ के तहत मात्रा बनाने की कोशिश कर रहे हैं।

पी.वी.

$ kubectl create –f local-01.yaml
persistentvolume "pv0001" created

जाँच कर रहे पी.वी.

$ kubectl get pv
NAME        CAPACITY      ACCESSMODES       STATUS       CLAIM      REASON     AGE
pv0001        10Gi            RWO         Available                            14s

पीवी का वर्णन करते हुए

$ kubectl describe pv pv0001

लगातार वॉल्यूम क्लेम बनाना

kind: PersistentVolumeClaim --------------> 1
apiVersion: v1
metadata:
   name: myclaim-1 --------------------> 2
spec:
   accessModes:
      - ReadWriteOnce ------------------------> 3
   resources:
      requests:
         storage: 3Gi ---------------------> 4

उपरोक्त कोड में, हमने परिभाषित किया है -

  • kind: PersistentVolumeClaim → यह अंतर्निहित बुनियादी ढांचे को निर्देश देता है कि हम अंतरिक्ष की एक निर्दिष्ट राशि का दावा करने की कोशिश कर रहे हैं।

  • name: myclaim-1 → उस दावे का नाम जो हम बनाने की कोशिश कर रहे हैं।

  • ReadWriteOnce → यह उस दावे के मोड को निर्दिष्ट करता है जिसे हम बनाने की कोशिश कर रहे हैं।

  • storage: 3Gi → यह कुबेरनेट्स को उस स्थान के बारे में बताएगा जो हम दावा करने की कोशिश कर रहे हैं।

पीवीसी बनाना

$ kubectl create –f myclaim-1
persistentvolumeclaim "myclaim-1" created

पीवीसी के बारे में विवरण प्राप्त करना

$ kubectl get pvc
NAME        STATUS   VOLUME   CAPACITY   ACCESSMODES   AGE
myclaim-1   Bound    pv0001     10Gi         RWO       7s

पीवीसी का वर्णन करें

$ kubectl describe pv pv0001

POD के साथ PV और PVC का उपयोग करना

kind: Pod
apiVersion: v1
metadata:
   name: mypod
   labels:
      name: frontendhttp
spec:
   containers:
   - name: myfrontend
      image: nginx
      ports:
      - containerPort: 80
         name: "http-server"
      volumeMounts: ----------------------------> 1
      - mountPath: "/usr/share/tomcat/html"
         name: mypd
   volumes: -----------------------> 2
      - name: mypd
         persistentVolumeClaim: ------------------------->3
         claimName: myclaim-1

उपरोक्त कोड में, हमने परिभाषित किया है -

  • volumeMounts: → कंटेनर में यह पथ है जिस पर बढ़ते समय लगेगा।

  • Volume: → यह परिभाषा उस वॉल्यूम परिभाषा को परिभाषित करती है जिसका हम दावा करने जा रहे हैं।

  • persistentVolumeClaim: → इसके अंतर्गत, हम वॉल्यूम नाम को परिभाषित करते हैं जिसे हम परिभाषित पॉड में उपयोग करने जा रहे हैं।