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