कुबेरनेट्स - सेटअप

कुबेरनेट्स स्थापित करने से पहले वर्चुअल डाटासेंटर (वीडीसी) स्थापित करना महत्वपूर्ण है। इसे मशीनों के एक सेट के रूप में माना जा सकता है जहां वे नेटवर्क के माध्यम से एक-दूसरे के साथ संवाद कर सकते हैं। हाथों के दृष्टिकोण के लिए, आप 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