ओपनशिफ्ट - डोकर और कुबेरनेट्स

ओपनशिफ्ट को डोकर और कुबेरनेट्स के शीर्ष पर बनाया गया है। सभी कंटेनरों को डोकर क्लस्टर के शीर्ष पर बनाया गया है, जो मूल रूप से कुबेरनेट्स ऑर्केस्ट्रेशन सुविधा का उपयोग करके लिनक्स मशीनों के शीर्ष पर कुबेरनेट्स सेवा है।

इस प्रक्रिया में, हम कुबेरनेट्स मास्टर का निर्माण करते हैं जो सभी नोड्स को नियंत्रित करता है और सभी नोड्स को कंटेनरों को तैनात करता है। कुबेरनेट्स का मुख्य कार्य विभिन्न प्रकार की कॉन्फ़िगरेशन फ़ाइल का उपयोग करके ओपनशिफ्ट क्लस्टर और परिनियोजन प्रवाह को नियंत्रित करना है। जैसे कि कुबेरनेट्स में, हम कुबेटल का उपयोग उसी तरह से करते हैं जैसे हम क्लस्टर नोड्स पर कंटेनरों के निर्माण और तैनाती के लिए ओसी कमांड लाइन उपयोगिता का उपयोग करते हैं।

क्लस्टर में विभिन्न प्रकार की वस्तुओं के निर्माण के लिए उपयोग की जाने वाली विभिन्न प्रकार की कॉन्फिग फाइल्स निम्नलिखित हैं।

  • Images
  • POD
  • Service
  • प्रतिकृति नियंत्रक
  • प्रतिकृति सेट
  • Deployment

इमेजिस

Kubernetes (Docker) चित्र कंटेनरीकृत अवसंरचना के प्रमुख निर्माण खंड हैं। अब तक, कुबेरनेट केवल समर्थन करते हैंDockerइमेजिस। एक फली में प्रत्येक कंटेनर में उसके अंदर चलने वाली डॉकर छवि होती है।

apiVersion: v1
kind: pod
metadata:
   name: Tesing_for_Image_pull -----------> 1
   spec:
   containers:
- name: neo4j-server ------------------------> 2
image: <Name of the Docker image>----------> 3
imagePullPolicy: Always ------------->4
command: [“echo”, “SUCCESS”] -------------------> 5

पॉड

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

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
      image: tomcat: 8.0
      ports:
- containerPort: 7500
imagePullPolicy: Always

सर्विस

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

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   ports:
   - port: 8080
      targetPort: 31999

प्रतिकृति नियंत्रक

प्रतिकृति नियंत्रक कुबेरनेट्स की प्रमुख विशेषताओं में से एक है, जो फली जीवनचक्र के प्रबंधन के लिए जिम्मेदार है। यह सुनिश्चित करने के लिए ज़िम्मेदार है कि निर्दिष्ट संख्या में पॉड प्रतिकृतियां किसी भी समय चल रही हैं।

apiVersion: v1
kind: ReplicationController
metadata:
   name: Tomcat-ReplicationController
spec:
   replicas: 3
   template:
   metadata:
      name: Tomcat-ReplicationController
   labels:
      app: App
      component: neo4j
   spec:
      containers:
      - name: Tomcat
      image: tomcat: 8.0
      ports:
      - containerPort: 7474

प्रतिकृति सेट करें

प्रतिकृति सेट सुनिश्चित करता है कि फली की कितनी प्रतिकृति चल रही है। इसे प्रतिकृति नियंत्रक के प्रतिस्थापन के रूप में माना जा सकता है।

apiVersion: extensions/v1beta1
kind: ReplicaSet
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   selector:
      matchLables:
      tier: Backend
   matchExpression:
      - { key: tier, operation: In, values: [Backend]}
   
   app: App
   component: neo4j
spec:
   containers:
   - name: Tomcat-
image: tomcat: 8.0
   ports:
containerPort: 7474

तैनाती

नियुक्तियाँ प्रतिकृति नियंत्रक के उन्नत और उच्चतर संस्करण हैं। वे प्रतिकृति सेटों की तैनाती का प्रबंधन करते हैं, जो प्रतिकृति नियंत्रक का उन्नत संस्करण भी है। उनके पास प्रतिकृति सेट को अपडेट करने की क्षमता है और वे पिछले संस्करण में वापस रोल करने में भी सक्षम हैं।

apiVersion: extensions/v1beta1 --------------------->1
kind: Deployment --------------------------> 2
metadata:
   name: Tomcat-ReplicaSet
spec:
   replicas: 3
   template:
      metadata:
lables:
   app: Tomcat-ReplicaSet
   tier: Backend
spec:
   containers:
name: Tomcat-
   image: tomcat: 8.0
   ports:
   - containerPort: 7474

सभी कॉन्फिग फाइल का उपयोग उनकी संबंधित कुबेरनेट वस्तुओं को बनाने के लिए किया जा सकता है।

$ Kubectl create –f <file name>.yaml

कुबेरनेट वस्तुओं का विवरण और विवरण जानने के लिए निम्नलिखित आदेशों का उपयोग किया जा सकता है।

For POD

$ Kubectl get pod <pod name>
$ kubectl delete pod <pod name>
$ kubectl describe pod <pod name>

For Replication Controller

$ Kubectl get rc <rc name>
$ kubectl delete rc <rc name>
$ kubectl describe rc <rc name>

For Service

$ Kubectl get svc <svc name>
$ kubectl delete svc <svc name>
$ kubectl describe svc <svc name>

डॉकर और कुबेरनेट्स के साथ काम करने के तरीके के बारे में अधिक जानकारी के लिए, कृपया नीचे दिए गए लिंक कुबेरनेट का उपयोग करके हमारे कुबेरनेट ट्यूटोरियल पर जाएं ।