OpenShift - Automatisation de la construction

Dans OpenShift, nous avons plusieurs méthodes pour automatiser le pipeline de construction. Pour ce faire, nous devons créer une ressource BuildConfig pour décrire le flux de génération. Le flux dans BuildConfig peut être comparé à la définition de travail dans la définition de travail Jenkins. Lors de la création du flux de build, nous devons choisir la stratégie de build.

Fichier BuildConfig

Dans OpenShift, BuildConfig est un objet de repos utilisé pour se connecter à l'API, puis créer une nouvelle instance.

kind: "BuildConfig"
apiVersion: "v1"
metadata:
   name: "<Name of build config file>"
spec:
   runPolicy: "Serial"
   triggers:
   -
      type: "GitHub"
      github:
         secret: "<Secrete file name>"
   - type: "Generic"
   generic:
      secret: "secret101"
   -
   type: "ImageChange"
   source:
      type: "<Source of code>"
      git:
   uri: "https://github.com/openshift/openshift-hello-world"
   dockerfile: "FROM openshift/openshift-22-centos7\nUSER example"
   strategy:
      type: "Source"
      
sourceStrategy:
   from:
      kind: "ImageStreamTag"
      name: "openshift-20-centos7:latest"
   output:
      to:
         kind: "ImageStreamTag"
         name: "origin-openshift-sample:latest"
   postCommit:
      script: "bundle exec rake test"

Dans OpenShift, il existe quatre types de stratégies de construction.

  • Stratégie source-image
  • Stratégie Docker
  • Stratégie personnalisée
  • Stratégie de pipeline

Stratégie source-image

Permet de créer des images de conteneurs à partir du code source. Dans ce flux, le code réel est d'abord téléchargé dans le conteneur, puis compilé à l'intérieur. Le code compilé est déployé dans le même conteneur et l'image est créée à partir de ce code.

strategy:
   type: "Source"
   sourceStrategy:
      from:
         kind: "ImageStreamTag"
         name: "builder-image:latest"
      forcePull: true

Il existe plusieurs politiques stratégiques.

  • Forcepull
  • Constructions incrémentielles
  • Constructions externes

Stratégie Docker

Dans ce flux, OpenShift utilise Dockerfile pour créer l'image, puis télécharger les images créées dans le registre Docker.

strategy:
   type: Docker
   dockerStrategy:
      from:
         kind: "ImageStreamTag"
         name: "ubuntu:latest"

L'option de fichier Docker peut être utilisée à plusieurs emplacements à partir du chemin du fichier, sans cache et de l'extraction forcée.

  • De l'image
  • Chemin Dockerfile
  • Pas de cache
  • Force de traction

Stratégie personnalisée

C'est l'un des différents types de stratégie de construction, dans lequel il n'y a pas de contrainte telle que le résultat de la construction va être une image. Cela peut être comparé à un travail de style libre de Jenkins. Avec cela, nous pouvons créer Jar, rpm et d'autres packages.

strategy:
   type: "Custom"
   customStrategy:
      from:
         kind: "DockerImage"
         name: "openshift/sti-image-builder"

Il se compose de plusieurs stratégies de construction.

  • Expose la prise Docker
  • Secrets
  • Force de traction

Stratégie de pipeline

La stratégie de pipeline est utilisée pour créer des pipelines de construction personnalisés. Ceci est essentiellement utilisé pour implémenter le flux de travail dans le pipeline. Ce flux de génération utilise un flux de pipeline de génération personnalisé à l'aide du langage Groovy DSL. OpenShift créera un travail de pipeline dans Jenkins et l'exécutera. Ce flux de pipeline peut également être utilisé dans Jenkins. Dans cette stratégie, nous utilisons Jenkinsfile et ajoutons cela dans la définition de buildconfig.

Strategy:
   type: "JenkinsPipeline"
   jenkinsPipelineStrategy:
   jenkinsfile: "node('agent') {\nstage 'build'\nopenshiftBuild(buildConfig: 'OpenShift-build', showBuildLogs: 'true')\nstage 'deploy'\nopenshiftDeploy(deploymentConfig: 'backend')\n}"

Using build pipeline

kind: "BuildConfig"
apiVersion: "v1"
metadata:
   name: "test-pipeline"
spec:
   source:
      type: "Git"
      git:
         uri: "https://github.com/openshift/openshift-hello-world"
   strategy:
      type: "JenkinsPipeline"
      jenkinsPipelineStrategy:
         jenkinsfilePath: <file path repository>