mirror of
				https://github.com/linuxkit/linuxkit.git
				synced 2025-10-31 09:09:57 +00:00 
			
		
		
		
	pkg: Update the metadata package to multi-stage build and alpine base
- Use the alpine base to compile the go program - Use a multi-stage build Signed-off-by: Rolf Neugebauer <rolf.neugebauer@docker.com>
This commit is contained in:
		| @@ -1,3 +1,15 @@ | |||||||
|  | FROM linuxkit/alpine:451603daf499e3a40308dbf5571dcffed2343ffa AS mirror | ||||||
|  |  | ||||||
|  | RUN apk add --no-cache go musl-dev | ||||||
|  | ENV GOPATH=/go PATH=$PATH:/go/bin | ||||||
|  |  | ||||||
|  | COPY .  /go/src/metadata/ | ||||||
|  | RUN go-compile.sh /go/src/metadata | ||||||
|  |  | ||||||
| FROM scratch | FROM scratch | ||||||
| COPY . ./ | ENTRYPOINT [] | ||||||
|  | CMD [] | ||||||
|  | WORKDIR / | ||||||
|  | COPY --from=mirror /go/bin/metadata /usr/bin/metadata | ||||||
| CMD ["/usr/bin/metadata"] | CMD ["/usr/bin/metadata"] | ||||||
|  | LABEL org.mobyproject.config='{"net": "host", "binds": ["/dev:/dev", "/var:/var", "/tmp/etc/resolv.conf:/etc/resolv.conf"], "capabilities": ["CAP_SYS_ADMIN"]}' | ||||||
|   | |||||||
| @@ -1,45 +1,15 @@ | |||||||
| GO_COMPILE=linuxkit/go-compile:4513068d9a7e919e4ec42e2d7ee879ff5b95b7f5@sha256:bdfadbe3e4ec699ca45b67453662321ec270f2d1a1dbdbf09625776d3ebd68c5 | .PHONY: tag push | ||||||
|  | default: push | ||||||
| SHA_IMAGE=alpine:3.5@sha256:dfbd4a3a8ebca874ebd2474f044a0b33600d4523d03b0df76e5c5986cb02d7e8 |  | ||||||
|  |  | ||||||
| METADATA_BINARY=usr/bin/metadata |  | ||||||
|  |  | ||||||
| ORG?=linuxkit | ORG?=linuxkit | ||||||
| IMAGE=metadata | IMAGE=metadata | ||||||
|  | DEPS=Dockerfile Makefile $(wildcard *.go) | ||||||
|  |  | ||||||
| .PHONY: tag push clean container | HASH?=$(shell git ls-tree HEAD -- ../$(notdir $(CURDIR)) | awk '{print $$3}') | ||||||
| default: push |  | ||||||
|  |  | ||||||
| $(METADATA_BINARY): $(wildcard *.go) Makefile | tag: $(DEPS) | ||||||
| 	mkdir -p $(dir $@) | 	docker build --squash --no-cache --network=none -t $(ORG)/$(IMAGE):$(HASH) . | ||||||
| 	tar cf - $^ | docker run --rm --net=none --log-driver=none -i $(GO_COMPILE) -o $@ | tar xf - |  | ||||||
|  |  | ||||||
| DIRS=dev proc sys | push: tag | ||||||
| $(DIRS): | 	DOCKER_CONTENT_TRUST=1 docker pull $(ORG)/$(IMAGE):$(HASH) || \ | ||||||
| 	mkdir -p $@ | 	DOCKER_CONTENT_TRUST=1 docker push $(ORG)/$(IMAGE):$(HASH) | ||||||
|  |  | ||||||
| DEPS=$(DIRS) $(METADATA_BINARY) |  | ||||||
|  |  | ||||||
| container: Dockerfile $(DEPS) |  | ||||||
| 	tar cf - $^ | docker build --no-cache -t $(IMAGE):build - |  | ||||||
|  |  | ||||||
| hash: Dockerfile $(DEPS) |  | ||||||
| 	find $^ -type f | xargs cat | docker run --rm -i $(SHA_IMAGE) sha1sum - | sed 's/ .*//' > hash |  | ||||||
|  |  | ||||||
| push: hash container |  | ||||||
| 	DOCKER_CONTENT_TRUST=1 docker pull $(ORG)/$(IMAGE):$(shell cat hash) || \ |  | ||||||
| 		(docker tag $(IMAGE):build $(ORG)/$(IMAGE):$(shell cat hash) && \ |  | ||||||
| 		 DOCKER_CONTENT_TRUST=1 docker push $(ORG)/$(IMAGE):$(shell cat hash)) |  | ||||||
| 	docker rmi $(IMAGE):build |  | ||||||
| 	rm -f hash |  | ||||||
|  |  | ||||||
| tag: hash container |  | ||||||
| 	docker pull $(ORG)/$(IMAGE):$(shell cat hash) || \ |  | ||||||
| 		docker tag $(IMAGE):build $(ORG)/$(IMAGE):$(shell cat hash) |  | ||||||
| 	docker rmi $(IMAGE):build |  | ||||||
| 	rm -f hash |  | ||||||
|  |  | ||||||
| clean: |  | ||||||
| 	rm -rf hash $(DIRS) usr |  | ||||||
|  |  | ||||||
| .DELETE_ON_ERROR: |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user