OpenShift-빌드 자동화

OpenShift에는 빌드 파이프 라인을 자동화하는 여러 방법이 있습니다. 이를 위해서는 빌드 흐름을 설명하는 BuildConfig 리소스를 만들어야합니다. BuildConfig의 흐름은 Jenkins 작업 정의의 작업 정의와 비교할 수 있습니다. 빌드 흐름을 만드는 동안 빌드 전략을 선택해야합니다.

BuildConfig 파일

OpenShift에서 BuildConfig는 API에 연결 한 다음 새 인스턴스를 만드는 데 사용되는 나머지 개체입니다.

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"

OpenShift에는 네 가지 유형의 빌드 전략이 있습니다.

  • 소스-이미지 전략
  • Docker 전략
  • 맞춤형 전략
  • 파이프 라인 전략

소스-이미지 전략

소스 코드에서 시작하는 컨테이너 이미지를 만들 수 있습니다. 이 흐름에서 실제 코드는 컨테이너에 먼저 다운로드 된 다음 내부에서 컴파일됩니다. 컴파일 된 코드는 동일한 컨테이너에 배포되고 이미지는 해당 코드에서 빌드됩니다.

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

여러 전략 정책이 있습니다.

  • Forcepull
  • 증분 빌드
  • 외부 빌드

Docker 전략

이 흐름에서 OpenShift는 Dockerfile을 사용하여 이미지를 빌드 한 다음 생성 된 이미지를 Docker 레지스트리에 업로드합니다.

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

Docker 파일 옵션은 파일 경로부터 시작하여 캐시없이 강제로 가져 오기를 여러 위치에서 사용할 수 있습니다.

  • 이미지에서
  • Dockerfile 경로
  • 캐시 없음
  • 힘 당기기

맞춤형 전략

이것은 다른 종류의 빌드 전략 중 하나이며 빌드의 출력이 이미지가 될 것이라는 강박이 없습니다. Jenkins의 무료 스타일 작업과 비교할 수 있습니다. 이를 통해 Jar, rpm 및 기타 패키지를 만들 수 있습니다.

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

여러 빌드 전략으로 구성됩니다.

  • Docker 소켓 노출
  • Secrets
  • 힘 당기기

파이프 라인 전략

파이프 라인 전략은 사용자 지정 빌드 파이프 라인을 만드는 데 사용됩니다. 이것은 기본적으로 파이프 라인에서 워크 플로를 구현하는 데 사용됩니다. 이 빌드 흐름은 Groovy DSL 언어를 사용하는 사용자 지정 빌드 파이프 라인 흐름을 사용합니다. OpenShift는 Jenkins에서 파이프 라인 작업을 생성하고 실행합니다. 이 파이프 라인 흐름은 Jenkins에서도 사용할 수 있습니다. 이 전략에서는 Jenkinsfile을 사용하고이를 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>