Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add s390x support on multiarch docker images #2948

Merged
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
bae83d3
Add s390x support on multiarch docker images
kun-lu20 Mar 19, 2021
4c6cabb
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Apr 21, 2021
c0de24a
Update tag computation and Dockerfile
kun-lu20 Apr 23, 2021
d973031
Optimize the code changes
kun-lu20 Apr 26, 2021
5273aa3
Optimize the code changes - update
kun-lu20 Apr 28, 2021
ef2e8a2
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Apr 28, 2021
edb391d
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 May 3, 2021
7974892
Optimize the code changes - update
kun-lu20 May 4, 2021
a0362fc
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 May 5, 2021
2613b6c
Optimize the code changes - update
kun-lu20 May 10, 2021
119d8e8
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 May 11, 2021
321907c
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 May 14, 2021
170b373
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 May 28, 2021
23ede72
upgrade the base image version
kun-lu20 May 28, 2021
54ba010
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Jun 11, 2021
027376a
Create a common shared script for docker images
kun-lu20 Jun 11, 2021
5a6b268
Refactor update
kun-lu20 Jun 14, 2021
2960e88
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Jun 14, 2021
ba3e9bc
Remove cross-script dependencies of debugimg name
kun-lu20 Jun 15, 2021
2acd49f
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Jun 17, 2021
4e4fcbb
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Jun 23, 2021
878e983
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Jun 24, 2021
18aad23
Fix the indentation issue
kun-lu20 Jun 24, 2021
56f3e4f
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Jun 25, 2021
c492340
Add comment in debug Dockerfile
kun-lu20 Jun 25, 2021
a62c82f
Merge branch 'master' into enablement_docker_images_on_s390x
kun-lu20 Jun 30, 2021
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions .github/workflows/ci-all-in-one-build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,11 @@ on:
jobs:
all-in-one:
runs-on: ubuntu-latest
services:
registry:
image: registry:2
ports:
- 5000:5000
jpkrohling marked this conversation as resolved.
Show resolved Hide resolved
steps:
- uses: actions/[email protected]
with:
Expand All @@ -31,6 +36,12 @@ jobs:

- name: Install tools
run: make install-ci

- uses: docker/setup-qemu-action@v1

- uses: docker/setup-buildx-action@v1
with:
driver-opts: network=host

- name: Build, test, and publish all-in-one image
run: bash scripts/build-all-in-one-image.sh
Expand Down
11 changes: 11 additions & 0 deletions .github/workflows/ci-crossdock.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,11 @@ on:
jobs:
crossdock:
runs-on: ubuntu-latest
services:
registry:
image: registry:2
ports:
- 5000:5000
strategy:
matrix:
steps:
Expand All @@ -33,6 +38,12 @@ jobs:

- name: Install tools
run: make install-ci

- uses: docker/setup-qemu-action@v1

- uses: docker/setup-buildx-action@v1
with:
driver-opts: network=host

- name: Build, test, and publish ${{ matrix.steps.name }} image
run: ${{ matrix.steps.cmd }}
Expand Down
18 changes: 14 additions & 4 deletions .github/workflows/ci-docker-build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,13 @@ on:
jobs:
docker-images:
runs-on: ubuntu-latest

services:
registry:
image: registry:2
ports:
- 5000:5000

steps:
- uses: actions/[email protected]
with:
Expand All @@ -32,11 +39,14 @@ jobs:
- name: Install tools
run: make install-ci

- name: Build docker images
run: make docker
jpkrohling marked this conversation as resolved.
Show resolved Hide resolved
- uses: docker/setup-qemu-action@v1

- name: Upload docker images
run: bash scripts/upload-all-docker-images.sh
- uses: docker/setup-buildx-action@v1
with:
driver-opts: network=host

- name: Build and upload all docker images
run: bash scripts/build-upload-docker-images.sh
env:
DOCKERHUB_TOKEN: ${{ secrets.DOCKERHUB_TOKEN }}
QUAY_TOKEN: ${{ secrets.QUAY_TOKEN }}
11 changes: 11 additions & 0 deletions .github/workflows/ci-hotrod.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,11 @@ on:
jobs:
hotrod:
runs-on: ubuntu-latest
services:
registry:
image: registry:2
ports:
- 5000:5000
steps:
- uses: actions/[email protected]
with:
Expand All @@ -27,6 +32,12 @@ jobs:

- name: Install tools
run: make install-ci

- uses: docker/setup-qemu-action@v1

- uses: docker/setup-buildx-action@v1
with:
driver-opts: network=host

- name: Build, test, and publish hotrod image
run: bash scripts/hotrod-integration-test.sh
Expand Down
19 changes: 13 additions & 6 deletions .github/workflows/ci-release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@ on:
jobs:
publish-release:
runs-on: ubuntu-latest
services:
registry:
image: registry:2
ports:
- 5000:5000

steps:
- uses: actions/[email protected]
with:
Expand Down Expand Up @@ -49,13 +55,14 @@ jobs:
repo_token: ${{ secrets.GITHUB_TOKEN }}
if: steps.package-binaries.outcome == 'success'

- name: Build docker images
id: build-images
run: make docker
- uses: docker/setup-qemu-action@v1

- name: Upload docker images
run: bash scripts/upload-all-docker-images.sh
if: steps.build-images.outcome == 'success'
- uses: docker/setup-buildx-action@v1
with:
driver-opts: network=host

- name: Build and upload all docker images
run: bash scripts/build-upload-docker-images.sh
env:
DOCKERHUB_TOKEN: ${{ secrets.DOCKERHUB_TOKEN }}
QUAY_TOKEN: ${{ secrets.QUAY_TOKEN }}
Expand Down
29 changes: 10 additions & 19 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -269,9 +269,6 @@ build-collector build-collector-debug:
build-ingester build-ingester-debug:
$(GOBUILD) $(DISABLE_OPTIMIZATIONS) -o ./cmd/ingester/ingester$(SUFFIX)-$(GOOS)-$(GOARCH) $(BUILD_INFO) ./cmd/ingester/main.go

.PHONY: docker
jpkrohling marked this conversation as resolved.
Show resolved Hide resolved
docker: build-binaries-linux docker-images-only

.PHONY: build-binaries-linux
build-binaries-linux:
GOOS=linux GOARCH=amd64 $(MAKE) build-platform-binaries
Expand Down Expand Up @@ -308,7 +305,8 @@ build-platform-binaries: build-agent \
build-all-in-one \
build-examples \
build-tracegen \
build-anonymizer
build-anonymizer \
build-esmapping-generator

.PHONY: build-all-platforms
build-all-platforms: build-binaries-linux build-binaries-windows build-binaries-darwin build-binaries-s390x build-binaries-arm64 build-binaries-ppc64le
Expand All @@ -319,9 +317,10 @@ docker-images-cassandra:
@echo "Finished building jaeger-cassandra-schema =============="

.PHONY: docker-images-elastic
docker-images-elastic: build-esmapping-generator-linux
docker-images-elastic:
GOOS=linux GOARCH=$(GOARCH) $(MAKE) build-esmapping-generator
docker build -t $(DOCKER_NAMESPACE)/jaeger-es-index-cleaner:${DOCKER_TAG} plugin/storage/es
docker build -t $(DOCKER_NAMESPACE)/jaeger-es-rollover:${DOCKER_TAG} plugin/storage/es -f plugin/storage/es/Dockerfile.rollover
docker build -t $(DOCKER_NAMESPACE)/jaeger-es-rollover:${DOCKER_TAG} plugin/storage/es -f plugin/storage/es/Dockerfile.rollover --build-arg TARGETARCH=$(GOARCH)
@echo "Finished building jaeger-es-indices-clean =============="

docker-images-jaeger-backend: TARGET = release
Expand Down Expand Up @@ -358,21 +357,13 @@ docker-images-only: docker-images-cassandra \
docker-images-tracegen \
docker-images-anonymizer

.PHONY: docker-push
docker-push:
@while [ -z "$$CONFIRM" ]; do \
read -r -p "Do you really want to push images to repository \"${DOCKER_NAMESPACE}\"? [y/N] " CONFIRM; \
done ; \
if [ $$CONFIRM != "y" ] && [ $$CONFIRM != "Y" ]; then \
echo "Exiting." ; exit 1 ; \
fi
for component in agent cassandra-schema es-index-cleaner es-rollover collector query ingester example-hotrod tracegen anonymizer; do \
docker push $(DOCKER_NAMESPACE)/jaeger-$$component ; \
done
.PHONY: build-crossdock-binary
build-crossdock-binary:
$(GOBUILD) -o ./crossdock/crossdock-$(GOOS)-$(GOARCH) ./crossdock/main.go

.PHONY: build-crossdock-linux
build-crossdock-linux:
GOOS=linux $(GOBUILD) -o ./crossdock/crossdock-linux ./crossdock/main.go
GOOS=linux $(MAKE) build-crossdock-binary

include crossdock/rules.mk

Expand All @@ -385,7 +376,7 @@ build-crossdock-ui-placeholder:

.PHONY: build-crossdock
build-crossdock: build-crossdock-ui-placeholder build-binaries-linux build-crossdock-linux docker-images-cassandra docker-images-jaeger-backend
docker build -t $(DOCKER_NAMESPACE)/test-driver:${DOCKER_TAG} crossdock/
docker build -t $(DOCKER_NAMESPACE)/test-driver:${DOCKER_TAG} --build-arg TARGETARCH=$(GOARCH) crossdock/
@echo "Finished building test-driver ==============" ; \

.PHONY: build-and-run-crossdock
Expand Down
2 changes: 1 addition & 1 deletion cmd/agent/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ ARG base_image
ARG debug_image

FROM $base_image AS release
ARG TARGETARCH=amd64
ARG TARGETARCH
ARG USER_UID=10001
COPY agent-linux-$TARGETARCH /go/bin/agent-linux
EXPOSE 5775/udp 6831/udp 6832/udp 5778/tcp
Expand Down
2 changes: 1 addition & 1 deletion cmd/all-in-one/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ ARG base_image
ARG debug_image

FROM $base_image AS release
ARG TARGETARCH=amd64
ARG TARGETARCH

# Agent zipkin.thrift compact
EXPOSE 5775/udp
Expand Down
2 changes: 1 addition & 1 deletion cmd/anonymizer/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
FROM scratch
ARG TARGETARCH=amd64
ARG TARGETARCH

COPY anonymizer-linux-$TARGETARCH /go/bin/anonymizer-linux
ENTRYPOINT ["/go/bin/anonymizer-linux"]
2 changes: 1 addition & 1 deletion cmd/collector/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ ARG base_image
ARG debug_image

FROM $base_image AS release
ARG TARGETARCH=amd64
ARG TARGETARCH
COPY collector-linux-$TARGETARCH /go/bin/collector-linux
EXPOSE 14250/tcp
ENTRYPOINT ["/go/bin/collector-linux"]
Expand Down
2 changes: 1 addition & 1 deletion cmd/ingester/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ ARG base_image
ARG debug_image

FROM $base_image AS release
ARG TARGETARCH=amd64
ARG TARGETARCH
COPY ingester-linux-$TARGETARCH /go/bin/ingester-linux
EXPOSE 14270/tcp 14271/tcp
ENTRYPOINT ["/go/bin/ingester-linux"]
Expand Down
2 changes: 1 addition & 1 deletion cmd/query/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ ARG base_image
ARG debug_image

FROM $base_image AS release
ARG TARGETARCH=amd64
ARG TARGETARCH
COPY query-linux-$TARGETARCH /go/bin/query-linux
EXPOSE 16686/tcp
ENTRYPOINT ["/go/bin/query-linux"]
Expand Down
2 changes: 1 addition & 1 deletion cmd/tracegen/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
FROM scratch
ARG TARGETARCH=amd64
ARG TARGETARCH

COPY tracegen-linux-$TARGETARCH /go/bin/tracegen-linux
ENTRYPOINT ["/go/bin/tracegen-linux"]
3 changes: 2 additions & 1 deletion crossdock/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
FROM scratch
ARG TARGETARCH

COPY crossdock-linux /go/bin/
COPY crossdock-linux-$TARGETARCH /go/bin/crossdock-linux

EXPOSE 8080
ENTRYPOINT ["/go/bin/crossdock-linux"]
11 changes: 7 additions & 4 deletions docker/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -3,18 +3,21 @@ ROOT_IMAGE ?= alpine:3.13
CERT_IMAGE := alpine:3.13
kun-lu20 marked this conversation as resolved.
Show resolved Hide resolved
GOLANG_IMAGE := golang:1.15-alpine

BASE_IMAGE := localhost/baseimg:$(VERSION)-$(shell echo $(ROOT_IMAGE) | tr : -)
DEBUG_IMAGE := localhost/debugimg:$(VERSION)-$(shell echo $(GOLANG_IMAGE) | tr : -)
BASE_IMAGE := localhost:5000/baseimg:$(VERSION)-$(shell echo $(ROOT_IMAGE) | tr : -)
DEBUG_IMAGE := localhost:5000/debugimg:$(VERSION)-$(shell echo $(GOLANG_IMAGE) | tr : -)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why do we encode the versions of base images instead of giving them a stable local name? When we include versions we're creating cross-script dependencies which require other scripts to be cognizant of the versions, e.g. base_debug_img_arg="--build-arg base_image=localhost:5000/baseimg:1.0.0-alpine-3.13 --build-arg debug_image=golang:1.15-alpine "

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, you're right, I'll change the names of base image and debug image to stable local names. Thanks!

Copy link
Contributor Author

@kun-lu20 kun-lu20 Jun 14, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @yurishkuro , I've changed the names of baseimg and debugimg to stable local names. I still set the debug_image arg to golang:1.15-alpine for building multi-arch release version images in build-all-in-one-image.sh and build-upload-docker-images.sh, since the built debugimg doe not support s390x yet (due to lack of go-delve support on s390x). For building amd64 debug version images, the debug_image arg is set to the stable local name.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @yurishkuro , I've made some changes to remove cross-script dependencies of debug_image image names. Please take a look when you are available. Thanks!

PLATFORMS := linux/amd64,linux/s390x

create-baseimg-debugimg: create-baseimg create-debugimg

create-baseimg:
docker build -t $(BASE_IMAGE) \
docker buildx build -t $(BASE_IMAGE) --push \
--build-arg root_image=$(ROOT_IMAGE) \
--build-arg cert_image=$(CERT_IMAGE) \
--platform=$(PLATFORMS) \
docker/base

create-debugimg:
docker build -t $(DEBUG_IMAGE) \
docker buildx build -t $(DEBUG_IMAGE) --push \
--build-arg golang_image=$(GOLANG_IMAGE) \
--platform=linux/amd64 \
docker/debug
2 changes: 1 addition & 1 deletion examples/hotrod/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
FROM scratch
ARG TARGETARCH=amd64
ARG TARGETARCH
EXPOSE 8080 8081 8082 8083
COPY hotrod-linux-$TARGETARCH /go/bin/hotrod-linux
ENTRYPOINT ["/go/bin/hotrod-linux"]
Expand Down
3 changes: 2 additions & 1 deletion plugin/storage/es/Dockerfile.rollover
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
FROM python:3-alpine3.11
ARG TARGETARCH

# Temporary fix for https://github.com/jaegertracing/jaeger/issues/1494
RUN pip install urllib3==1.24.3

RUN pip install elasticsearch elasticsearch-curator
COPY ./mappings/* /mappings/
COPY esRollover.py /es-rollover/
COPY esmapping-generator /usr/bin/
COPY esmapping-generator-linux-$TARGETARCH /usr/bin/esmapping-generator

ENTRYPOINT ["python3", "/es-rollover/esRollover.py"]
47 changes: 18 additions & 29 deletions scripts/build-all-in-one-image.sh
Original file line number Diff line number Diff line change
Expand Up @@ -34,36 +34,25 @@ run_integration_test() {
docker kill $CID
}

upload_to_docker() {
# Only push the docker image to dockerhub/quay.io for master/release branch
if [[ "$BRANCH" == "master" || $BRANCH =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "upload $1 to dockerhub/quay.io"
REPO=$1
bash scripts/upload-to-registry.sh $REPO
else
echo 'skip docker images upload for PR'
fi
}

make build-all-in-one GOOS=linux GOARCH=$GOARCH
make create-baseimg-debugimg

make build-all-in-one GOOS=linux GOARCH=amd64
make build-all-in-one GOOS=linux GOARCH=s390x
platforms="linux/amd64,linux/s390x"
repo=jaegertracing/all-in-one
docker build -f cmd/all-in-one/Dockerfile \
--target release \
--tag $repo:latest cmd/all-in-one \
--build-arg base_image=localhost/baseimg:1.0.0-alpine-3.12 \
--build-arg debug_image=localhost/debugimg:1.0.0-golang-1.15-alpine \
--build-arg TARGETARCH=$GOARCH
run_integration_test $repo
upload_to_docker $repo
base_debug_img_arg="--build-arg base_image=localhost:5000/baseimg:1.0.0-alpine-3.13 --build-arg debug_image=golang:1.15-alpine "
#build all-in-one image locally for integration test
bash scripts/build-upload-a-docker-image.sh -l -c all-in-one -b "${base_debug_img_arg}" -d cmd/all-in-one -p "${platforms}" -t release
run_integration_test localhost:5000/$repo
#build all-in-one image and upload to dockerhub/quay.io
bash scripts/build-upload-a-docker-image.sh -c all-in-one -b "${base_debug_img_arg}" -d cmd/all-in-one -p "${platforms}" -t release


make build-all-in-one-debug GOOS=linux GOARCH=$GOARCH
repo=jaegertracing/all-in-one-debug
docker build -f cmd/all-in-one/Dockerfile \
--target debug \
--tag $repo:latest cmd/all-in-one \
--build-arg base_image=localhost/baseimg:1.0.0-alpine-3.12 \
--build-arg debug_image=localhost/debugimg:1.0.0-golang-1.15-alpine \
--build-arg TARGETARCH=$GOARCH
run_integration_test $repo
upload_to_docker $repo
repo=${repo}-debug
base_debug_img_arg="--build-arg base_image=localhost:5000/baseimg:1.0.0-alpine-3.13 --build-arg debug_image=localhost:5000/debugimg:1.0.0-golang-1.15-alpine "
#build all-in-one-debug image locally for integration test
bash scripts/build-upload-a-docker-image.sh -l -c all-in-one-debug -b "${base_debug_img_arg}" -d cmd/all-in-one -t debug
run_integration_test localhost:5000/$repo
#build all-in-one-debug image and upload to dockerhub/quay.io
bash scripts/build-upload-a-docker-image.sh -c all-in-one-debug -b "${base_debug_img_arg}" -d cmd/all-in-one -t debug
Loading