ओपनशिफ्ट - क्लस्टर

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