कुबेरनेट्स - त्वरित गाइड

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

कुबेरनेट्स में तैनाती को स्वचालित करने की क्षमता, अनुप्रयोग के स्केलिंग, और समूहों में अनुप्रयोग कंटेनरों के संचालन की क्षमता है। यह कंटेनर केंद्रित बुनियादी ढांचा बनाने में सक्षम है।

कुबेरनेट्स की विशेषताएं

कुबेरनेट की कुछ महत्वपूर्ण विशेषताएं निम्नलिखित हैं।

  • विकास, एकीकरण और तैनाती को जारी रखता है

  • कंटेनरीकृत अवसंरचना

  • अनुप्रयोग-केंद्रित प्रबंधन

  • ऑटो-स्केलेबल इंफ्रास्ट्रक्चर

  • विकास परीक्षण और उत्पादन में पर्यावरणीय स्थिरता

  • ढीली युग्मित अवसंरचना, जहां प्रत्येक घटक एक अलग इकाई के रूप में कार्य कर सकता है

  • संसाधन उपयोग का उच्च घनत्व

  • प्रिडिक्टेबल इंफ्रास्ट्रक्चर जो बनने जा रहा है

कुबेरनेट्स के प्रमुख घटकों में से एक है, यह भौतिक और आभासी मशीन अवसंरचना के समूहों पर आवेदन चला सकता है। यह क्लाउड पर एप्लिकेशन चलाने की क्षमता भी रखता है।It helps in moving from host-centric infrastructure to container-centric infrastructure.

इस अध्याय में, हम कुबेरनेट्स की बुनियादी वास्तुकला पर चर्चा करेंगे।

कुबेरनेट्स - क्लस्टर वास्तुकला

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

मास्टर और नोड के प्रमुख घटक निम्नलिखित अनुभाग में परिभाषित किए गए हैं।

कुबेरनेट्स - मास्टर मशीन घटक

कुबेरनेट्स मास्टर मशीन के घटक निम्नलिखित हैं।

etcd

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

एपीआई सर्वर

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

नियंत्रक प्रबंधक

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

समयबद्धक

यह कुबेरनेट्स मास्टर के प्रमुख घटकों में से एक है। यह वर्कलोड को वितरित करने के लिए जिम्मेदार मास्टर में एक सेवा है। यह क्लस्टर नोड्स पर काम के भार के उपयोग पर नज़र रखने और फिर काम का बोझ रखने के लिए जिम्मेदार है, जिस पर संसाधन उपलब्ध हैं और कार्यभार स्वीकार करते हैं। दूसरे शब्दों में, यह नोड्स को उपलब्ध नोड्स को आवंटित करने के लिए जिम्मेदार है। शेड्यूलर कार्यभार के उपयोग और फली को नए नोड को आवंटित करने के लिए जिम्मेदार है।

कुबेरनेट्स - नोड घटक

निम्नलिखित नोड सर्वर के प्रमुख घटक हैं जो कुबेरनेट्स मास्टर के साथ संवाद करने के लिए आवश्यक हैं।

डाक में काम करनेवाला मज़दूर

प्रत्येक नोड की पहली आवश्यकता डॉकर है जो अपेक्षाकृत पृथक लेकिन हल्के ऑपरेटिंग वातावरण में इनकैप्सुलेटेड एप्लिकेशन कंटेनरों को चलाने में मदद करता है।

क्यूबलेट सेवा

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

Kubernetes प्रॉक्सी सेवा

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

कुबेरनेट्स - मास्टर और नोड संरचना

निम्नलिखित चित्र कुबेरनेट्स मास्टर और नोड की संरचना को दर्शाते हैं।

कुबेरनेट्स स्थापित करने से पहले वर्चुअल डाटासेंटर (वीडीसी) स्थापित करना महत्वपूर्ण है। इसे मशीनों के एक सेट के रूप में माना जा सकता है जहां वे नेटवर्क के माध्यम से एक दूसरे के साथ संवाद कर सकते हैं। हाथों के दृष्टिकोण के लिए, आप vDC को चालू कर सकते हैंPROFITBRICKS यदि आपके पास भौतिक या क्लाउड इन्फ्रास्ट्रक्चर स्थापित नहीं है।

एक बार किसी भी क्लाउड पर IaaS सेटअप पूरा हो जाने के बाद, आपको कॉन्फ़िगर करने की आवश्यकता है Master और यह Node

Note- सेटअप को उबंटू मशीनों के लिए दिखाया गया है। इसे अन्य लिनक्स मशीनों पर भी स्थापित किया जा सकता है।

आवश्यक शर्तें

Installing Docker- कुबेरनेट्स के सभी उदाहरणों पर डॉकर की आवश्यकता है। निम्नलिखित डॉकर को स्थापित करने के चरण हैं।

Step 1 - रूट यूजर अकाउंट के साथ मशीन पर लॉग ऑन करें।

Step 2- पैकेज की जानकारी अपडेट करें। सुनिश्चित करें कि उपयुक्त पैकेज काम कर रहा है।

Step 3 - निम्नलिखित कमांड चलाएँ।

$ sudo apt-get update $ sudo apt-get install apt-transport-https ca-certificates

Step 4 - नई GPG कुंजी जोड़ें।

$ sudo apt-key adv \ --keyserver hkp://ha.pool.sks-keyservers.net:80 \ --recv-keys 58118E89F3A912897C070ADBF76221572C52609D $ echo "deb https://apt.dockerproject.org/repo ubuntu-trusty main" | sudo tee
/etc/apt/sources.list.d/docker.list

Step 5 - एपीआई पैकेज छवि को अपडेट करें।

$ sudo apt-get update

एक बार जब उपरोक्त सभी कार्य पूरे हो जाएंगे, तो आप डॉक इंजन की वास्तविक स्थापना के साथ शुरू कर सकते हैं। हालाँकि, इससे पहले आपको यह सत्यापित करने की आवश्यकता है कि आपके द्वारा उपयोग किया जा रहा कर्नेल संस्करण सही है।

डॉकर इंजन स्थापित करें

डॉकर इंजन को स्थापित करने के लिए निम्न कमांड चलाएँ।

Step 1 - मशीन के लिए लॉगऑन।

Step 2 - पैकेज इंडेक्स अपडेट करें।

$ sudo apt-get update

Step 3 - निम्नलिखित कमांड का उपयोग करके डॉकर इंजन स्थापित करें।

$ sudo apt-get install docker-engine

Step 4 - डॉकर डेमॉन की शुरुआत करें।

$ sudo apt-get install docker-engine

Step 5 - बहुत अगर डॉकटर स्थापित हो, तो निम्न कमांड का उपयोग करें।

$ sudo docker run hello-world

2.0 स्थापित करें

कुबेरनेट्स मास्टर मशीन पर इसे स्थापित करने की आवश्यकता है। इसे स्थापित करने के लिए, निम्न कमांड चलाएं।

$ curl -L https://github.com/coreos/etcd/releases/download/v2.0.0/etcd
-v2.0.0-linux-amd64.tar.gz -o etcd-v2.0.0-linux-amd64.tar.gz ->1
$ tar xzvf etcd-v2.0.0-linux-amd64.tar.gz ------>2 $ cd etcd-v2.0.0-linux-amd64 ------------>3
$ mkdir /opt/bin ------------->4 $ cp etcd* /opt/bin ----------->5

कमांड के उपरोक्त सेट में -

  • सबसे पहले, हम डाउनलोड करते हैं etcd। इसे निर्दिष्ट नाम से सहेजें।
  • फिर, हमें टार पैकेज को अन-टार करना होगा।
  • हम एक डायर बनाते हैं। अंदर / ऑप्ट नाम बिन।
  • निकाले गए फ़ाइल को लक्ष्य स्थान पर कॉपी करें।

अब हम कुबेरनेट बनाने के लिए तैयार हैं। हमें क्लस्टर पर सभी मशीनों पर कुबेरनेट्स स्थापित करने की आवश्यकता है।

$ git clone https://github.com/GoogleCloudPlatform/kubernetes.git $ cd kubernetes
$ make release

उपरोक्त कमांड एक बना देगा _outputkubernetes फ़ोल्डर की जड़ में dir। इसके बाद, हम अपनी पसंद / ऑप्ट / बिन, आदि में से किसी भी निर्देशिका में निर्देशिका निकाल सकते हैं।

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

$ echo "<IP address of master machine> kube-master
< IP address of Node Machine>" >> /etc/hosts

निम्नलिखित उपरोक्त कमांड का आउटपुट होगा।

अब, हम कुबेरनेट्स मास्टर पर वास्तविक कॉन्फ़िगरेशन के साथ शुरू करेंगे।

सबसे पहले, हम सभी कॉन्फ़िगरेशन फ़ाइलों को उनके सही स्थान पर कॉपी करना शुरू करेंगे।

$ cp <Current dir. location>/kube-apiserver /opt/bin/ $ cp <Current dir. location>/kube-controller-manager /opt/bin/
$ cp <Current dir. location>/kube-kube-scheduler /opt/bin/ $ cp <Current dir. location>/kubecfg /opt/bin/
$ cp <Current dir. location>/kubectl /opt/bin/ $ cp <Current dir. location>/kubernetes /opt/bin/

उपरोक्त कमांड सभी कॉन्फ़िगरेशन फ़ाइलों को आवश्यक स्थान पर कॉपी करेगा। अब हम उसी निर्देशिका में वापस आएँगे जहाँ हमने Kubernetes फ़ोल्डर बनाया है।

$ cp kubernetes/cluster/ubuntu/init_conf/kube-apiserver.conf /etc/init/ $ cp kubernetes/cluster/ubuntu/init_conf/kube-controller-manager.conf /etc/init/
$ cp kubernetes/cluster/ubuntu/init_conf/kube-kube-scheduler.conf /etc/init/ $ cp kubernetes/cluster/ubuntu/initd_scripts/kube-apiserver /etc/init.d/
$ cp kubernetes/cluster/ubuntu/initd_scripts/kube-controller-manager /etc/init.d/ $ cp kubernetes/cluster/ubuntu/initd_scripts/kube-kube-scheduler /etc/init.d/

$ cp kubernetes/cluster/ubuntu/default_scripts/kubelet /etc/default/ $ cp kubernetes/cluster/ubuntu/default_scripts/kube-proxy /etc/default/
$ cp kubernetes/cluster/ubuntu/default_scripts/kubelet /etc/default/

अगला चरण कॉपी की गई कॉन्फ़िगरेशन फ़ाइल को / etc के तहत अपडेट करना है। dir।

निम्न आदेश का उपयोग करके मास्टर पर कॉन्फ़िगर कॉन्फ़िगर करें।

$ ETCD_OPTS = "-listen-client-urls = http://kube-master:4001"

कॉन्फ़िगर करें क्यूब-अपीज़र

इसके लिए गुरु पर, हमें संपादित करने की आवश्यकता है /etc/default/kube-apiserver फ़ाइल जिसे हमने पहले कॉपी किया था।

$ KUBE_APISERVER_OPTS = "--address = 0.0.0.0 \
--port = 8080 \
--etcd_servers = <The path that is configured in ETCD_OPTS> \
--portal_net = 11.1.1.0/24 \
--allow_privileged = false \
--kubelet_port = < Port you want to configure> \
--v = 0"

क्यूब नियंत्रक प्रबंधक को कॉन्फ़िगर करें

हमें निम्नलिखित सामग्री को इसमें जोड़ना होगा /etc/default/kube-controller-manager

$ KUBE_CONTROLLER_MANAGER_OPTS = "--address = 0.0.0.0 \
--master = 127.0.0.1:8080 \
--machines = kube-minion \ -----> #this is the kubernatics node
--v = 0

इसके बाद, संबंधित फ़ाइल में क्यूब अनुसूचक को कॉन्फ़िगर करें।

$ KUBE_SCHEDULER_OPTS = "--address = 0.0.0.0 \
--master = 127.0.0.1:8080 \
--v = 0"

एक बार उपरोक्त सभी कार्य पूरे हो जाने के बाद, कुबेरनेट्स मास्टर को आगे लाकर हम आगे बढ़ सकते हैं। ऐसा करने के लिए, हम डॉकर को पुनः आरंभ करेंगे।

$ service docker restart

कुबेरनेट्स नोड कॉन्फ़िगरेशन

कुबेरनेट्स नोड दो सेवाएं चलाएगा kubelet and the kube-proxy। आगे बढ़ने से पहले, हमें उन आवश्यक फ़ोल्डर में डाउनलोड किए गए बायनेरिज़ को कॉपी करने की आवश्यकता है जहां हम कुबेरनेट्स नोड को कॉन्फ़िगर करना चाहते हैं।

फ़ाइलों की प्रतिलिपि बनाने की उसी विधि का उपयोग करें जो हमने कुबेरनेट्स मास्टर के लिए किया था। चूंकि यह केवल क्यूबलेट और क्यूब-प्रॉक्सी चलाएगा, हम उन्हें कॉन्फ़िगर करेंगे।

$ cp <Path of the extracted file>/kubelet /opt/bin/ $ cp <Path of the extracted file>/kube-proxy /opt/bin/
$ cp <Path of the extracted file>/kubecfg /opt/bin/ $ cp <Path of the extracted file>/kubectl /opt/bin/
$ cp <Path of the extracted file>/kubernetes /opt/bin/

अब, हम सामग्री को उपयुक्त डायर पर कॉपी करेंगे।

$ cp kubernetes/cluster/ubuntu/init_conf/kubelet.conf /etc/init/
$ cp kubernetes/cluster/ubuntu/init_conf/kube-proxy.conf /etc/init/ $ cp kubernetes/cluster/ubuntu/initd_scripts/kubelet /etc/init.d/
$ cp kubernetes/cluster/ubuntu/initd_scripts/kube-proxy /etc/init.d/ $ cp kubernetes/cluster/ubuntu/default_scripts/kubelet /etc/default/
$ cp kubernetes/cluster/ubuntu/default_scripts/kube-proxy /etc/default/

हम कॉन्फ़िगर करेंगे kubelet तथा kube-proxy conf फ़ाइलें।

हम कॉन्फ़िगर करेंगे /etc/init/kubelet.conf

$ KUBELET_OPTS = "--address = 0.0.0.0 \
--port = 10250 \
--hostname_override = kube-minion \
--etcd_servers = http://kube-master:4001 \
--enable_server = true
--v = 0"
/

क्यूब-प्रॉक्सी के लिए, हम निम्नलिखित कमांड का उपयोग करके कॉन्फ़िगर करेंगे।

$ KUBE_PROXY_OPTS = "--etcd_servers = http://kube-master:4001 \
--v = 0"
/etc/init/kube-proxy.conf

अंत में, हम डॉकर सेवा को फिर से शुरू करेंगे।

$ service docker restart

अब हम कॉन्फ़िगरेशन के साथ कर रहे हैं। आप निम्न कमांड चलाकर जांच कर सकते हैं।

$ /opt/bin/kubectl get minions

Kubernetes (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"] ------------------->

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

  • name: Tesing_for_Image_pull - यह नाम उस डॉकटर रजिस्ट्री से छवियों को खींचने के बाद बनने वाले कंटेनर का नाम क्या है, इसकी पहचान करने और जांचने के लिए दिया गया है।

  • name: neo4j-server- यह कंटेनर को दिया गया नाम है जिसे हम बनाने की कोशिश कर रहे हैं। जैसे हमने neo4j-server दिया है।

  • image: <Name of the Docker image>- यह उस छवि का नाम है जिसे हम छवियों की डॉकर या आंतरिक रजिस्ट्री से खींचने की कोशिश कर रहे हैं। हमें उस छवि नाम के साथ एक पूर्ण रजिस्ट्री पथ को परिभाषित करने की आवश्यकता है जिसे हम खींचने की कोशिश कर रहे हैं।

  • imagePullPolicy - हमेशा - यह इमेज पुल पॉलिसी यह परिभाषित करती है कि जब भी हम कंटेनर बनाने के लिए इस फाइल को चलाएंगे, यह फिर से उसी नाम को खींच लेगा।

  • command: [“echo”, “SUCCESS”] - इसके साथ, जब हम कंटेनर बनाते हैं और अगर सब कुछ ठीक हो जाता है, तो यह एक संदेश प्रदर्शित करेगा जब हम कंटेनर तक पहुंचेंगे।

छवि को खींचने और एक कंटेनर बनाने के लिए, हम निम्नलिखित कमांड चलाएंगे।

$ kubectl create –f Tesing_for_Image_pull

एक बार जब हम लॉग लाएंगे, तो हम आउटपुट को सफल के रूप में प्राप्त करेंगे।

$ kubectl log Tesing_for_Image_pull

उपरोक्त आदेश सफलता का आउटपुट उत्पन्न करेगा या हमें विफलता के रूप में आउटपुट मिलेगा।

Note - यह अनुशंसा की जाती है कि आप सभी आदेशों को स्वयं आज़माएं।

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

नौकरी पैदा करना

नौकरी बनाने के लिए निम्नलिखित कमांड का उपयोग करें -

apiVersion: v1
kind: Job ------------------------> 1
metadata:
   name: py
   spec:
   template:
      metadata
      name: py -------> 2
      spec:
         containers:
            - name: py ------------------------> 3
            image: python----------> 4
            command: ["python", "SUCCESS"]
            restartPocliy: Never --------> 5

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

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

  • Name:py → यह उस टेम्पलेट का नाम है जिसका हम उपयोग कर रहे हैं और कल्पना टेम्पलेट को परिभाषित करती है।

  • name: py → हमने एक नाम दिया है py कंटेनर स्पेक के तहत जो पॉड की पहचान करने में मदद करता है जो इससे बाहर निकलने वाला है।

  • Image: python → वह छवि जिसे हम कंटेनर बनाने के लिए खींचने जा रहे हैं जो फली के अंदर चलेगा।

  • restartPolicy: Never →छवि पुनरारंभ की यह शर्त कभी नहीं दी जाती है जिसका अर्थ है कि यदि कंटेनर को मार दिया गया है या यदि यह गलत है, तो यह स्वयं को पुनरारंभ नहीं करेगा।

हम yaml के साथ निम्नलिखित कमांड का उपयोग करके कार्य बनाएंगे जिसे नाम के साथ सहेजा गया है py.yaml

$ kubectl create –f py.yaml

उपरोक्त कमांड एक नौकरी पैदा करेगा। यदि आप नौकरी की स्थिति की जांच करना चाहते हैं, तो निम्न कमांड का उपयोग करें।

$ kubectl describe jobs/py

उपरोक्त कमांड एक नौकरी पैदा करेगा। यदि आप नौकरी की स्थिति की जांच करना चाहते हैं, तो निम्न कमांड का उपयोग करें।

अनुसूचित नौकरी

कुबेरनेट्स में अनुसूचित नौकरी का उपयोग करता है Cronetes, जो कुबेरनेट्स नौकरी लेता है और उन्हें कुबेरनेट क्लस्टर में लॉन्च करता है।

  • एक समयबद्धन एक निर्दिष्ट समय पर एक पॉड चलाएगा।
  • इसके लिए एक पैरोडिक जॉब बनाई जाती है जो अपने आप ही इनवॉइस करती है।

Note - अनुसूचित नौकरी की सुविधा संस्करण 1.4 द्वारा समर्थित है और betch / v2alpha 1 API को पास करके चालू किया गया है –runtime-config=batch/v2alpha1 API सर्वर लाते समय।

हम उसी yaml का उपयोग करेंगे जिसका उपयोग हम नौकरी बनाने के लिए करते हैं और इसे एक निर्धारित कार्य बनाते हैं।

apiVersion: v1
kind: Job
metadata:
   name: py
spec:
   schedule: h/30 * * * * ? -------------------> 1
   template:
      metadata
         name: py
      spec:
         containers:
         - name: py
         image: python
         args:
/bin/sh -------> 2
-c
ps –eaf ------------> 3
restartPocliy: OnFailure

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

  • schedule: h/30 * * * * ? → नौकरी को हर 30 मिनट में चलाने के लिए शेड्यूल करें।

  • /bin/sh: यह कंटेनर में / बिन / श के साथ प्रवेश करेगा

  • ps –eaf → मशीन पर ps -eaf कमांड चलाएगा और एक कंटेनर के अंदर सभी चल रही प्रक्रिया को सूचीबद्ध करेगा।

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

लेबल

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

चयनकर्ताओं

लेबल विशिष्टता प्रदान नहीं करते हैं। सामान्य तौर पर, हम कह सकते हैं कि कई ऑब्जेक्ट समान लेबल ले जा सकते हैं। लेबल चयनकर्ता कुबेरनेट्स में कोर ग्रुपिंग आदिम हैं। उनका उपयोग उपयोगकर्ताओं द्वारा वस्तुओं के एक सेट का चयन करने के लिए किया जाता है।

कुबेरनेट्स एपीआई वर्तमान में दो प्रकार के चयनकर्ताओं का समर्थन करता है -

  • समानता-आधारित चयनकर्ता
  • सेट-आधारित चयनकर्ता

समानता-आधारित चयनकर्ता

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

सेट-आधारित चयनकर्ता

सेट-आधारित चयनकर्ता मानों के एक सेट के अनुसार कुंजी को फ़िल्टर करने की अनुमति देते हैं।

apiVersion: v1
kind: Service
metadata:
   name: sp-neo4j-standalone
spec:
   ports:
      - port: 7474
      name: neo4j
   type: NodePort
   selector:
      app: salesplatform ---------> 1
      component: neo4j -----------> 2

उपरोक्त कोड में, हम लेबल चयनकर्ता का उपयोग कर रहे हैं app: salesplatform और घटक के रूप में component: neo4j

एक बार जब हम फ़ाइल का उपयोग करते हैं kubectl कमांड, यह नाम के साथ एक सेवा बनाएगा sp-neo4j-standalone जो पोर्ट 7474 पर संचार करेगा। ype है NodePort नए लेबल चयनकर्ता के साथ के रूप में app: salesplatform तथा component: neo4j

Namespace संसाधन नाम के लिए एक अतिरिक्त योग्यता प्रदान करता है। यह तब मददगार होता है जब कई टीमें एक ही क्लस्टर का उपयोग कर रही हों और नाम की टक्कर की संभावना हो। यह कई समूहों के बीच एक आभासी दीवार के रूप में हो सकता है।

नेमस्पेस की कार्यक्षमता

कुबेरनेट्स में एक नेमस्पेस के कुछ महत्वपूर्ण कार्य निम्नलिखित हैं -

  • Namespaces समान नामस्थान का उपयोग करके पॉड-टू-पॉड संचार में मदद करते हैं।

  • नाम स्थान आभासी क्लस्टर हैं जो एक ही भौतिक क्लस्टर के शीर्ष पर बैठ सकते हैं।

  • वे टीमों और उनके वातावरण के बीच तार्किक अलगाव प्रदान करते हैं।

एक नाम स्थान बनाएँ

नेमस्पेस बनाने के लिए निम्न कमांड का उपयोग किया जाता है।

apiVersion: v1
kind: Namespce
metadata
   name: elk

नेमस्पेस को नियंत्रित करें

नेमस्पेस को नियंत्रित करने के लिए निम्न कमांड का उपयोग किया जाता है।

$ kubectl create –f namespace.yml ---------> 1
$ kubectl get namespace -----------------> 2 $ kubectl get namespace <Namespace name> ------->3
$ kubectl describe namespace <Namespace name> ---->4 $ kubectl delete namespace <Namespace name>

उपरोक्त कोड में,

  • हम एक नाम स्थान बनाने के लिए कमांड का उपयोग कर रहे हैं।
  • यह सभी उपलब्ध नामस्थानों को सूचीबद्ध करेगा।
  • यह एक विशेष नामस्थान मिलेगा जिसका नाम कमांड में निर्दिष्ट है।
  • यह सेवा के बारे में संपूर्ण विवरण का वर्णन करेगा।
  • यह क्लस्टर में मौजूद एक विशेष नामस्थान को हटा देगा।

सेवा में नाम स्थान का उपयोग करना - उदाहरण

सेवा में नाम स्थान का उपयोग करने के लिए नमूना फ़ाइल का एक उदाहरण निम्नलिखित है।

apiVersion: v1
kind: Service
metadata:
   name: elasticsearch
   namespace: elk
   labels:
      component: elasticsearch
spec:
   type: LoadBalancer
   selector:
      component: elasticsearch
   ports:
   - name: http
      port: 9200
      protocol: TCP
   - name: transport
      port: 9300
      protocol: TCP

उपरोक्त कोड में, हम नाम के साथ सेवा मेटाडेटा के तहत समान नाम स्थान का उपयोग कर रहे हैं elk

एक नोड Kubernetes क्लस्टर में एक कामकाजी मशीन है जिसे मिनियन के रूप में भी जाना जाता है। वे कामकाजी इकाइयाँ हैं जो भौतिक, वीएम या एक बादल उदाहरण हो सकती हैं।

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

वे कुबेरनेट्स द्वारा नहीं बनाए गए हैं, लेकिन वे बाहरी रूप से क्लाउड सेवा प्रदाता या भौतिक या वीएम मशीनों पर कुबेरनेट क्लस्टर प्रबंधक द्वारा बनाए गए हैं।

कई नोड्स को संभालने के लिए कुबेरनेट्स का प्रमुख घटक नियंत्रक प्रबंधक है, जो नोड्स को प्रबंधित करने के लिए कई प्रकार के नियंत्रक चलाता है। नोड्स का प्रबंधन करने के लिए, कुबेरनेट्स एक प्रकार का नोड बनाता है जो कि मान्य करेगा कि बनाई गई वस्तु एक वैध नोड है।

चयनकर्ता के साथ सेवा

apiVersion: v1
kind: node
metadata:
   name: < ip address of the node>
   labels:
      name: <lable name>

JSON फॉर्मेट में वास्तविक ऑब्जेक्ट बनाया जाता है जो निम्नानुसार दिखता है -

{
   Kind: node
   apiVersion: v1
   "metadata": 
   {
      "name": "10.01.1.10",
      "labels"
      {
         "name": "cluster 1 node"
      }
   }
}

नोड नियंत्रक

वे सेवाओं का संग्रह हैं जो कुबेरनेट्स मास्टर में चलते हैं और मेटाडेटा.नाम के आधार पर क्लस्टर में नोड की निरंतर निगरानी करते हैं। यदि सभी आवश्यक सेवाएं चल रही हैं, तो नोड को मान्य किया जाता है और नियंत्रक द्वारा एक नया बनाया पॉड उस नोड को सौंपा जाएगा। यदि यह मान्य नहीं है, तो स्वामी इसके लिए कोई पॉड नहीं देगा और तब तक प्रतीक्षा करेगा जब तक कि यह वैध न हो जाए।

कुबेरनेट्स मास्टर नोड को स्वचालित रूप से पंजीकृत करता है, यदि –register-node झंडा सच है।

–register-node = true

हालाँकि, यदि क्लस्टर व्यवस्थापक इसे मैन्युअल रूप से प्रबंधित करना चाहता है, तो इसे - के फ्लैट को मोड़कर किया जा सकता है

–register-node = false

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

एक सेवा Kubernetes में REST ऑब्जेक्ट है जिसकी परिभाषा को Kubernetes apiServer पर Kubernetes मास्टर पर एक नया उदाहरण बनाने के लिए पोस्ट किया जा सकता है।

चयनकर्ता के बिना सेवा

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

उपरोक्त कॉन्फ़िगरेशन Tutorial_point_service नाम के साथ एक सेवा बनाएगा।

सेवा विन्यास फाइल चयनकर्ता के साथ

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   selector:
      application: "My Application" -------------------> (Selector)
   ports:
   - port: 8080
   targetPort: 31999

इस उदाहरण में, हमारे पास एक चयनकर्ता है; इसलिए ट्रैफ़िक स्थानांतरित करने के लिए, हमें मैन्युअल रूप से एक समापन बिंदु बनाने की आवश्यकता है।

apiVersion: v1
kind: Endpoints
metadata:
   name: Tutorial_point_service
subnets:
   address:
      "ip": "192.168.168.40" -------------------> (Selector)
   ports:
      - port: 8080

उपरोक्त कोड में, हमने एक एंडपॉइंट बनाया है जो ट्रैफिक को "192.168.168.40:8080" के रूप में परिभाषित समापन बिंदु तक ले जाएगा।

मल्टी-पोर्ट सर्विस क्रिएशन

apiVersion: v1
kind: Service
metadata:
   name: Tutorial_point_service
spec:
   selector:
      application: “My Application” -------------------> (Selector)
   ClusterIP: 10.3.0.12
   ports:
      -name: http
      protocol: TCP
      port: 80
      targetPort: 31999
   -name:https
      Protocol: TCP
      Port: 443
      targetPort: 31998

सेवाओं के प्रकार

ClusterIP- यह क्लस्टर के भीतर सेवा को प्रतिबंधित करने में मदद करता है। यह परिभाषित कुबेरनेट क्लस्टर के भीतर सेवा को उजागर करता है।

spec:
   type: NodePort
   ports:
   - port: 8080
      nodePort: 31999
      name: NodeportService

NodePort- यह तैनात नोड पर एक स्थिर पोर्ट पर सेवा को उजागर करेगा। एClusterIP सेवा, जो करने के लिए NodePortसेवा मार्ग, स्वचालित रूप से बनाया जाता है। इस सेवा का उपयोग क्लस्टर के बाहर से किया जा सकता हैNodeIP:nodePort

spec:
   ports:
   - port: 8080
      nodePort: 31999
      name: NodeportService
      clusterIP: 10.20.30.40

Load Balancer - इसमें क्लाउड प्रोवाइडर्स के लोड बैलेंसर का इस्तेमाल किया गया है। NodePort तथा ClusterIP सेवाओं को स्वचालित रूप से बनाया जाता है जिससे बाहरी लोड बैलेंसर रूट हो जाएगा।

एक पूर्ण सेवा yamlनोड पोर्ट के रूप में सेवा प्रकार के साथ फ़ाइल। खुद को बनाने की कोशिश करें।

apiVersion: v1
kind: Service
metadata:
   name: appname
   labels:
      k8s-app: appname
spec:
   type: NodePort
   ports:
   - port: 8080
      nodePort: 31999
      name: omninginx
   selector:
      k8s-app: appname
      component: nginx
      env: env_name

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

फली के प्रकार

दो प्रकार के पॉड हैं -

  • एकल कंटेनर फली
  • मल्टी कंटेनर फली

एकल कंटेनर फली

वे केवल कुबेटल रन कमांड के साथ बनाए जा सकते हैं, जहां आपके पास डॉकर रजिस्ट्री पर एक परिभाषित छवि है जिसे हम एक पॉड बनाते समय खींचेंगे।

$ kubectl run <name of pod> --image=<name of the image from registry>

Example - हम एक टॉमकट इमेज के साथ एक पॉड बनाएंगे जो डॉकर हब पर उपलब्ध है।

$ kubectl run tomcat --image = tomcat:8.0

यह भी बनाकर किया जा सकता है yaml फ़ाइल और फिर चल रहा है kubectl create आदेश।

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

एक बार ऊपर yaml फ़ाइल बनाई गई है, हम फ़ाइल को नाम के साथ सहेजेंगे tomcat.yml और दस्तावेज़ को चलाने के लिए कमांड बनाएँ।

$ kubectl create –f tomcat.yml

यह टॉमकैट के नाम से एक फली बनाएगा। हम वर्णन कमांड का उपयोग कर सकते हैंkubectl फली का वर्णन करने के लिए।

मल्टी कंटेनर पॉड

मल्टी कंटेनर पॉड का उपयोग करके बनाया जाता है yaml mail कंटेनरों की परिभाषा के साथ।

apiVersion: v1
kind: Pod
metadata:
   name: Tomcat
spec:
   containers:
   - name: Tomcat
    image: tomcat: 8.0
    ports:
containerPort: 7500
   imagePullPolicy: Always
   -name: Database
   Image: mongoDB
   Ports:
containerPort: 7501
   imagePullPolicy: Always

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

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

बार-बार फली बनाने के बजाय फली जीवन चक्र का प्रबंधन करने के लिए प्रतिकृति नियंत्रक का उपयोग करना सबसे अच्छा अभ्यास है।

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

सेटअप विवरण

  • Kind: ReplicationController → उपरोक्त कोड में, हमने प्रतिकृति नियंत्रक के रूप में उस प्रकार को परिभाषित किया है जो बताता है kubectl कि yaml प्रतिकृति नियंत्रक बनाने के लिए फ़ाइल का उपयोग किया जा रहा है।

  • name: Tomcat-ReplicationController→ यह उस नाम की पहचान करने में मदद करता है जिसके साथ प्रतिकृति नियंत्रक बनाया जाएगा। यदि हम कुबेटल चलाते हैं, तो प्राप्त करेंrc < Tomcat-ReplicationController > यह प्रतिकृति नियंत्रक विवरण दिखाएगा।

  • replicas: 3 → यह प्रतिकृति नियंत्रक को यह समझने में मदद करता है कि उसे पॉड जीवनचक्र में किसी भी समय एक पॉड के तीन प्रतिकृतियों को बनाए रखने की आवश्यकता है।

  • name: Tomcat → स्पेक सेक्शन में, हमने नाम को tomcat के रूप में परिभाषित किया है जो प्रतिकृति नियंत्रक को बताएगा कि फली के अंदर मौजूद कंटेनर tomcat है।

  • containerPort: 7474 → यह सुनिश्चित करने में मदद करता है कि फली के सभी नोड्स जहाँ फली के अंदर कंटेनर चल रहा है, उसी पोर्ट 7474 पर सामने आएंगे।

यहां, कुबेरनेट्स सेवा तीन टॉमकैट प्रतिकृतियों के लिए एक लोड बैलेंसर के रूप में काम कर रही है।

प्रतिकृति सेट सुनिश्चित करता है कि फली की कितनी प्रतिकृति होनी चाहिए। इसे प्रतिकृति नियंत्रक के प्रतिस्थापन के रूप में माना जा सकता है। प्रतिकृति सेट और प्रतिकृति नियंत्रक के बीच महत्वपूर्ण अंतर है, प्रतिकृति नियंत्रक केवल समानता-आधारित चयनकर्ता का समर्थन करता है जबकि प्रतिकृति सेट-आधारित चयनकर्ता का समर्थन करता है।

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

सेटअप विवरण

  • apiVersion: extensions/v1beta1 → उपरोक्त कोड में, एपीआई संस्करण कुबेरनेट्स का उन्नत बीटा संस्करण है जो प्रतिकृति सेट की अवधारणा का समर्थन करता है।

  • kind: ReplicaSet → हमने प्रतिकृति सेट के रूप में उस प्रकार को परिभाषित किया है जो कुब्लेट को यह समझने में मदद करता है कि फ़ाइल का उपयोग प्रतिकृति सेट बनाने के लिए किया जाता है।

  • tier: Backend → हमने लेबल टियर को बैकएंड के रूप में परिभाषित किया है जो एक मिलान चयनकर्ता बनाता है।

  • {key: tier, operation: In, values: [Backend]} → यह मदद करेगा matchExpression मिलान स्थिति को समझने के लिए जिसे हमने परिभाषित किया है और जो ऑपरेशन में उपयोग किया जाता है matchlabel विवरण खोजने के लिए।

उपरोक्त फ़ाइल का उपयोग करके चलाएँ kubectl और प्रदान की गई परिभाषा के साथ बैकएंड प्रतिकृति सेट करें yaml फ़ाइल।

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

वे कई अद्यतन सुविधाएँ प्रदान करते हैं matchLabels तथा selectors। हमें कुबेरनेट्स मास्टर में एक नया नियंत्रक मिला है जिसे तैनाती नियंत्रक कहा जाता है जो ऐसा करता है। इसमें तैनाती मध्य मार्ग को बदलने की क्षमता है।

तैनाती बदलना

Updating- पूरा होने से पहले उपयोगकर्ता चल रही तैनाती को अपडेट कर सकता है। इसमें मौजूदा तैनाती को निपटाया जाएगा और नई तैनाती बनाई जाएगी।

Deleting- उपयोगकर्ता इसे पूरा होने से पहले हटाकर तैनाती को रोक / रद्द कर सकता है। उसी तैनाती को फिर से शुरू करना इसे फिर से शुरू करेगा।

Rollback- हम तैनाती या प्रगति में तैनाती को वापस कर सकते हैं। उपयोगकर्ता का उपयोग करके परिनियोजन बना या अद्यतन कर सकता हैDeploymentSpec.PodTemplateSpec = oldRC.PodTemplateSpec.

तैनाती की रणनीतियाँ

परिनियोजन रणनीतियाँ यह परिभाषित करने में मदद करती हैं कि नए RC को मौजूदा RC को कैसे बदलना चाहिए।

Recreate- यह फीचर सभी मौजूदा आरसी को मार देगा और फिर नए को लाएगा। यह त्वरित तैनाती का परिणाम है, हालांकि यह डाउनटाइम में परिणाम देगा जब पुरानी फली नीचे होती है और नई फली नहीं आती है।

Rolling Update- यह सुविधा धीरे-धीरे पुराने आरसी को नीचे लाती है और नए को लाती है। यह धीमी तैनाती का परिणाम है, हालांकि कोई तैनाती नहीं है। हर समय, कुछ पुरानी फली और कुछ नई फली इस प्रक्रिया में उपलब्ध हैं।

परिनियोजन की कॉन्फ़िगरेशन फ़ाइल इस तरह दिखती है।

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: Tomcatimage:
            tomcat: 8.0
            ports:
               - containerPort: 7474

उपरोक्त कोड में, केवल एक चीज जो प्रतिकृति सेट से अलग है, हमने तैनाती के रूप में परिभाषित किया है।

तैनाती करना

$ kubectl create –f Deployment.yaml -–record
deployment "Deployment" created Successfully.

तैनाती पाओ

$ kubectl get deployments
NAME           DESIRED     CURRENT     UP-TO-DATE     AVILABLE    AGE
Deployment        3           3           3              3        20s

तैनाती की स्थिति की जाँच करें

$ kubectl rollout status deployment/Deployment

परिनियोजन अद्यतन करना

$ kubectl set image deployment/Deployment tomcat=tomcat:6.0

पिछला परिनियोजन पर वापस लौटना

$ kubectl rollout undo deployment/Deployment –to-revision=2

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

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

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

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

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

  • 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वॉल्यूम का उपयोग एक पर्सेन्टवोल्यूम को फली में माउंट करने के लिए किया जाता है। 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 को बताता है कि जिस यमल फ़ाइल का उपयोग किया जा रहा है वह 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: → इसके तहत, हम वॉल्यूम नाम को परिभाषित करते हैं जिसे हम परिभाषित पॉड में उपयोग करने जा रहे हैं।

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

कुबेरनेट्स में रहस्य बनाने के कई तरीके हैं।

  • Txt फ़ाइलों से बनाना।
  • Yaml फ़ाइल से बनाना।

टेक्स्ट फ़ाइल से बनाना

उपयोगकर्ता नाम और पासवर्ड जैसे पाठ फ़ाइल से रहस्य बनाने के लिए, हमें पहले उन्हें एक txt फ़ाइल में संग्रहीत करना होगा और निम्नलिखित कमांड का उपयोग करना होगा।

$ kubectl create secret generic tomcat-passwd –-from-file = ./username.txt –fromfile = ./.
password.txt

यमल फ़ाइल से बनाना

apiVersion: v1
kind: Secret
metadata:
name: tomcat-pass
type: Opaque
data:
   password: <User Password>
   username: <User Name>

सीक्रेट बनाना

$ kubectl create –f Secret.yaml
secrets/tomcat-pass

राज का उपयोग करना

एक बार जब हम रहस्य बना लेते हैं, तो इसका सेवन फली या प्रतिकृति नियंत्रक में किया जा सकता है -

  • वातावरण विविधता
  • Volume

पर्यावरण चर के रूप में

पर्यावरण चर के रूप में रहस्य का उपयोग करने के लिए, हम उपयोग करेंगे env फली yaml फ़ाइल के विशेष खंड के तहत।

env:
- name: SECRET_USERNAME
   valueFrom:
      secretKeyRef:
         name: mysecret
         key: tomcat-pass

वॉल्यूम के रूप में

spec:
   volumes:
      - name: "secretstest"
         secret:
            secretName: tomcat-pass
   containers:
      - image: tomcat:7.0
         name: awebserver
         volumeMounts:
            - mountPath: "/tmp/mysec"
            name: "secretstest"

पर्यावरण चर के रूप में गुप्त विन्यास

apiVersion: v1
kind: ReplicationController
metadata:
   name: appname
spec:
replicas: replica_count
template:
   metadata:
      name: appname
   spec:
      nodeSelector:
         resource-group:
      containers:
         - name: appname
            image:
            imagePullPolicy: Always
            ports:
            - containerPort: 3000
            env: -----------------------------> 1
               - name: ENV
                  valueFrom:
                     configMapKeyRef:
                        name: appname
                        key: tomcat-secrets

उपरोक्त कोड में, के तहत env परिभाषा, हम प्रतिकृति नियंत्रक में पर्यावरण चर के रूप में रहस्यों का उपयोग कर रहे हैं।

वॉल्यूम माउंट के रूप में राज

apiVersion: v1
kind: pod
metadata:
   name: appname
spec:
   metadata:
      name: appname
   spec:
   volumes:
      - name: "secretstest"
         secret:
            secretName: tomcat-pass
   containers:
      - image: tomcat: 8.0
         name: awebserver
         volumeMounts:
            - mountPath: "/tmp/mysec"
            name: "secretstest"

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

सबसे पहले, हमें Namespace Isolation Policy को कॉन्फ़िगर करना होगा। मूल रूप से, लोड बैलेंसरों पर इस तरह की नेटवर्किंग नीतियों की आवश्यकता होती है।

kind: Namespace
apiVersion: v1
metadata:
   annotations:
      net.beta.kubernetes.io/network-policy: |
      {
         "ingress": 
         {
            "isolation": "DefaultDeny"
         }
      }
$ kubectl annotate ns <namespace> "net.beta.kubernetes.io/network-policy = 
{\"ingress\": {\"isolation\": \"DefaultDeny\"}}"

नाम स्थान बन जाने के बाद, हमें नेटवर्क नीति बनाने की आवश्यकता है।

नेटवर्क नीति यमल

kind: NetworkPolicy
apiVersion: extensions/v1beta1
metadata:
   name: allow-frontend
   namespace: myns
spec:
   podSelector:
      matchLabels:
         role: backend
   ingress:
   - from:
      - podSelector:
         matchLabels:
            role: frontend
   ports:
      - protocol: TCP
         port: 6379

Kubernetes API सिस्टम के लिए घोषणात्मक कॉन्फ़िगरेशन स्कीमा की नींव के रूप में कार्य करता है। KubectlAPI ऑब्जेक्ट बनाने, अपडेट करने, हटाने और प्राप्त करने के लिए कमांड-लाइन टूल का उपयोग किया जा सकता है। कुबेरनेट्स एपीआई कुबेरनेट्स के विभिन्न घटकों के बीच एक संचारक का काम करता है।

कुबेरनेट्स में एपीआई जोड़ना

Kubernetes में एक नया API जोड़ने से Kubernetes में नई सुविधाएँ जोड़ी जाएंगी, जिससे Kubernetes की कार्यक्षमता बढ़ जाएगी। हालांकि, इसके साथ ही यह प्रणाली की लागत और स्थिरता को भी बढ़ाएगा। लागत और जटिलता के बीच संतुलन बनाने के लिए, इसके लिए कुछ सेट निर्धारित हैं।

जो API जोड़ा जा रहा है वह 50% से अधिक उपयोगकर्ताओं के लिए उपयोगी होना चाहिए। कुबेरनेट्स में कार्यक्षमता को लागू करने का कोई अन्य तरीका नहीं है। कुबेरनेट्स की सामुदायिक बैठक में असाधारण परिस्थितियों पर चर्चा की जाती है, और फिर एपीआई को जोड़ा जाता है।

एपीआई परिवर्तन

कुबेरनेट्स की क्षमता बढ़ाने के लिए, सिस्टम में लगातार परिवर्तन किए जाते हैं। यह कुबेरनेट्स टीम द्वारा सिस्टम की मौजूदा कार्यक्षमता को हटाने या प्रभावित किए बिना कुबेरनेट्स में कार्यक्षमता जोड़ने के लिए किया जाता है।

सामान्य प्रक्रिया को प्रदर्शित करने के लिए, यहाँ एक (काल्पनिक) उदाहरण है -

  • एक उपयोगकर्ता एक पॉड वस्तु को पोस्ट करता है /api/v7beta1/...

  • JSON एक में अनारक्षित है v7beta1.Pod संरचना

  • डिफ़ॉल्ट मानों पर लागू होते हैं v7beta1.Pod

  • v7beta1.Pod में परिवर्तित हो जाता है api.Pod संरचना

  • api.Pod मान्य किया गया है, और कोई भी त्रुटि उपयोगकर्ता को दी जाती है

  • api.Pod v6 में परिवर्तित किया जाता है। पोड (क्योंकि v6 नवीनतम स्थिर संस्करण है)

  • v6.Pod JSON में marshalled है और को लिखा गया है etcd

अब जब हमारे पास पॉड ऑब्जेक्ट संग्रहीत है, तो उपयोगकर्ता किसी भी समर्थित एपीआई संस्करण में उस ऑब्जेक्ट को प्राप्त कर सकता है। उदाहरण के लिए -

  • एक उपयोगकर्ता फली से प्राप्त करता है /api/v5/...

  • JSON से पढ़ा जाता है etcd तथा unmarshalled में v6.Pod संरचना

  • डिफ़ॉल्ट मानों पर लागू होते हैं v6.Pod

  • v6.Pod को api.Pod संरचना में बदल दिया जाता है

  • api.Pod में परिवर्तित हो जाता है v5.Pod संरचना

  • v5.Pod JSON में marshalled है और उपयोगकर्ता को भेजा जाता है

इस प्रक्रिया का निहितार्थ यह है कि एपीआई परिवर्तन सावधानीपूर्वक और पीछे की ओर से किया जाना चाहिए।

एपीआई संस्करण

कई संरचनाओं का समर्थन करना आसान बनाने के लिए, कुबेरनेट्स अलग-अलग एपीआई पथ जैसे प्रत्येक पर कई एपीआई संस्करणों का समर्थन करता है /api/v1 या /apsi/extensions/v1beta1

कुबेरनेट्स में संस्करण मानकों को कई मानकों में परिभाषित किया गया है।

अल्फा स्तर

  • इस संस्करण में अल्फा शामिल है (उदाहरण के लिए v1alp1)

  • यह संस्करण छोटी गाड़ी हो सकती है; सक्षम संस्करण में बग हो सकते हैं

  • बग के लिए समर्थन किसी भी समय गिराया जा सकता है।

  • केवल अल्पकालिक परीक्षण में उपयोग किए जाने की सिफारिश की जाती है क्योंकि समर्थन हर समय मौजूद नहीं हो सकता है।

बीटा स्तर

  • संस्करण नाम में बीटा शामिल है (उदाहरण v2beta3)

  • कोड का पूरी तरह से परीक्षण किया गया है और सक्षम संस्करण को स्थिर माना जाता है।

  • सुविधा का समर्थन गिराया नहीं जाएगा; कुछ छोटे बदलाव हो सकते हैं।

  • केवल गैर-व्यावसायिक-महत्वपूर्ण उपयोगों के लिए अनुशंसित क्योंकि बाद के रिलीज में असंगत परिवर्तन की क्षमता है।

स्थिर स्तर

  • संस्करण का नाम है vX कहाँ पे X एक पूर्णांक है।

  • जारी किए गए सॉफ़्टवेयर में कई बाद के संस्करणों के लिए स्थिर संस्करण दिखाई देंगे।

Kubernet एपीआई के साथ बातचीत करने के लिए Kubectl कमांड लाइन उपयोगिता है। यह एक इंटरफ़ेस है जो कुबेरनेट क्लस्टर में फली को संप्रेषित और प्रबंधित करने के लिए उपयोग किया जाता है।

कुबेरनेट क्लस्टर के साथ बातचीत करने के लिए स्थानीय को कुबेटेल स्थापित करने की आवश्यकता है।

Kubectl की स्थापना

कर्ल कमांड का उपयोग करते हुए स्थानीय वर्कस्टेशन पर निष्पादन योग्य डाउनलोड करें।

लिनक्स पर

$ curl -O https://storage.googleapis.com/kubernetesrelease/
release/v1.5.2/bin/linux/amd64/kubectl

OS X वर्कस्टेशन पर

$ curl -O https://storage.googleapis.com/kubernetesrelease/
release/v1.5.2/bin/darwin/amd64/kubectl

डाउनलोड पूरा होने के बाद, बायनेरिज़ को सिस्टम के पथ में स्थानांतरित करें।

$ chmod +x kubectl
$ mv kubectl /usr/local/bin/kubectl

Kubectl को कॉन्फ़िगर करना

कॉन्फ़िगरेशन ऑपरेशन करने के लिए निम्न चरण हैं।

$ kubectl config set-cluster default-cluster --server = https://${MASTER_HOST} -- certificate-authority = ${CA_CERT}

$ kubectl config set-credentials default-admin --certificateauthority = ${
CA_CERT} --client-key = ${ADMIN_KEY} --clientcertificate = ${
ADMIN_CERT}

$ kubectl config set-context default-system --cluster = default-cluster -- user = default-admin $ kubectl config use-context default-system
  • बदलने के ${MASTER_HOST} पिछले चरणों में उपयोग किए गए मास्टर नोड पते या नाम के साथ।

  • बदलने के ${CA_CERT} के पूर्ण पथ के साथ ca.pem पिछले चरणों में बनाया गया।

  • बदलने के ${ADMIN_KEY} के पूर्ण पथ के साथ admin-key.pem पिछले चरणों में बनाया गया।

  • बदलने के ${ADMIN_CERT} के पूर्ण पथ के साथ admin.pem पिछले चरणों में बनाया गया।

सेटअप का सत्यापन करना

यह सत्यापित करने के लिए कि क्या kubectl ठीक काम कर रहा है या नहीं, यह जांच लें कि कुबेरनेट्स क्लाइंट ठीक से सेट है या नहीं।

$ kubectl get nodes

NAME       LABELS                                     STATUS
Vipin.com  Kubernetes.io/hostname = vipin.mishra.com    Ready

Kubectlकुबेरनेट्स क्लस्टर को नियंत्रित करता है। यह कुबेरनेट्स के प्रमुख घटकों में से एक है जो सेटअप होने पर किसी भी मशीन पर कार्य केंद्र पर चलता है। यह क्लस्टर में नोड्स को प्रबंधित करने की क्षमता रखता है।

KubectlKubernetes ऑब्जेक्ट और क्लस्टर को इंटरैक्ट करने और प्रबंधित करने के लिए कमांड का उपयोग किया जाता है। इस अध्याय में, हम कुबेरनेट के माध्यम से कुबेरनेट में प्रयुक्त कुछ आदेशों पर चर्चा करेंगे।

kubectl annotate - यह एक संसाधन पर एनोटेशन को अपडेट करता है।

$kubectl annotate [--overwrite] (-f FILENAME | TYPE NAME) KEY_1=VAL_1 ...
KEY_N = VAL_N [--resource-version = version]

उदाहरण के लिए,

kubectl annotate pods tomcat description = 'my frontend'

kubectl api-versions - यह क्लस्टर पर एपीआई के समर्थित संस्करणों को प्रिंट करता है।

$ kubectl api-version;

kubectl apply - इसमें फाइल या स्टड द्वारा किसी संसाधन को कॉन्फ़िगर करने की क्षमता है।

$ kubectl apply –f <filename>

kubectl attach - यह रनिंग कंटेनर में चीजों को जोड़ता है।

$ kubectl attach <pod> –c <container> $ kubectl attach 123456-7890 -c tomcat-conatiner

kubectl autoscale - इसका उपयोग ऑटो स्केल पॉड्स के लिए किया जाता है जो कि परिनियोजन, प्रतिकृति सेट, प्रतिकृति नियंत्रक जैसे परिभाषित होते हैं।

$ kubectl autoscale (-f FILENAME | TYPE NAME | TYPE/NAME) [--min = MINPODS] -- max = MAXPODS [--cpu-percent = CPU] [flags] $ kubectl autoscale deployment foo --min = 2 --max = 10

kubectl cluster-info - यह क्लस्टर जानकारी प्रदर्शित करता है।

$ kubectl cluster-info

kubectl cluster-info dump - यह डिबगिंग और निदान के लिए क्लस्टर के संबंध में प्रासंगिक जानकारी को डंप करता है।

$ kubectl cluster-info dump
$ kubectl cluster-info dump --output-directory = /path/to/cluster-state

kubectl config - kubeconfig फ़ाइल को संशोधित करता है।

$ kubectl config <SUBCOMMAD>
$ kubectl config –-kubeconfig <String of File name>

kubectl config current-context - यह वर्तमान संदर्भ प्रदर्शित करता है।

$ kubectl config current-context
#deploys the current context

kubectl config delete-cluster - कुबेकॉन्फिग से निर्दिष्ट क्लस्टर को हटाता है।

$ kubectl config delete-cluster <Cluster Name>

kubectl config delete-context - kubeconfig से एक निर्दिष्ट संदर्भ हटाता है।

$ kubectl config delete-context <Context Name>

kubectl config get-clusters - कुबेकॉन्फिग में परिभाषित क्लस्टर प्रदर्शित करता है।

$ kubectl config get-cluster $ kubectl config get-cluster <Cluser Name>

kubectl config get-contexts - एक या कई संदर्भों का वर्णन करता है।

$ kubectl config get-context <Context Name>

kubectl config set-cluster - कुबेरनेट्स में क्लस्टर प्रविष्टि सेट करता है।

$ kubectl config set-cluster NAME [--server = server] [--certificateauthority =
path/to/certificate/authority] [--insecure-skip-tls-verify = true]

kubectl config set-context - कुबेरनेट्स एंट्रीपॉइंट में एक संदर्भ प्रविष्टि सेट करता है।

$ kubectl config set-context NAME [--cluster = cluster_nickname] [-- user = user_nickname] [--namespace = namespace] $ kubectl config set-context prod –user = vipin-mishra

kubectl config set-credentials - kubeconfig में एक उपयोगकर्ता प्रविष्टि सेट करता है।

$ kubectl config set-credentials cluster-admin --username = vipin --
password = uXFGweU9l35qcif

kubectl config set - kubeconfig फ़ाइल में एक अलग मान सेट करता है।

$ kubectl config set PROPERTY_NAME PROPERTY_VALUE

kubectl config unset - यह kubectl में एक विशिष्ट घटक को अनसेट करता है।

$ kubectl config unset PROPERTY_NAME PROPERTY_VALUE

kubectl config use-context - kubectl फ़ाइल में वर्तमान संदर्भ सेट करता है।

$ kubectl config use-context <Context Name>

kubectl config view

$ kubectl config view $ kubectl config view –o jsonpath='{.users[?(@.name == "e2e")].user.password}'

kubectl cp - कॉपी और कंटेनरों से फ़ाइलों और निर्देशिकाओं।

$ kubectl cp <Files from source> <Files to Destinatiion> $ kubectl cp /tmp/foo <some-pod>:/tmp/bar -c <specific-container>

kubectl create- या स्टड के फ़ाइल नाम से संसाधन बनाने के लिए। ऐसा करने के लिए, JSON या YAML प्रारूप स्वीकार किए जाते हैं।

$ kubectl create –f <File Name> $ cat <file name> | kubectl create –f -

उसी तरह, हम कई चीजों को बना सकते हैं जैसे कि सूचीबद्ध हैं create साथ में आज्ञा kubectl

  • deployment
  • namespace
  • quota
  • गुप्त डॉकटर-रजिस्ट्री
  • secret
  • गुप्त सामान्य
  • गुप्त चोंच
  • serviceaccount
  • सेवा क्लस्टर
  • सेवा भारोत्तोलक
  • सेवा

kubectl delete - फ़ाइल नाम, स्टडिन, संसाधन और नामों से संसाधनों को हटाता है।

$ kubectl delete –f ([-f FILENAME] | TYPE [(NAME | -l label | --all)])

kubectl describe- कुबेरनेट में किसी विशेष संसाधन का वर्णन करता है। संसाधन या संसाधनों के समूह का विवरण दिखाता है।

$ kubectl describe <type> <type name>
$ kubectl describe pod tomcat

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

$ kubectl drain tomcat –force

kubectl edit- इसका उपयोग सर्वर पर संसाधनों को समाप्त करने के लिए किया जाता है। यह एक संसाधन को सीधे संपादित करने की अनुमति देता है जिसे कोई कमांड लाइन टूल के माध्यम से प्राप्त कर सकता है।

$ kubectl edit <Resource/Name | File Name) Ex. $ kubectl edit rc/tomcat

kubectl exec - यह कंटेनर में एक कमांड निष्पादित करने में मदद करता है।

$ kubectl exec POD <-c CONTAINER > -- COMMAND < args...> $ kubectl exec tomcat 123-5-456 date

kubectl expose- इसका उपयोग कुबेरनेट वस्तुओं, जैसे फली, प्रतिकृति नियंत्रक, और सेवा को एक नए कुबेरनेसेस सेवा के रूप में उजागर करने के लिए किया जाता है। यह एक चल कंटेनर के माध्यम से या एक से इसे उजागर करने की क्षमता हैyaml फ़ाइल।

$ kubectl expose (-f FILENAME | TYPE NAME) [--port=port] [--protocol = TCP|UDP] [--target-port = number-or-name] [--name = name] [--external-ip = external-ip-ofservice] [--type = type] $ kubectl expose rc tomcat –-port=80 –target-port = 30000
$ kubectl expose –f tomcat.yaml –port = 80 –target-port =

kubectl get - यह कमांड Kubernetes संसाधनों के बारे में क्लस्टर पर डेटा लाने में सक्षम है।

$ kubectl get [(-o|--output=)json|yaml|wide|custom-columns=...|custom-columnsfile=...|
go-template=...|go-template-file=...|jsonpath=...|jsonpath-file=...]
(TYPE [NAME | -l label] | TYPE/NAME ...) [flags]

उदाहरण के लिए,

$ kubectl get pod <pod name> $ kubectl get service <Service name>

kubectl logs- वे एक फली में कंटेनर के लॉग प्राप्त करने के लिए उपयोग किया जाता है। लॉग को प्रिंट करना पॉड में कंटेनर के नाम को परिभाषित करना हो सकता है। यदि POD में केवल एक कंटेनर है तो इसके नाम को परिभाषित करने की कोई आवश्यकता नहीं है।

$ kubectl logs [-f] [-p] POD [-c CONTAINER] Example $ kubectl logs tomcat.
$ kubectl logs –p –c tomcat.8

kubectl port-forward - इनका उपयोग पॉड्स के लिए एक या एक से अधिक लोकल पोर्ट को फॉरवर्ड करने के लिए किया जाता है।

$ kubectl port-forward POD [LOCAL_PORT:]REMOTE_PORT
[...[LOCAL_PORT_N:]REMOTE_PORT_N]
$ kubectl port-forward tomcat 3000 4000 $ kubectl port-forward tomcat 3000:5000

kubectl replace - फ़ाइल नाम या फ़ाइल द्वारा किसी संसाधन को बदलने में सक्षम stdin

$ kubectl replace -f FILENAME $ kubectl replace –f tomcat.yml
$ cat tomcat.yml | kubectl replace –f -

kubectl rolling-update- एक प्रतिकृति नियंत्रक पर एक रोलिंग अद्यतन करता है। एक समय में एक POD को अपडेट करके नए प्रतिकृति नियंत्रक के साथ निर्दिष्ट प्रतिकृति नियंत्रक बदलता है।

$ kubectl rolling-update OLD_CONTROLLER_NAME ([NEW_CONTROLLER_NAME] --
image = NEW_CONTAINER_IMAGE | -f NEW_CONTROLLER_SPEC)
$ kubectl rolling-update frontend-v1 –f freontend-v2.yaml

kubectl rollout - यह तैनाती के रोलआउट के प्रबंधन में सक्षम है।

$ Kubectl rollout <Sub Command>
$ kubectl rollout undo deployment/tomcat

उपरोक्त के अलावा, हम रोलआउट का उपयोग करके कई कार्य कर सकते हैं जैसे कि -

  • रोलआउट इतिहास
  • रोलआउट रोकें
  • रोलआउट फिर से शुरू करें
  • रोलआउट स्थिति
  • रोलआउट पूर्ववत करें

kubectl run - रन कमांड में कुबेरनेट क्लस्टर पर एक छवि को चलाने की क्षमता है।

$ kubectl run NAME --image = image [--env = "key = value"] [--port = port] [--
replicas = replicas] [--dry-run = bool] [--overrides = inline-json] [--command] --
[COMMAND] [args...]
$ kubectl run tomcat --image = tomcat:7.0 $ kubectl run tomcat –-image = tomcat:7.0 –port = 5000

kubectl scale - यह Kubernetes Deploments, ReplicaSet, प्रतिकृति नियंत्रक या नौकरी के आकार को मापेगा।

$ kubectl scale [--resource-version = version] [--current-replicas = count] -- replicas = COUNT (-f FILENAME | TYPE NAME ) $ kubectl scale –-replica = 3 rs/tomcat
$ kubectl scale –replica = 3 tomcat.yaml

kubectl set image - यह पॉड टेम्पलेट की छवि को अपडेट करता है।

$ kubectl set image (-f FILENAME | TYPE NAME)
CONTAINER_NAME_1 = CONTAINER_IMAGE_1 ... CONTAINER_NAME_N = CONTAINER_IMAGE_N
$ kubectl set image deployment/tomcat busybox = busybox ngnix = ngnix:1.9.1 $ kubectl set image deployments, rc tomcat = tomcat6.0 --all

kubectl set resources- इसका उपयोग संसाधन की सामग्री को सेट करने के लिए किया जाता है। यह पॉड टेम्पलेट के साथ ऑब्जेक्ट पर संसाधन / सीमा को अद्यतन करता है।

$ kubectl set resources (-f FILENAME | TYPE NAME) ([--limits = LIMITS & -- requests = REQUESTS] $ kubectl set resources deployment tomcat -c = tomcat --
limits = cpu = 200m,memory = 512Mi

kubectl top node- यह सीपीयू / मेमोरी / स्टोरेज उपयोग प्रदर्शित करता है। शीर्ष कमांड आपको नोड्स के लिए संसाधन खपत को देखने की अनुमति देता है।

$ kubectl top node [node Name]

एक ही कमांड को एक फली के साथ भी इस्तेमाल किया जा सकता है।

कुबेरनेट्स परिनियोजन के लिए एक एप्लिकेशन बनाने के लिए, हमें पहले डॉकर पर एप्लिकेशन बनाना होगा। इसे दो तरीकों से किया जा सकता है -

  • डाउनलोड करके
  • डॉकर फ़ाइल से

डाउनलोड करके

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

ऐसा करने के लिए, डॉकर को चलाएं pull आदेश।

$ docker pull --help
Usage: docker pull [OPTIONS] NAME[:TAG|@DIGEST]
Pull an image or a repository from the registry
   -a, --all-tags = false     Download all tagged images in the repository
   --help = false             Print usage

निम्नलिखित उपरोक्त कोड का आउटपुट होगा।

उपरोक्त स्क्रीनशॉट में छवियों का एक सेट दिखाया गया है जो हमारे स्थानीय डॉकर रजिस्ट्री में संग्रहीत हैं।

यदि हम छवि से एक कंटेनर बनाना चाहते हैं जिसमें परीक्षण करने के लिए एक एप्लिकेशन शामिल है, तो हम इसे डॉकर रन कमांड का उपयोग करके कर सकते हैं।

$ docker run –i –t unbunt /bin/bash

डॉकर फ़ाइल से

डॉकर फ़ाइल से एक एप्लिकेशन बनाने के लिए, हमें पहले एक डॉकर फ़ाइल बनाना होगा।

इसके बाद जेनकिन्स डोकर फाइल का एक उदाहरण है।

FROM ubuntu:14.04
MAINTAINER [email protected]
ENV REFRESHED_AT 2017-01-15
RUN apt-get update -qq && apt-get install -qqy curl
RUN curl https://get.docker.io/gpg | apt-key add -
RUN echo deb http://get.docker.io/ubuntu docker main > /etc/apt/↩
sources.list.d/docker.list
RUN apt-get update -qq && apt-get install -qqy iptables ca-↩
certificates lxc openjdk-6-jdk git-core lxc-docker
ENV JENKINS_HOME /opt/jenkins/data
ENV JENKINS_MIRROR http://mirrors.jenkins-ci.org
RUN mkdir -p $JENKINS_HOME/plugins
RUN curl -sf -o /opt/jenkins/jenkins.war -L $JENKINS_MIRROR/war-↩ stable/latest/jenkins.war RUN for plugin in chucknorris greenballs scm-api git-client git ↩ ws-cleanup ;\ do curl -sf -o $JENKINS_HOME/plugins/${plugin}.hpi \ -L $JENKINS_MIRROR/plugins/${plugin}/latest/${plugin}.hpi ↩
; done
ADD ./dockerjenkins.sh /usr/local/bin/dockerjenkins.sh
RUN chmod +x /usr/local/bin/dockerjenkins.sh
VOLUME /var/lib/docker
EXPOSE 8080
ENTRYPOINT [ "/usr/local/bin/dockerjenkins.sh" ]

एक बार उपरोक्त फाइल बन जाने के बाद, इसे फाइल पथ पर Dockerfile और cd के नाम से सहेजें। उसके बाद, निम्न आदेश चलाएँ।

$ sudo docker build -t jamtur01/Jenkins .

एक बार छवि बन जाने के बाद, हम परीक्षण कर सकते हैं कि क्या छवि ठीक काम कर रही है और इसे कंटेनर में बदला जा सकता है।

$ docker run –i –t jamtur01/Jenkins /bin/bash

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

इस सेटअप में, हम पॉड्स के एक सेट पर ट्रैफ़िक डायवर्ट करने वाले ट्रैफ़िक के ऊपर एक लोड बैलेंसर सेट कर सकते हैं और बाद में वे पॉड्स बैकेंड करने के लिए संवाद करते हैं। पॉड्स के बीच संचार कुबेरनेट्स में निर्मित सेवा वस्तु के माध्यम से होता है।

Ngnix लोड बैलेंसर यमल फ़ाइल

apiVersion: v1
kind: Service
metadata:
   name: oppv-dev-nginx
      labels:
         k8s-app: omni-ppv-api
spec:
   type: NodePort
   ports:
   - port: 8080
      nodePort: 31999
      name: omninginx
   selector:
      k8s-app: appname
      component: nginx
      env: dev

Ngnix प्रतिकृति नियंत्रक यमल

apiVersion: v1
kind: ReplicationController
metadata:
   name: appname
spec:
   replicas: replica_count
   template:
      metadata:
         name: appname
         labels:
            k8s-app: appname
            component: nginx
               env: env_name
spec:
   nodeSelector:
      resource-group: oppv
   containers:
      - name: appname
      image: IMAGE_TEMPLATE
      imagePullPolicy: Always
      ports:
         - containerPort: 8080
         resources:
            requests:
               memory: "request_mem"
               cpu: "request_cpu"
            limits:
               memory: "limit_mem"
               cpu: "limit_cpu"
            env:
            - name: BACKEND_HOST
               value: oppv-env_name-node:3000

सीमावर्ती सेवा यमल फ़ाइल

apiVersion: v1
kind: Service
metadata:
   name: appname
   labels:
      k8s-app: appname
spec:
   type: NodePort
   ports:
   - name: http
      port: 3000
      protocol: TCP
      targetPort: 3000
   selector:
      k8s-app: appname
      component: nodejs
      env: dev

सीमावर्ती प्रतिकृति नियंत्रक यमल फ़ाइल

apiVersion: v1
kind: ReplicationController
metadata:
   name: Frontend
spec:
   replicas: 3
   template:
      metadata:
         name: frontend
         labels:
            k8s-app: Frontend
            component: nodejs
            env: Dev
spec:
   nodeSelector:
      resource-group: oppv
   containers:
      - name: appname
         image: IMAGE_TEMPLATE
         imagePullPolicy: Always
         ports:
            - containerPort: 3000
            resources:
               requests:
                  memory: "request_mem"
                  cpu: "limit_cpu"
                  limits:
                  memory: "limit_mem"
                  cpu: "limit_cpu"
            env:
               - name: ENV
               valueFrom:
               configMapKeyRef:
               name: appname
               key: config-env

बैकेंड सेवा यमल फ़ाइल

apiVersion: v1
kind: Service
metadata:
   name: backend
   labels:
      k8s-app: backend
spec:
   type: NodePort
   ports:
   - name: http
      port: 9010
      protocol: TCP
      targetPort: 9000
   selector:
      k8s-app: appname
      component: play
      env: dev

समर्थित प्रतिकृति नियंत्रक यमल फ़ाइल

apiVersion: v1
kind: ReplicationController
metadata:
   name: backend
spec:
   replicas: 3
   template:
      metadata:
         name: backend
      labels:
         k8s-app: beckend
         component: play
         env: dev
spec:
   nodeSelector:
      resource-group: oppv
      containers:
         - name: appname
            image: IMAGE_TEMPLATE
            imagePullPolicy: Always
            ports:
            - containerPort: 9000
            command: [ "./docker-entrypoint.sh" ]
            resources:
               requests:
                  memory: "request_mem"
                  cpu: "request_cpu"
               limits:
                  memory: "limit_mem"
                  cpu: "limit_cpu"
            volumeMounts:
               - name: config-volume
               mountPath: /app/vipin/play/conf
         volumes:
            - name: config-volume
            configMap:
            name: appname

Autoscalingकुबेरनेट क्लस्टर में प्रमुख विशेषताओं में से एक है। यह एक ऐसी सुविधा है जिसमें क्लस्टर नोड्स की संख्या बढ़ाने में सक्षम है क्योंकि सेवा प्रतिक्रिया की मांग बढ़ जाती है और आवश्यकता घटने पर नोड्स की संख्या कम हो जाती है। ऑटो स्केलिंग की यह सुविधा वर्तमान में Google क्लाउड इंजन (GCE) और Google कंटेनर इंजन (GKE) में समर्थित है और जल्द ही AWS के साथ शुरू होगी।

जीसीई में स्केलेबल इन्फ्रास्ट्रक्चर स्थापित करने के लिए, हमें पहले Google क्लाउड मॉनिटरिंग, Google क्लाउड लॉगिंग और स्टैकड्राइवर सक्षम की सुविधाओं के साथ एक सक्रिय GCE प्रोजेक्ट की आवश्यकता है।

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

वातावरण विविधता

export NUM_NODES = 2
export KUBE_AUTOSCALER_MIN_NODES = 2
export KUBE_AUTOSCALER_MAX_NODES = 5
export KUBE_ENABLE_CLUSTER_AUTOSCALER = true

एक बार हो जाने पर, हम क्लस्टर को चालू कर देंगे kube-up.sh। यह क्लस्टर ऑटो-स्केलर ऐड पर एक साथ एक क्लस्टर बनाएगा।

./cluster/kube-up.sh

क्लस्टर के निर्माण पर, हम निम्नलिखित kubectl कमांड का उपयोग करके अपने क्लस्टर की जांच कर सकते हैं।

$ kubectl get nodes
NAME                             STATUS                       AGE
kubernetes-master                Ready,SchedulingDisabled     10m
kubernetes-minion-group-de5q     Ready                        10m
kubernetes-minion-group-yhdx     Ready                        8m

अब, हम क्लस्टर पर एक एप्लिकेशन को तैनात कर सकते हैं और फिर क्षैतिज पॉड ऑटोसालर को सक्षम कर सकते हैं। यह निम्न कमांड का उपयोग करके किया जा सकता है।

$ kubectl autoscale deployment <Application Name> --cpu-percent = 50 --min = 1 --
max = 10

उपरोक्त कमांड से पता चलता है कि हम POD की कम से कम एक और अधिकतम 10 प्रतिकृति को बनाए रखेंगे क्योंकि आवेदन बढ़ता है।

हम ऑटोकैलर की स्थिति को चलाकर जांच सकते हैं $kubclt get hpaआदेश। हम निम्नलिखित कमांड का उपयोग करके फली पर भार बढ़ाएंगे।

$ kubectl run -i --tty load-generator --image = busybox /bin/sh
$ while true; do wget -q -O- http://php-apache.default.svc.cluster.local; done

हम जांच कर सकते हैं hpa चलाकर $ kubectl get hpa आदेश।

$ kubectl get hpa NAME REFERENCE TARGET CURRENT php-apache Deployment/php-apache/scale 50% 310% MINPODS MAXPODS AGE 1 20 2m $ kubectl get deployment php-apache
NAME         DESIRED    CURRENT    UP-TO-DATE    AVAILABLE   AGE
php-apache      7          7           7            3        4m

हम निम्नलिखित कमांड का उपयोग करके चलने वाली फली की संख्या की जांच कर सकते हैं।

jsz@jsz-desk2:~/k8s-src$ kubectl get pods
php-apache-2046965998-3ewo6 0/1        Pending 0         1m
php-apache-2046965998-8m03k 1/1        Running 0         1m
php-apache-2046965998-ddpgp 1/1        Running 0         5m
php-apache-2046965998-lrik6 1/1        Running 0         1m
php-apache-2046965998-nj465 0/1        Pending 0         1m
php-apache-2046965998-tmwg1 1/1        Running 0         1m
php-apache-2046965998-xkbw1 0/1        Pending 0         1m

और अंत में, हम नोड स्थिति प्राप्त कर सकते हैं।

$ kubectl get nodes
NAME                             STATUS                        AGE
kubernetes-master                Ready,SchedulingDisabled      9m
kubernetes-minion-group-6z5i     Ready                         43s
kubernetes-minion-group-de5q     Ready                         9m
kubernetes-minion-group-yhdx     Ready                         9m

कुबेरनेट्स डैशबोर्ड की स्थापना में इसे स्थापित करने के लिए आवश्यक शर्तें के रूप में आवश्यक उपकरणों के एक सेट के साथ कई कदम शामिल हैं।

  • डॉकर (1.3+)
  • जाओ (1.5+)
  • नोडज (4.2.2+)
  • npm (1.3+)
  • जावा (7+)
  • गल्प (3.9+)
  • कुबेरनेट्स (1.1.2+)

डैशबोर्ड पर सेट करना

$ sudo apt-get update && sudo apt-get upgrade Installing Python $ sudo apt-get install python
$ sudo apt-get install python3 Installing GCC $ sudo apt-get install gcc-4.8 g++-4.8

Installing make
$ sudo apt-get install make Installing Java $ sudo apt-get install openjdk-7-jdk

Installing Node.js
$ wget https://nodejs.org/dist/v4.2.2/node-v4.2.2.tar.gz $ tar -xzf node-v4.2.2.tar.gz
$ cd node-v4.2.2 $ ./configure
$ make $ sudo make install

Installing gulp
$ npm install -g gulp $ npm install gulp

संस्करणों का सत्यापन

Java Version
$ java –version java version "1.7.0_91" OpenJDK Runtime Environment (IcedTea 2.6.3) (7u91-2.6.3-1~deb8u1+rpi1) OpenJDK Zero VM (build 24.91-b01, mixed mode) $ node –v
V4.2.2

$ npn -v 2.14.7 $ gulp -v
[09:51:28] CLI version 3.9.0

$ sudo gcc --version
gcc (Raspbian 4.8.4-1) 4.8.4
Copyright (C) 2013 Free Software Foundation, Inc. This is free software; 
see the source for copying conditions. There is NO warranty; not even for 
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

जीओ स्थापित करना

$ git clone https://go.googlesource.com/go
$ cd go $ git checkout go1.4.3
$ cd src Building GO $ ./all.bash
$ vi /root/.bashrc In the .bashrc export GOROOT = $HOME/go
   export PATH = $PATH:$GOROOT/bin
   
$ go version
go version go1.4.3 linux/arm

कुबेरनेट्स डैशबोर्ड स्थापित करना

$ git clone https://github.com/kubernetes/dashboard.git
$ cd dashboard $ npm install -g bower

डैशबोर्ड चला रहे हैं

$ git clone https://github.com/kubernetes/dashboard.git $ cd dashboard
$ npm install -g bower $ gulp serve
[11:19:12] Requiring external module babel-core/register
[11:20:50] Using gulpfile ~/dashboard/gulpfile.babel.js
[11:20:50] Starting 'package-backend-source'...
[11:20:50] Starting 'kill-backend'...
[11:20:50] Finished 'kill-backend' after 1.39 ms
[11:20:50] Starting 'scripts'...
[11:20:53] Starting 'styles'...
[11:21:41] Finished 'scripts' after 50 s
[11:21:42] Finished 'package-backend-source' after 52 s
[11:21:42] Starting 'backend'...
[11:21:43] Finished 'styles' after 49 s
[11:21:43] Starting 'index'...
[11:21:44] Finished 'index' after 1.43 s
[11:21:44] Starting 'watch'...
[11:21:45] Finished 'watch' after 1.41 s
[11:23:27] Finished 'backend' after 1.73 min
[11:23:27] Starting 'spawn-backend'...
[11:23:27] Finished 'spawn-backend' after 88 ms
[11:23:27] Starting 'serve'...
2016/02/01 11:23:27 Starting HTTP server on port 9091
2016/02/01 11:23:27 Creating API client for
2016/02/01 11:23:27 Creating Heapster REST client for http://localhost:8082
[11:23:27] Finished 'serve' after 312 ms
[BS] [BrowserSync SPA] Running...
[BS] Access URLs:
--------------------------------------
Local: http://localhost:9090/
External: http://192.168.1.21:9090/
--------------------------------------
UI: http://localhost:3001
UI External: http://192.168.1.21:3001
--------------------------------------
[BS] Serving files from: /root/dashboard/.tmp/serve
[BS] Serving files from: /root/dashboard/src/app/frontend
[BS] Serving files from: /root/dashboard/src/app

कुबेरनेट्स डैशबोर्ड

बड़े समूहों के प्रबंधन के लिए निगरानी एक प्रमुख घटक है। इसके लिए, हमारे पास कई उपकरण हैं।

प्रोमेथियस के साथ निगरानी

यह एक निगरानी और चेतावनी प्रणाली है। यह साउंडक्लाउड में बनाया गया था और 2012 में खुला था। यह बहुआयामी डेटा को बहुत अच्छी तरह से संभालता है।

प्रोमेथियस के पास निगरानी में भाग लेने के लिए कई घटक हैं -

  • Prometheus - यह मुख्य घटक है जो डेटा को स्क्रैप और स्टोर करता है।

  • Prometheus node explore - मेजबान स्तर के मैच्योर हो जाते हैं और उन्हें प्रोमेथियस को उजागर करते हैं।

  • Ranch-eye - ए है haproxy और उजागर करता है cAdvisor प्रोमेथियस को आँकड़े।

  • Grafana - डेटा का विज़ुअलाइज़ेशन।

  • InfuxDB - टाइम सीरीज़ डेटाबेस विशेष रूप से रैंचर के डेटा को स्टोर करने के लिए उपयोग किया जाता है।

  • Prom-ranch-exporter - यह एक साधारण नोड.जेएस एप्लिकेशन है, जो सेवा के स्टैक की स्थिति के लिए रैंचर सर्वर को क्वेरी करने में मदद करता है।

सेमाटेक्स्ट डॉकर एजेंट

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

एजेंटों को नोड्स में तैनात करना

Kubernetes DeamonSets प्रदान करता है जो सुनिश्चित करता है कि फली को क्लस्टर में जोड़ा जाता है।

SemaText Docker Agent को कॉन्फ़िगर करना

यह पर्यावरण चर के माध्यम से कॉन्फ़िगर किया गया है।

  • यदि आपके पास पहले से कोई खाता नहीं है, तो apps.sematext.com पर एक निःशुल्क खाता प्राप्त करें ।

  • SPM ऐप टोकन प्राप्त करने के लिए "Docker" प्रकार का एक SPM ऐप बनाएं। एसपीएम ऐप आपके कुबेरनेट्स प्रदर्शन मैट्रिक्स और घटना का आयोजन करेगा।

  • Logsene App टोकन प्राप्त करने के लिए एक Logsene App बनाएँ। Logsene App आपके Kubernetes लॉग को रखेगा।

  • नीचे दिखाए गए अनुसार DaemonSet परिभाषा में LOGSENE_TOKEN और SPM_TOKEN के मान संपादित करें।

    • नवीनतम sematext-agent-daemonset.yml (कच्चे सादे-पाठ) टेम्पलेट (नीचे दिखाया गया है) को भी पकड़ो।

    • इसे डिस्क पर कहीं स्टोर करें।

    • SPM_TOKEN और LOGSENE_TOKEN प्लेसहोल्डर्स को अपने SPM और Logsene App टोकन से बदलें।

DaemonSet ऑब्जेक्ट बनाएँ

apiVersion: extensions/v1beta1
kind: DaemonSet
metadata:
   name: sematext-agent
spec:
   template:
      metadata:
         labels:
            app: sematext-agent
      spec:
         selector: {}
         dnsPolicy: "ClusterFirst"
         restartPolicy: "Always"
         containers:
         - name: sematext-agent
            image: sematext/sematext-agent-docker:latest
            imagePullPolicy: "Always"
            env:
            - name: SPM_TOKEN
               value: "REPLACE THIS WITH YOUR SPM TOKEN"
            - name: LOGSENE_TOKEN
               value: "REPLACE THIS WITH YOUR LOGSENE TOKEN"
            - name: KUBERNETES
               value: "1"
            volumeMounts:
               - mountPath: /var/run/docker.sock
                  name: docker-sock
               - mountPath: /etc/localtime
                  name: localtime
            volumes:
               - name: docker-sock
                  hostPath:
                     path: /var/run/docker.sock
               - name: localtime
                  hostPath:
                     path: /etc/localtime

कुबेटेल के साथ सेमटेक्स्ट एजेंट डोकर चलाना

$ kubectl create -f sematext-agent-daemonset.yml
daemonset "sematext-agent-daemonset" created

कुबेरनेट्स लॉग

कुबेरनेट्स कंटेनर के लॉग डॉक कंटेनर लॉग से बहुत अलग नहीं हैं। हालांकि, कुबेरनेट्स उपयोगकर्ताओं को तैनात पॉड्स के लिए लॉग देखने की जरूरत है। इसलिए, लॉग खोज के लिए कुबेरनेट्स-विशिष्ट जानकारी उपलब्ध होना बहुत उपयोगी है, जैसे कि -

  • कुबेरनेट्स नामस्थान
  • कुबेरनेट्स पॉड नाम
  • कुबेरनेट्स कंटेनर नाम
  • डॉकर छवि नाम
  • कुबेरनेट्स यूआईडी

एल्क स्टैक और लॉगस्पाउट का उपयोग करना

ईएलके स्टैक में एलेस्टिक्स खोज, लॉगस्टैश और किबाना शामिल हैं। लॉगिंग प्लेटफ़ॉर्म पर लॉग को इकट्ठा करने और आगे बढ़ाने के लिए, हम लॉगस्पाउट का उपयोग करेंगे (हालांकि फ़्लुएंटीडी जैसे अन्य विकल्प भी हैं)।

निम्न कोड दिखाता है कि कुबेरनेट्स पर ELK क्लस्टर कैसे स्थापित करें और ElasticSearch के लिए सेवा बनाएं -

apiVersion: v1
kind: Service
metadata:
   name: elasticsearch
   namespace: elk
   labels:
      component: elasticsearch
spec:
   type: LoadBalancer
   selector:
      component: elasticsearch
   ports:
   - name: http
      port: 9200
      protocol: TCP
   - name: transport
      port: 9300
      protocol: TCP

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

apiVersion: v1
kind: ReplicationController
metadata:
   name: es
   namespace: elk
   labels:
      component: elasticsearch
spec:
   replicas: 1
   template:
      metadata:
         labels:
            component: elasticsearch
spec:
serviceAccount: elasticsearch
containers:
   - name: es
      securityContext:
      capabilities:
      add:
      - IPC_LOCK
   image: quay.io/pires/docker-elasticsearch-kubernetes:1.7.1-4
   env:
   - name: KUBERNETES_CA_CERTIFICATE_FILE
   value: /var/run/secrets/kubernetes.io/serviceaccount/ca.crt
   - name: NAMESPACE
   valueFrom:
      fieldRef:
         fieldPath: metadata.namespace
   - name: "CLUSTER_NAME"
      value: "myesdb"
   - name: "DISCOVERY_SERVICE"
      value: "elasticsearch"
   - name: NODE_MASTER
      value: "true"
   - name: NODE_DATA
      value: "true"
   - name: HTTP_ENABLE
      value: "true"
ports:
- containerPort: 9200
   name: http
   protocol: TCP
- containerPort: 9300
volumeMounts:
- mountPath: /data
   name: storage
volumes:
   - name: storage
      emptyDir: {}

किबना यूआरएल

किबाना के लिए, हम एक पर्यावरण चर के रूप में एलेस्टिक्स खोज URL प्रदान करते हैं।

- name: KIBANA_ES_URL
value: "http://elasticsearch.elk.svc.cluster.local:9200"
- name: KUBERNETES_TRUST_CERT
value: "true"

किबाना यूआई कंटेनर पोर्ट 5601 और इसी होस्ट / नोड पोर्ट संयोजन पर उपलब्ध होगा। जब आप शुरू करते हैं, तो Kibana में कोई डेटा नहीं होगा (जो कि अपेक्षित है क्योंकि आपने कोई डेटा धक्का नहीं दिया है)।