कुबेरनेट्स पॉड्स

From binaryoption
Jump to navigation Jump to search
Баннер1
    1. कुबेरनेट्स पॉड्स: शुरुआती गाइड

कुबेरनेट्स (Kubernetes) आधुनिक एप्लिकेशन डिप्लॉयमेंट और मैनेजमेंट के लिए एक शक्तिशाली ओपन-सोर्स प्लेटफॉर्म है। यह विशेष रूप से कंटेनराइज्ड एप्लिकेशन को स्केल करने और प्रबंधित करने में मदद करता है। कुबेरनेट्स की मूलभूत इकाई पॉड है। इस लेख में, हम कुबेरनेट्स पॉड्स की अवधारणा को विस्तार से समझेंगे, उनके उपयोग, संरचना, और प्रबंधन के बारे में जानेंगे।

पॉड क्या है?

एक पॉड कुबेरनेट्स में डिप्लॉयमेंट की सबसे छोटी और मूलभूत इकाई है। इसे एक लॉजिकल होस्ट के रूप में समझा जा सकता है, जिसमें एक या अधिक कंटेनर होते हैं जो एक साथ काम करते हैं। ये कंटेनर एक ही नेटवर्क नेमस्पेस और स्टोरेज वॉल्यूम साझा करते हैं। सरल शब्दों में, पॉड एक समूह है जो एक ही कार्य को करने के लिए एक साथ काम करने वाले कंटेनरों को एक साथ रखता है।

पॉड को एक वर्चुअल मशीन (VM) से भ्रमित नहीं होना चाहिए। VM में एक पूरा ऑपरेटिंग सिस्टम होता है, जबकि पॉड में केवल कंटेनर होते हैं जो होस्ट ऑपरेटिंग सिस्टम के कर्नेल (kernel) को साझा करते हैं। इससे पॉड VM की तुलना में हल्के और अधिक कुशल होते हैं।

पॉड्स का उपयोग क्यों करें?

पॉड का उपयोग करने के कई फायदे हैं:

  • **एकात्मकता:** पॉड एक ही यूनिट के रूप में डिप्लॉय और स्केल किए जाते हैं, जिससे एप्लिकेशन मैनेजमेंट आसान हो जाता है।
  • **साझा संसाधन:** पॉड के अंदर के कंटेनर एक ही नेटवर्क और स्टोरेज संसाधनों को साझा करते हैं, जिससे संचार और डेटा साझाकरण सरल हो जाता है।
  • **पुनरुत्पादकता:** पॉड को आसानी से दोहराया जा सकता है, जिससे एप्लिकेशन की उपलब्धता और विश्वसनीयता बढ़ती है।
  • **पोर्टेबिलिटी:** पॉड को किसी भी कुबेरनेट्स क्लस्टर पर डिप्लॉय किया जा सकता है, जिससे एप्लिकेशन की पोर्टेबिलिटी सुनिश्चित होती है।
  • **स्केलेबिलिटी:** कुबेरनेट्स पॉड्स को आसानी से स्केल करने की क्षमता प्रदान करता है, जिससे एप्लिकेशन की मांग के अनुसार संसाधनों को बढ़ाया या घटाया जा सकता है।

पॉड की संरचना

एक पॉड में निम्नलिखित मुख्य घटक होते हैं:

  • **कंटेनर:** पॉड में एक या अधिक कंटेनर हो सकते हैं। प्रत्येक कंटेनर एक एप्लिकेशन या एप्लिकेशन का एक भाग चलाता है।
  • **नेटवर्क नेमस्पेस:** पॉड के अंदर के सभी कंटेनर एक ही नेटवर्क नेमस्पेस साझा करते हैं, जिसका अर्थ है कि वे एक ही IP एड्रेस और पोर्ट का उपयोग कर सकते हैं।
  • **स्टोरेज वॉल्यूम:** पॉड के अंदर के कंटेनर एक या अधिक स्टोरेज वॉल्यूम साझा कर सकते हैं। ये वॉल्यूम डेटा को बनाए रखने और कंटेनरों के बीच साझा करने के लिए उपयोग किए जाते हैं।
  • **पॉड आईपी एड्रेस:** प्रत्येक पॉड को एक अद्वितीय आईपी एड्रेस असाइन किया जाता है, जिसका उपयोग अन्य पॉड्स और सेवाओं द्वारा इसके साथ संचार करने के लिए किया जाता है।
  • **पॉड मेटाडेटा:** पॉड मेटाडेटा में लेबल, एनोटेशन और अन्य जानकारी शामिल होती है जो पॉड का वर्णन करती है।
पॉड घटक
घटक विवरण
कंटेनर एप्लिकेशन या एप्लिकेशन का भाग चलाने वाला एक आइसोलेटेड यूनिट।
नेटवर्क नेमस्पेस कंटेनरों के लिए साझा नेटवर्क वातावरण।
स्टोरेज वॉल्यूम डेटा भंडारण और साझाकरण के लिए उपयोग किया जाता है।
पॉड आईपी एड्रेस पॉड के लिए अद्वितीय नेटवर्क पहचानकर्ता।
पॉड मेटाडेटा पॉड का वर्णन करने वाली जानकारी (लेबल, एनोटेशन आदि)।

पॉड बनाना

पॉड को YAML (YAML Ain't Markup Language) फ़ाइल का उपयोग करके परिभाषित किया जाता है। यह फ़ाइल पॉड की संरचना, कंटेनर, और अन्य कॉन्फ़िगरेशन को निर्दिष्ट करती है।

यहाँ एक साधारण पॉड YAML फ़ाइल का उदाहरण दिया गया है:

```yaml apiVersion: v1 kind: Pod metadata:

 name: my-pod
 labels:
   app: my-app

spec:

 containers:
 - name: my-container
   image: nginx:latest
   ports:
   - containerPort: 80

```

इस YAML फ़ाइल में:

  • `apiVersion: v1` कुबेरनेट्स API का संस्करण निर्दिष्ट करता है।
  • `kind: Pod` बताता है कि हम एक पॉड बना रहे हैं।
  • `metadata` पॉड के बारे में जानकारी प्रदान करता है, जैसे कि नाम और लेबल।
  • `spec` पॉड की वांछित स्थिति को परिभाषित करता है, जैसे कि कंटेनर और पोर्ट।

इस पॉड को बनाने के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं:

```bash kubectl apply -f my-pod.yaml ```

यह कमांड कुबेरनेट्स क्लस्टर पर पॉड को डिप्लॉय कर देगा।

पॉड का प्रबंधन

कुबेरनेट्स पॉड्स को प्रबंधित करने के लिए कई कमांड-लाइन उपकरण प्रदान करता है, जिनमें शामिल हैं:

  • **kubectl get pods:** क्लस्टर में सभी पॉड्स की सूची प्रदर्शित करता है।
  • **kubectl describe pod <पॉड का नाम>:** एक विशिष्ट पॉड के बारे में विस्तृत जानकारी प्रदर्शित करता है।
  • **kubectl delete pod <पॉड का नाम>:** एक विशिष्ट पॉड को हटाता है।
  • **kubectl logs <पॉड का नाम>:** एक विशिष्ट पॉड के कंटेनर के लॉग प्रदर्शित करता है।
  • **kubectl exec -it <पॉड का नाम> -- <कंटेनर का नाम> -- bash:** एक विशिष्ट पॉड के कंटेनर में एक शेल खोलता है।

पॉड्स और डिप्लोयमेंट्स

हालांकि आप सीधे पॉड्स बना सकते हैं, लेकिन आमतौर पर डिप्लॉयमेंट का उपयोग करके पॉड्स को प्रबंधित करना बेहतर होता है। एक डिप्लॉयमेंट पॉड्स के डिप्लॉयमेंट और अपडेट को स्वचालित करता है, और यह सुनिश्चित करता है कि एप्लिकेशन हमेशा उपलब्ध रहे।

डिप्लॉयमेंट पॉड्स की वांछित संख्या, अपडेट रणनीति, और अन्य कॉन्फ़िगरेशन को निर्दिष्ट करता है। यदि कोई पॉड विफल हो जाता है, तो डिप्लॉयमेंट स्वचालित रूप से एक नया पॉड बनाएगा।

यहाँ एक साधारण डिप्लॉयमेंट YAML फ़ाइल का उदाहरण दिया गया है:

```yaml apiVersion: apps/v1 kind: Deployment metadata:

 name: my-deployment
 labels:
   app: my-app

spec:

 replicas: 3
 selector:
   matchLabels:
     app: my-app
 template:
   metadata:
     labels:
       app: my-app
   spec:
     containers:
     - name: my-container
       image: nginx:latest
       ports:
       - containerPort: 80

```

इस YAML फ़ाइल में:

  • `apiVersion: apps/v1` कुबेरनेट्स API का संस्करण निर्दिष्ट करता है।
  • `kind: Deployment` बताता है कि हम एक डिप्लॉयमेंट बना रहे हैं।
  • `replicas: 3` निर्दिष्ट करता है कि हम 3 पॉड्स चाहते हैं।
  • `selector` डिप्लॉयमेंट द्वारा प्रबंधित किए जाने वाले पॉड्स को निर्दिष्ट करता है।
  • `template` पॉड के लिए एक टेम्पलेट प्रदान करता है।

इस डिप्लॉयमेंट को बनाने के लिए, आप निम्नलिखित कमांड का उपयोग कर सकते हैं:

```bash kubectl apply -f my-deployment.yaml ```

यह कमांड कुबेरनेट्स क्लस्टर पर डिप्लॉयमेंट को डिप्लॉय कर देगा, जो 3 पॉड्स बनाएगा।

पॉड्स और सर्विसेज

पॉड गतिशील होते हैं और उनका आईपी एड्रेस बदल सकता है। इसलिए, पॉड्स को सीधे एक्सेस करना मुश्किल हो सकता है। सर्विस एक स्थिर आईपी एड्रेस और DNS नाम प्रदान करके पॉड्स तक पहुंचने का एक तरीका प्रदान करता है।

एक सर्विस पॉड्स के एक समूह को एक ही इंटरफेस के पीछे उजागर करती है। यह लोड बैलेंसिंग और सर्विस डिस्कवरी जैसी सुविधाएँ भी प्रदान करता है।

पॉड स्वास्थ्य जांच

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

दो प्रकार की स्वास्थ्य जांच हैं:

  • **लाइवनेस जांच:** यह जांचती है कि पॉड अभी भी चल रहा है या नहीं।
  • **रेडीनेस जांच:** यह जांचती है कि पॉड ट्रैफ़िक स्वीकार करने के लिए तैयार है या नहीं।

पॉड्स के लिए संसाधन सीमाएं

आप पॉड्स के लिए संसाधन सीमाएं निर्दिष्ट कर सकते हैं, जैसे कि CPU और मेमोरी। यह सुनिश्चित करता है कि पॉड क्लस्टर के अन्य पॉड्स के संसाधनों का उपयोग न करें।

आप पॉड YAML फ़ाइल में `resources` फ़ील्ड का उपयोग करके संसाधन सीमाएं निर्दिष्ट कर सकते हैं।

पॉड्स के लिए लेबल और एनोटेशन

लेबल और एनोटेशन पॉड्स के बारे में अतिरिक्त जानकारी प्रदान करने का एक तरीका हैं। लेबल का उपयोग पॉड्स को व्यवस्थित करने और फ़िल्टर करने के लिए किया जाता है, जबकि एनोटेशन का उपयोग पॉड्स के बारे में गैर-पहचान योग्य जानकारी संग्रहीत करने के लिए किया जाता है।

आप पॉड YAML फ़ाइल में `metadata` फ़ील्ड में लेबल और एनोटेशन जोड़ सकते हैं।

निष्कर्ष

कुबेरनेट्स पॉड्स आधुनिक एप्लिकेशन डिप्लॉयमेंट और मैनेजमेंट के लिए एक शक्तिशाली उपकरण हैं। इस लेख में, हमने पॉड्स की अवधारणा, संरचना, प्रबंधन, और उपयोग के बारे में सीखा है। उम्मीद है कि यह जानकारी आपको कुबेरनेट्स के साथ शुरुआत करने में मदद करेगी।

कुबेरनेट्स, कंटेनर, डिप्लॉयमेंट, सर्विस, स्वास्थ्य जांच, लेबल, एनोटेशन, YAML, kubectl, स्केलेबिलिटी, पोर्टेबिलिटी, नेटवर्क नेमस्पेस, स्टोरेज वॉल्यूम, पॉड आईपी एड्रेस, पॉड मेटाडेटा, लाइवनेस जांच, रेडीनेस जांच, संसाधन सीमाएं, एकात्मकता, पुनरुत्पादकता

    • संबंधित रणनीतियाँ, तकनीकी विश्लेषण और वॉल्यूम विश्लेषण के लिए लिंक:**

अभी ट्रेडिंग शुरू करें

IQ Option पर रजिस्टर करें (न्यूनतम जमा $10) Pocket Option में खाता खोलें (न्यूनतम जमा $5)

हमारे समुदाय में शामिल हों

हमारे Telegram चैनल @strategybin से जुड़ें और प्राप्त करें: ✓ दैनिक ट्रेडिंग सिग्नल ✓ विशेष रणनीति विश्लेषण ✓ बाजार की प्रवृत्ति पर अलर्ट ✓ शुरुआती के लिए शिक्षण सामग्री

Баннер