OpenShift - Anwendungsskalierung

Die automatische Skalierung ist eine Funktion in OpenShift, mit der die bereitgestellten Anwendungen nach Bedarf gemäß bestimmten Spezifikationen skaliert und abgesenkt werden können. In der OpenShift-Anwendung wird die automatische Skalierung auch als Pod-Autoskalierung bezeichnet. Es gibt zweitypes of application scaling wie folgt.

Vertikale Skalierung

Bei der vertikalen Skalierung geht es darum, einer einzelnen Maschine immer mehr Leistung hinzuzufügen, was bedeutet, dass mehr CPU und Festplatte hinzugefügt werden. Dies ist eine alte OpenShift-Methode, die jetzt von OpenShift-Versionen nicht unterstützt wird.

Horizontale Skalierung

Diese Art der Skalierung ist nützlich, wenn mehr Anforderungen verarbeitet werden müssen, indem die Anzahl der Maschinen erhöht wird.

In OpenShift gibt es two methods to enable the scaling feature.

  • Verwenden der Bereitstellungskonfigurationsdatei
  • Während Sie das Image ausführen

Verwenden der Bereitstellungskonfigurationsdatei

Bei dieser Methode wird die Skalierungsfunktion über eine Bereitstellungskonfigurations-Yaml-Datei aktiviert. Zu diesem Zweck wird der Befehl OC autoscale mit einer minimalen und maximalen Anzahl von Replikaten verwendet, die zu einem bestimmten Zeitpunkt im Cluster ausgeführt werden müssen. Wir benötigen eine Objektdefinition für die Erstellung von Autoscaler. Im Folgenden finden Sie ein Beispiel für eine Pod-Autoscaler-Definitionsdatei.

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

Sobald wir die Datei eingerichtet haben, müssen wir sie im Yaml-Format speichern und den folgenden Befehl für die Bereitstellung ausführen.

$ oc create –f <file name>.yaml

Während Sie das Image ausführen

Sie können auch ohne die yaml-Datei automatisch skalieren, indem Sie Folgendes verwenden oc autoscale Befehl in der oc-Befehlszeile.

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

Dieser Befehl generiert auch eine ähnliche Art von Datei, die später als Referenz verwendet werden kann.

Bereitstellungsstrategien in OpenShift

Die Bereitstellungsstrategie in OpenShift definiert einen Bereitstellungsfluss mit verschiedenen verfügbaren Methoden. In OpenShift sind die folgendenimportant types of deployment strategies.

  • Rollende Strategie
  • Strategie neu erstellen
  • Benutzerdefinierte Strategie

Im Folgenden finden Sie ein Beispiel für eine Bereitstellungskonfigurationsdatei, die hauptsächlich für die Bereitstellung auf OpenShift-Knoten verwendet wird.

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"

In der obigen Deploymentconfig-Datei haben wir die Strategie Rolling.

Wir können den folgenden OC-Befehl für die Bereitstellung verwenden.

$ oc deploy <deployment_config> --latest

Rollende Strategie

Die Rolling-Strategie wird für Rolling-Updates oder die Bereitstellung verwendet. Dieser Prozess unterstützt auch Lifecycle-Hooks, mit denen Code in jeden Bereitstellungsprozess eingefügt wird.

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

Strategie neu erstellen

Diese Bereitstellungsstrategie enthält einige der Grundfunktionen einer fortlaufenden Bereitstellungsstrategie und unterstützt auch den Lebenszyklus-Hook.

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

Benutzerdefinierte Strategie

Dies ist sehr hilfreich, wenn Sie einen eigenen Bereitstellungsprozess oder -ablauf bereitstellen möchten. Alle Anpassungen können je nach Anforderung vorgenommen werden.

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