OpenShift - अनुप्रयोग स्केलिंग

ऑटोकैसलिंग ओपनशिफ्ट में एक ऐसी सुविधा है जहां पर तैनात अनुप्रयोग कुछ विशिष्ट विनिर्देशों के रूप में और जब आवश्यक हो तब स्केल कर सकते हैं। OpenShift एप्लिकेशन में, ऑटोस्क्लिगिंग को पॉड ऑटोस्कोलिंग के रूप में भी जाना जाता है। वहाँ दॊ हैtypes of application scaling निम्नलिखित नुसार।

लंबवत स्केलिंग

वर्टिकल स्केलिंग एक मशीन में अधिक से अधिक शक्ति जोड़ने का मतलब है जिसमें अधिक CPU और हार्ड डिस्क को जोड़ना है। OpenShift की एक पुरानी पद्धति है जो अब OpenShift रिलीज़ द्वारा समर्थित नहीं है।

क्षैतिज स्केलिंग

इस प्रकार की स्केलिंग तब उपयोगी होती है जब मशीनों की संख्या बढ़ाकर अधिक अनुरोध को संभालने की आवश्यकता होती है।

OpenShift में, हैं two methods to enable the scaling feature

  • परिनियोजन कॉन्फ़िगरेशन फ़ाइल का उपयोग करना
  • प्रतिमा चलाते समय

परिनियोजन कॉन्फ़िगरेशन फ़ाइल का उपयोग करना

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

apiVersion: extensions/v1beta1
kind: HorizontalPodAutoscaler
metadata:
   name: database
spec:
   scaleRef:
      kind: DeploymentConfig
      name: database
      apiVersion: v1
      subresource: scale
   minReplicas: 1
   maxReplicas: 10
   cpuUtilization:
      targetPercentage: 80

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

$ oc create –f <file name>.yaml

छवि चलाते हुए

निम्नलिखित का उपयोग करके, यमल फ़ाइल के बिना भी ऑटोस्कोप किया जा सकता है oc autoscale महासागर कमांड लाइन में कमांड।

$ oc autoscale dc/database --min 1 --max 5 --cpu-percent = 75
deploymentconfig "database" autoscaled

यह कमांड एक समान प्रकार की फ़ाइल भी उत्पन्न करेगा जिसे बाद में संदर्भ के लिए उपयोग किया जा सकता है।

OpenShift में परिनियोजन रणनीतियाँ

OpenShift में परिनियोजन रणनीति विभिन्न उपलब्ध विधियों के साथ परिनियोजन के प्रवाह को परिभाषित करती है। OpenShift में, निम्नलिखित हैंimportant types of deployment strategies

  • रोलिंग की रणनीति
  • फिर से बनाने की रणनीति
  • कस्टम रणनीति

निम्नलिखित परिनियोजन कॉन्फ़िगरेशन फ़ाइल का एक उदाहरण है, जो मुख्य रूप से OpenShift नोड्स पर परिनियोजन के लिए उपयोग किया जाता है।

kind: "DeploymentConfig"
apiVersion: "v1"
metadata:
   name: "database"
spec:
   template:
      metadata:
         labels:
            name: "Database1"
spec:
   containers:
      - name: "vipinopenshifttest"
         image: "openshift/mongoDB"
         ports:
            - containerPort: 8080
               protocol: "TCP"
replicas: 5
selector:
   name: "database"
triggers:
- type: "ConfigChange"
- type: "ImageChange"
   imageChangeParams:
      automatic: true
      containerNames:
         - "vipinopenshifttest"
      from:
         kind: "ImageStreamTag"
         name: "mongoDB:latest"
   strategy:
      type: "Rolling"

ऊपर की तैनाती फ़ाइल में, हमारे पास रोलिंग के रूप में रणनीति है।

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

$ oc deploy <deployment_config> --latest

रोलिंग की रणनीति

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

strategy:
   type: Rolling
   rollingParams:
      timeoutSeconds: <time in seconds>
      maxSurge: "<definition in %>"
      maxUnavailable: "<Defintion in %>"
      pre: {}
      post: {}

रणनीति बनाना

इस परिनियोजन रणनीति में रोलिंग परिनियोजन रणनीति की कुछ बुनियादी विशेषताएं हैं और यह जीवन-चक्र हुक का भी समर्थन करता है।

strategy:
   type: Recreate
   recreateParams:
      pre: {}
      mid: {}
      post: {}

कस्टम रणनीति

यह तब बहुत मददगार होता है जब कोई अपनी खुद की तैनाती प्रक्रिया या प्रवाह प्रदान करना चाहता है। आवश्यकता के अनुसार सभी अनुकूलन किए जा सकते हैं।

strategy:
   type: Custom
   customParams:
      image: organization/mongoDB
      command: [ "ls -l", "$HOME" ]
      environment:
         - name: VipinOpenshiftteat
         value: Dev1