ओपनशिफ्ट - डोकर और कुबेरनेट्स
ओपनशिफ्ट को डोकर और कुबेरनेट्स के शीर्ष पर बनाया गया है। सभी कंटेनरों को डोकर क्लस्टर के शीर्ष पर बनाया गया है, जो मूल रूप से कुबेरनेट्स ऑर्केस्ट्रेशन सुविधा का उपयोग करके लिनक्स मशीनों के शीर्ष पर कुबेरनेट्स सेवा है।
इस प्रक्रिया में, हम कुबेरनेट्स मास्टर का निर्माण करते हैं जो सभी नोड्स को नियंत्रित करता है और सभी नोड्स को कंटेनरों को तैनात करता है। कुबेरनेट्स का मुख्य कार्य विभिन्न प्रकार की कॉन्फ़िगरेशन फ़ाइल का उपयोग करके ओपनशिफ्ट क्लस्टर और परिनियोजन प्रवाह को नियंत्रित करना है। जैसे कि कुबेरनेट्स में, हम कुबेटल का उपयोग उसी तरह से करते हैं जैसे हम क्लस्टर नोड्स पर कंटेनरों के निर्माण और तैनाती के लिए ओसी कमांड लाइन उपयोगिता का उपयोग करते हैं।
क्लस्टर में विभिन्न प्रकार की वस्तुओं के निर्माण के लिए उपयोग की जाने वाली विभिन्न प्रकार की कॉन्फिग फाइल्स निम्नलिखित हैं।
- 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>
डॉकर और कुबेरनेट्स के साथ काम करने के तरीके के बारे में अधिक जानकारी के लिए, कृपया नीचे दिए गए लिंक कुबेरनेट का उपयोग करके हमारे कुबेरनेट ट्यूटोरियल पर जाएं ।