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>