ओपनशिफ्ट - क्लस्टर
OpenShift, OpenShift क्लस्टर की स्थापना के दो स्थापना विधियों का उपयोग करता है।
- त्वरित स्थापना विधि
- उन्नत विन्यास विधि
क्लस्टर की स्थापना
त्वरित स्थापना विधि
इस पद्धति का उपयोग त्वरित अप्राप्य क्लस्टर सेटअप कॉन्फ़िगरेशन को चलाने के लिए किया जाता है। इस पद्धति का उपयोग करने के लिए, हमें पहले इंस्टॉलर को स्थापित करना होगा। यह निम्न कमांड चलाकर किया जा सकता है।
Interactive method
$ atomic-openshift-installer install
यह तब उपयोगी होता है जब कोई एक इंटरैक्टिव सेटअप चलाना चाहता है।
Unattended installation method
इस विधि का उपयोग तब किया जाता है जब कोई इंस्टालेशन विधि के अनअटेंडेड तरीके को सेट करना चाहता है, जिसमें उपयोगकर्ता कॉन्फ़िगरेशन yaml फ़ाइल को परिभाषित कर सकता है और इसे नीचे रख सकता है। ~/.config/openshift/संस्थापक के नाम के साथ ।.cfg.yml। फिर, निम्न कमांड को स्थापित करने के लिए चलाया जा सकता है–u tag।
$ atomic-openshift-installer –u install
डिफ़ॉल्ट रूप से यह नीचे स्थित विन्यास फाइल का उपयोग करता है ~/.config/openshift/। दूसरी ओर Ansible स्थापना के बैकअप के रूप में उपयोग किया जाता है।
version: v2
variant: openshift-enterprise
variant_version: 3.1
ansible_log_path: /tmp/ansible.log
deployment:
ansible_ssh_user: root
hosts:
- ip: 172.10.10.1
hostname: vklnld908.int.example.com
public_ip: 24.222.0.1
public_hostname: master.example.com
roles:
- master
- node
containerized: true
connect_to: 24.222.0.1
- ip: 172.10.10.2
hostname: vklnld1446.int.example.com
public_ip: 24.222.0.2
public_hostname: node1.example.com
roles:
- node
connect_to: 10.0.0.2
- ip: 172.10.10.3
hostname: vklnld1447.int.example.com
public_ip: 10..22.2.3
public_hostname: node2.example.com
roles:
- node
connect_to: 10.0.0.3
roles:
master:
<variable_name1>: "<value1>"
<variable_name2>: "<value2>"
node:
<variable_name1>: "<value1>"
यहां, हमारे पास भूमिका-विशिष्ट चर है, जिसे परिभाषित किया जा सकता है यदि कोई विशिष्ट चर सेट करना चाहता है।
एक बार हो जाने के बाद, हम निम्नलिखित कमांड का उपयोग करके इंस्टॉलेशन को सत्यापित कर सकते हैं।
$ oc get nodes
NAME STATUS AGE
master.example.com Ready 10d
node1.example.com Ready 10d
node2.example.com Ready 10d
विकसित संस्थापन
उन्नत इंस्टॉलेशन पूरी तरह से Ansible कॉन्फ़िगरेशन पर आधारित है जिसमें मास्टर और नोड कॉन्फ़िगरेशन के बारे में संपूर्ण होस्ट कॉन्फ़िगरेशन और वैरिएबल परिभाषा मौजूद है। इसमें कॉन्फ़िगरेशन के संबंध में सभी विवरण हैं।
एक बार हमारे पास सेटअप है और प्लेबुक तैयार है, हम बस क्लस्टर को सेटअप करने के लिए निम्न कमांड को चला सकते हैं।
$ ansible-playbook -i inventry/hosts ~/openshift-ansible/playbooks/byo/config.yml
एक क्लस्टर में मेजबान जोड़ना
हम क्लस्टर का उपयोग करके एक मेजबान जोड़ सकते हैं -
- त्वरित इंस्टॉलर उपकरण
- उन्नत विन्यास विधि
Quick installation toolइंटरैक्टिव और गैर-इंटरैक्टिव मोड में दोनों काम करता है। निम्न आदेश का उपयोग करें।
$ atomic-openshift-installer -u -c </path/to/file> scaleup
एप्लिकेशन कॉन्फ़िगरेशन फ़ाइल को स्केल करने का प्रारूप दोनों मास्टर और नोड को जोड़ने के लिए उपयोग किया जा सकता है।
उन्नत विन्यास विधि
इस पद्धति में, हम Ansible की होस्ट फ़ाइल को अपडेट करते हैं और फिर इस फ़ाइल में एक नया नोड या सर्वर विवरण जोड़ते हैं। कॉन्फ़िगरेशन फ़ाइल निम्न की तरह दिखता है।
[OSEv3:children]
masters
nodes
new_nodes
new_master
उसी Ansible होस्ट फ़ाइल में, नीचे दिखाए गए अनुसार नए नोड के बारे में चर विवरण जोड़ें।
[new_nodes]
vklnld1448.int.example.com openshift_node_labels = "{'region': 'primary', 'zone': 'east'}"
अंत में, अद्यतन होस्ट फ़ाइल का उपयोग करके, नया कॉन्फ़िगरेशन चलाएं और निम्न कमांड का उपयोग करके सेटअप प्राप्त करने के लिए कॉन्फ़िगरेशन फ़ाइल को लागू करें।
$ ansible-playbook -i /inventory/hosts /usr/share/ansible/openshift-ansible/playbooks/test/openshift-node/scaleup.yml
क्लस्टर लॉग का प्रबंधन
ओपनशिफ्ट क्लस्टर लॉग कुछ भी नहीं है, लेकिन लॉग जो मास्टर और क्लस्टर की नोड मशीनों से उत्पन्न हो रहे हैं। ये सर्वर लॉग, मास्टर लॉग, कंटेनर लॉग, पॉड लॉग, आदि से शुरू होने वाले किसी भी प्रकार के लॉग का प्रबंधन कर सकते हैं। कंटेनर लॉग प्रबंधन के लिए कई प्रौद्योगिकियां और अनुप्रयोग मौजूद हैं।
कुछ उपकरण सूचीबद्ध हैं, जिन्हें लॉग प्रबंधन के लिए लागू किया जा सकता है।
- Fluentd
- ELK
- Kabna
- Nagios
- Splunk
ELK stack- सभी नोड्स से लॉग को इकट्ठा करने और उन्हें एक व्यवस्थित प्रारूप में प्रस्तुत करने की कोशिश करते समय यह स्टैक उपयोगी है। ईएलके स्टैक मुख्य रूप से तीन प्रमुख श्रेणियों में विभाजित है।
ElasticSearch - मुख्य रूप से सभी कंटेनरों से जानकारी एकत्र करने और इसे केंद्रीय स्थान पर रखने के लिए प्रतिक्रियाशील है।
Fluentd - इलास्टिक्स खोज कंटेनर इंजन में एकत्रित लॉग को खिलाने के लिए उपयोग किया जाता है।
Kibana - एक ग्राफिकल इंटरफेस का उपयोग ग्राफिकल इंटरफेस में एक उपयोगी जानकारी के रूप में एकत्रित डेटा को प्रस्तुत करने के लिए किया जाता है।
नोट करने के लिए एक महत्वपूर्ण बिंदु यह है कि जब यह सिस्टम क्लस्टर पर तैनात किया जाता है तो यह सभी नोड्स से लॉग इकट्ठा करना शुरू कर देता है।
लॉग डायग्नोस्टिक्स
ओपनशिफ्ट में एक इनबिल्ट है oc adm dignosticsOC के साथ कमांड जिसे कई त्रुटि स्थितियों के विश्लेषण के लिए उपयोग किया जा सकता है। इस उपकरण का उपयोग मास्टर से क्लस्टर व्यवस्थापक के रूप में किया जा सकता है। यह उपयोगिता बहुत उपयोगी है और ज्ञात समस्याओं का निवारण और गरिमा प्रदान करती है। यह मास्टर क्लाइंट और नोड्स पर चलता है।
यदि बिना किसी आंदोलन या झंडे के चलाया जाता है, तो यह क्लाइंट, सर्वर, और नोड मचनी की कॉन्फ़िगरेशन फ़ाइलों की तलाश करेगा, और निदान के लिए उनका उपयोग करेगा। निम्नांकित तर्कों को पारित करके निदान को व्यक्तिगत रूप से चलाया जा सकता है -
- AggregatedLogging
- AnalyzeLogs
- ClusterRegistry
- ClusterRoleBindings
- ClusterRoles
- ClusterRouter
- ConfigContexts
- DiagnosticPod
- MasterConfigCheck
- MasterNode
- MetricsApiProxy
- NetworkCheck
- NodeConfigCheck
- NodeDefinitions
- ServiceExternalIPs
- UnitStatus
एक बस उन्हें निम्नलिखित कमांड के साथ चला सकता है।
$ oc adm diagnostics <DiagnosticName>
एक क्लस्टर का उन्नयन
क्लस्टर के उन्नयन में क्लस्टर के भीतर कई चीजों को अपग्रेड करना और नए घटकों और अपग्रेड के साथ क्लस्टर को अपडेट करना शामिल है। इसमें शामिल है -
- मास्टर घटकों का उन्नयन
- नोड घटकों का उन्नयन
- नीतियों का उन्नयन
- मार्गों का उन्नयन
- छवि धारा का उन्नयन
इन सभी उन्नयनों को करने के लिए, हमें पहले स्थान पर त्वरित इंस्टॉलर या बर्तन प्राप्त करने की आवश्यकता है। उसके लिए हमें निम्नलिखित उपयोगिताओं को अपडेट करना होगा -
- atomic-openshift-utils
- atomic-openshift-excluder
- atomic-openshift-docker-excluder
- आदि पैकेज
अपग्रेड शुरू करने से पहले, हमें मास्टर मशीन पर बैकअप आदि की आवश्यकता होती है, जिसे निम्नलिखित कमांड का उपयोग करके किया जा सकता है।
$ ETCD_DATA_DIR = /var/lib/origin/openshift.local.etcd
$ etcdctl backup \
--data-dir $ETCD_DATA_DIR \
--backup-dir $ETCD_DATA_DIR.bak.<date>
मास्टर घटकों का उन्नयन
OpenShift मास्टर में, हम etcd फाइल को अपडेट करके अपग्रेड शुरू करते हैं और फिर Docker पर जाते हैं। अंत में, हम क्लस्टर को आवश्यक स्थिति में लाने के लिए स्वचालित निष्पादक चलाते हैं। हालांकि, अपग्रेड शुरू करने से पहले हमें प्रत्येक स्वामी पर परमाणु ओपनशिफ्ट पैकेज को सक्रिय करना होगा। यह निम्न आदेशों का उपयोग करके किया जा सकता है।
Step 1 - परमाणु-उत्थान संकुल हटाएं
$ atomic-openshift-excluder unexclude
Step 2 - सभी उस्तादों पर अपग्रेड वगैरह।
$ yum update etcd
Step 3 - वगैरह की सेवा फिर से शुरू करें और जांचें कि क्या यह सफलतापूर्वक शुरू हो गई है।
$ systemctl restart etcd
$ journalctl -r -u etcd
Step 4 - डॉकर पैकेज को अपग्रेड करें।
$ yum update docker
Step 5 - डॉकर सेवा को फिर से शुरू करें और जांचें कि क्या यह सही है।
$ systemctl restart docker
$ journalctl -r -u docker
Step 6 - हो जाने के बाद, निम्न कमांड के साथ सिस्टम को रिबूट करें।
$ systemctl reboot
$ journalctl -r -u docker
Step 7 - अंत में, yum को बाहर करने की सूची में संकुल को वापस लाने के लिए परमाणु-निष्पादक चलाएँ।
$ atomic-openshift-excluder exclude
पॉलिसी को अपग्रेड करने के लिए ऐसी कोई बाध्यता नहीं है, इसे केवल सिफारिश किए जाने पर अपग्रेड करने की आवश्यकता है, जिसे निम्न कमांड से जांचा जा सकता है।
$ oadm policy reconcile-cluster-roles
अधिकांश मामलों में, हमें नीति परिभाषा को अपडेट करने की आवश्यकता नहीं है।
नोड घटकों का उन्नयन
एक बार मास्टर अपडेट पूरा होने के बाद, हम नोड्स को अपग्रेड करना शुरू कर सकते हैं। एक बात का ध्यान रखें कि क्लस्टर में किसी भी तरह की समस्या से बचने के लिए अपग्रेड की अवधि कम होनी चाहिए।
Step 1 - सभी नोड्स से सभी परमाणु ओपनशिफ्ट पैकेज निकालें, जहां आप अपग्रेड करना चाहते हैं।
$ atomic-openshift-excluder unexclude
Step 2 - अगला, उन्नयन से पहले नोड शेड्यूलिंग को अक्षम करें।
$ oadm manage-node <node name> --schedulable = false
Step 3 - वर्तमान होस्ट से अन्य होस्ट के लिए सभी नोड को फिर से दोहराएं।
$ oadm drain <node name> --force --delete-local-data --ignore-daemonsets
Step 4 - होस्ट पर डॉकटर सेटअप को अपग्रेड करें।
$ yum update docker
Step 5 - डॉकर सेवा को पुनरारंभ करें और फिर डॉकर सेवा नोड शुरू करें।
$systemctl restart docker
$ systemctl restart atomic-openshift-node
Step 6 - जांचें कि दोनों सही ढंग से शुरू हुए।
$ journalctl -r -u atomic-openshift-node
Step 7 - अपग्रेड पूरा होने के बाद, नोड मशीन को रिबूट करें।
$ systemctl reboot
$ journalctl -r -u docker
Step 8 - नोड्स पर शेड्यूलिंग को फिर से सक्षम करें।
$ oadm manage-node <node> --schedulable.
Step 9 - OpenShift पैकेज को नोड पर वापस लाने के लिए परमाणु-ओपनशिफ्ट को निष्पादित करें।
$ atomic-openshift-excluder exclude
Step 10 - अंत में, जांचें कि क्या सभी नोड्स उपलब्ध हैं।
$ oc get nodes
NAME STATUS AGE
master.example.com Ready 12d
node1.example.com Ready 12d
node2.example.com Ready 12d