OpenShift - Application Scaling

Penskalaan otomatis adalah fitur dalam OpenShift tempat aplikasi yang disinkronkan dapat menskalakan dan tenggelam saat dan saat diminta sesuai spesifikasi tertentu. Dalam aplikasi OpenShift, penskalaan otomatis juga dikenal sebagai penskalaan otomatis pod. Ada duatypes of application scaling sebagai berikut.

Penskalaan Vertikal

Penskalaan vertikal adalah tentang menambahkan lebih banyak daya ke satu mesin yang berarti menambahkan lebih banyak CPU dan hard disk. Ini adalah metode lama OpenShift yang sekarang tidak didukung oleh rilis OpenShift.

Penskalaan Horizontal

Jenis penskalaan ini berguna ketika ada kebutuhan untuk menangani lebih banyak permintaan dengan menambah jumlah mesin.

Di OpenShift, ada two methods to enable the scaling feature.

  • Menggunakan file konfigurasi penerapan
  • Saat menjalankan gambar

Menggunakan File Konfigurasi Penerapan

Dalam metode ini, fitur penskalaan diaktifkan melalui file yaml konfigurasi deploymant. Untuk ini, perintah OC autoscale digunakan dengan jumlah minimum dan maksimum replika, yang perlu dijalankan pada titik waktu tertentu dalam cluster. Kami membutuhkan definisi objek untuk pembuatan autoscaler. Berikut adalah contoh file definisi pod autoscaler.

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

Setelah kami memiliki file di tempatnya, kami perlu menyimpannya dengan format yaml dan menjalankan perintah berikut untuk penyebaran.

$ oc create –f <file name>.yaml

Saat Menjalankan Gambar

Seseorang juga dapat melakukan penskalaan otomatis tanpa file yaml, dengan menggunakan yang berikut ini oc autoscale perintah di baris perintah oc.

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

Perintah ini juga akan menghasilkan jenis file serupa yang nantinya dapat digunakan sebagai referensi.

Strategi Penerapan di OpenShift

Strategi penyebaran di OpenShift menentukan aliran penerapan dengan berbagai metode yang tersedia. Di OpenShift, berikut ini adalahimportant types of deployment strategies.

  • Strategi bergulir
  • Buat kembali strategi
  • Strategi kustom

Berikut adalah contoh file konfigurasi penerapan, yang digunakan terutama untuk penerapan pada node 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"

Dalam file Deploymentconfig di atas, kami memiliki strategi sebagai Rolling.

Kita dapat menggunakan perintah OC berikut untuk penyebaran.

$ oc deploy <deployment_config> --latest

Strategi Bergulir

Strategi bergulir digunakan untuk pembaruan bergulir atau penerapan. Proses ini juga mendukung pengait siklus hidup, yang digunakan untuk memasukkan kode ke dalam proses penerapan apa pun.

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

Buat kembali Strategi

Strategi penerapan ini memiliki beberapa fitur dasar dari strategi penerapan bergulir dan juga mendukung pengait siklus hidup.

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

Strategi Kustom

Ini sangat membantu ketika seseorang ingin menyediakan proses atau alur penerapannya sendiri. Semua kustomisasi dapat dilakukan sesuai kebutuhan.

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