Improve Docker build
This commit is contained in:
		
							parent
							
								
									e9f5df2eb3
								
							
						
					
					
						commit
						667d263f7d
					
				
							
								
								
									
										53
									
								
								Dockerfile
								
								
								
								
							
							
						
						
									
										53
									
								
								Dockerfile
								
								
								
								
							|  | @ -1,53 +0,0 @@ | ||||||
| FROM docker:18.09 |  | ||||||
| 
 |  | ||||||
| ARG GO_VERSION |  | ||||||
| ARG OPERATOR_SDK_VERSION |  | ||||||
| ARG MINIKUBE_VERSION |  | ||||||
| 
 |  | ||||||
| ARG GOPATH="/go" |  | ||||||
| 
 |  | ||||||
| RUN mkdir -p /go |  | ||||||
| 
 |  | ||||||
| # Stage 1 - Install dependencies |  | ||||||
| RUN apk update && \ |  | ||||||
|     apk add --no-cache \ |  | ||||||
|             curl \ |  | ||||||
|             python \ |  | ||||||
|             py-crcmod \ |  | ||||||
|             bash \ |  | ||||||
|             libc6-compat \ |  | ||||||
|             openssh-client \ |  | ||||||
|             git \ |  | ||||||
|             make \ |  | ||||||
|             gcc \ |  | ||||||
|             libc-dev \ |  | ||||||
|             git \ |  | ||||||
|             mercurial |  | ||||||
| 
 |  | ||||||
| RUN curl -O https://storage.googleapis.com/golang/go$GO_VERSION.linux-amd64.tar.gz && tar -xvf go$GO_VERSION.linux-amd64.tar.gz |  | ||||||
| 
 |  | ||||||
| # Stage 2 - Install operator-sdk |  | ||||||
| RUN echo $GOPATH/bin/operator-sdk |  | ||||||
| RUN curl -L https://github.com/operator-framework/operator-sdk/releases/download/v$OPERATOR_SDK_VERSION/operator-sdk-v$OPERATOR_SDK_VERSION-x86_64-linux-gnu -o $GOPATH/bin/operator-sdk \ |  | ||||||
|     && chmod +x $GOPATH/bin/operator-sdk |  | ||||||
| 
 |  | ||||||
| RUN curl -Lo minikube https://storage.googleapis.com/minikube/releases/v$MINIKUBE_VERSION/minikube-linux-amd64 \ |  | ||||||
|     && chmod +x minikube \ |  | ||||||
|     && cp minikube /usr/local/bin/ \ |  | ||||||
|     && rm minikube |  | ||||||
| 
 |  | ||||||
| RUN curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl \ |  | ||||||
|     && chmod +x ./kubectl \ |  | ||||||
|     && mv ./kubectl /usr/local/bin/kubectl |  | ||||||
| 
 |  | ||||||
| RUN export GO111MODULE=auto |  | ||||||
| 
 |  | ||||||
| RUN mkdir -p $GOPATH/src/github.com/jenkinsci/kubernetes-operator |  | ||||||
| WORKDIR $GOPATH/src/github.com/jenkinsci/kubernetes-operator |  | ||||||
| 
 |  | ||||||
| RUN mkdir -p /home/builder |  | ||||||
| 
 |  | ||||||
| ENV DOCKER_TLS_VERIFY   1 |  | ||||||
| ENV DOCKER_CERT_PATH    /minikube/certs |  | ||||||
| 
 |  | ||||||
| ENTRYPOINT ["./entrypoint.sh"] |  | ||||||
							
								
								
									
										30
									
								
								Makefile
								
								
								
								
							
							
						
						
									
										30
									
								
								Makefile
								
								
								
								
							|  | @ -293,7 +293,11 @@ docker-login: ## Log in into the Docker repository | ||||||
| .PHONY: docker-build | .PHONY: docker-build | ||||||
| docker-build: check-env ## Build the container
 | docker-build: check-env ## Build the container
 | ||||||
| 	@echo "+ $@" | 	@echo "+ $@" | ||||||
| 	docker build . -t $(DOCKER_REGISTRY):$(GITCOMMIT) --file build/Dockerfile | 	docker build \
 | ||||||
|  | 	--build-arg GO_VERSION=$(GO_VERSION) \
 | ||||||
|  | 	--build-arg OPERATOR_SDK_VERSION=$(OPERATOR_SDK_VERSION) \
 | ||||||
|  | 	-t $(DOCKER_REGISTRY):$(GITCOMMIT) . \
 | ||||||
|  | 	--file build/Dockerfile | ||||||
| 
 | 
 | ||||||
| .PHONY: docker-images | .PHONY: docker-images | ||||||
| docker-images: ## List all local containers
 | docker-images: ## List all local containers
 | ||||||
|  | @ -415,30 +419,6 @@ endif | ||||||
| 	go mod vendor -v | 	go mod vendor -v | ||||||
| 	@echo | 	@echo | ||||||
| 
 | 
 | ||||||
| .PHONY: image |  | ||||||
| image: ## Create the docker image from the Dockerfile. This image is used to build linux binary regardless of the system on the host
 |  | ||||||
| 	@echo "+ $@" |  | ||||||
| 	docker build --rm --force-rm --no-cache \
 |  | ||||||
| 	--build-arg GO_VERSION=$(GO_VERSION) \
 |  | ||||||
| 	--build-arg MINIKUBE_VERSION=$(MINIKUBE_VERSION) \
 |  | ||||||
| 	--build-arg OPERATOR_SDK_VERSION=$(OPERATOR_SDK_VERSION) \
 |  | ||||||
| 	-t jenkins-operator/runner . |  | ||||||
| 
 |  | ||||||
| .PHONY: indocker |  | ||||||
| PWD := $(shell pwd) |  | ||||||
| DOCKER_HOST_IP := $(shell minikube docker-env | grep DOCKER_HOST | cut -d '"' -f 2 2> /dev/null) |  | ||||||
| MINIKUBE_IP := $(shell minikube ip 2> /dev/null) |  | ||||||
| indocker: minikube-start image ## Run make in a docker container
 |  | ||||||
| 	@echo "+ $@" |  | ||||||
| 	docker run --rm -it $(DOCKER_FLAGS) \
 |  | ||||||
| 		-v /var/run/docker.sock:/var/run/docker.sock \
 |  | ||||||
| 		--mount type=bind,source=$(PWD),target=/go/src/github.com/jenkinsci/kubernetes-operator \
 |  | ||||||
| 		--mount type=bind,source=$(HOME)/.minikube,target=/minikube \
 |  | ||||||
| 		--mount type=bind,source=$(HOME)/.kube,target=/home/builder/.kube \
 |  | ||||||
| 		-e DOCKER_HOST=$(DOCKER_HOST_IP) \
 |  | ||||||
| 		-e MINIKUBE_IP=$(MINIKUBE_IP) \
 |  | ||||||
| 		jenkins-operator/runner |  | ||||||
| 
 |  | ||||||
| .PHONY: travis-prepare | .PHONY: travis-prepare | ||||||
| travis-prepare: | travis-prepare: | ||||||
| 	@echo "+ $@" | 	@echo "+ $@" | ||||||
|  |  | ||||||
|  | @ -1,7 +1,21 @@ | ||||||
| FROM alpine:3.8 | ARG GO_VERSION | ||||||
|  | 
 | ||||||
|  | # build stage | ||||||
|  | FROM golang:$GO_VERSION-alpine3.10 AS build-stage | ||||||
|  | ARG OPERATOR_SDK_VERSION | ||||||
|  | ENV GO111MODULE=on | ||||||
|  | RUN apk --no-cache add git curl make \ | ||||||
|  |     && curl -L https://github.com/operator-framework/operator-sdk/releases/download/v$OPERATOR_SDK_VERSION/operator-sdk-v$OPERATOR_SDK_VERSION-x86_64-linux-gnu -o /usr/local/bin/operator-sdk \ | ||||||
|  |     && chmod +x /usr/local/bin/operator-sdk | ||||||
|  | ADD . /kubernetes-operator | ||||||
|  | 
 | ||||||
|  | RUN cd /kubernetes-operator && make build | ||||||
|  | 
 | ||||||
|  | # run stage | ||||||
|  | FROM alpine:3.10 | ||||||
| 
 | 
 | ||||||
| USER nobody | USER nobody | ||||||
| 
 | 
 | ||||||
| ADD build/_output/bin/jenkins-operator /usr/local/bin/jenkins-operator | COPY --from=build-stage /kubernetes-operator/build/_output/bin/jenkins-operator /usr/local/bin/jenkins-operator | ||||||
| 
 | 
 | ||||||
| CMD [ "/usr/local/bin/jenkins-operator" ] | CMD [ "/usr/local/bin/jenkins-operator" ] | ||||||
|  |  | ||||||
|  | @ -1,19 +0,0 @@ | ||||||
| #!/bin/bash |  | ||||||
| 
 |  | ||||||
| export GOPATH=/go |  | ||||||
| export PATH=$PATH:/usr/local/go/bin:$GOPATH/bin |  | ||||||
| export GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| kubectl config set-cluster minikube --server=https://$MINIKUBE_IP:8443 \ |  | ||||||
|       --certificate-authority=/minikube/ca.crt && \ |  | ||||||
|     kubectl config set-credentials minikube --certificate-authority=/root/.minikube/ca.crt \ |  | ||||||
|       --client-key=/minikube/client.key \ |  | ||||||
|       --client-certificate=/minikube/client.crt && \ |  | ||||||
|     kubectl config set-context minikube --cluster=minikube --user=minikube && \ |  | ||||||
|     kubectl config use-context minikube |  | ||||||
| 
 |  | ||||||
| make go-dependencies |  | ||||||
| ln -s $GOPATH/src/github.com/jenkinsci/kubernetes-operator/vendor/k8s.io $GOPATH/src/k8s.i |  | ||||||
| ln -s $GOPATH/src/github.com/jenkinsci/kubernetes-operator/vendor/sigs.k8s.io $GOPATH/src/sigs.k8s.io |  | ||||||
| 
 |  | ||||||
| bash |  | ||||||
		Loading…
	
		Reference in New Issue