From 42145902a72da415c8505042285802c592ceb874 Mon Sep 17 00:00:00 2001 From: Norman Maurer Date: Thu, 24 Dec 2020 12:00:08 +0100 Subject: [PATCH] Correctly deploy artifacts that are build on different archs (#10893) Motivation: We need to take special care when deploying snapshots as we need to generate the jars in multiple steps Modifications: - Use the nexus staging pluging to stage jars locally in multiple steps - Add extra job that will merge these staged jars and deploy these Result: Fixes https://github.com/netty/netty/issues/10887 --- .github/workflows/ci-deploy.yml | 151 +++++++++++++++---------- docker/docker-compose.centos-6.18.yaml | 3 + docker/docker-compose.centos-7.yaml | 12 +- docker/docker-compose.yaml | 10 ++ 4 files changed, 114 insertions(+), 62 deletions(-) diff --git a/.github/workflows/ci-deploy.yml b/.github/workflows/ci-deploy.yml index 7208df32f5..513dee25a2 100644 --- a/.github/workflows/ci-deploy.yml +++ b/.github/workflows/ci-deploy.yml @@ -11,24 +11,75 @@ on: workflow_dispatch: jobs: - deploy-linux-x86_64: + stage-snapshot: runs-on: ubuntu-latest - steps: - - uses: s4u/maven-settings-action@v2.2.0 - with: - servers: | - [{ - "id": "sonatype-nexus-snapshots", - "username": "${{ secrets.SONATYPE_USERNAME }}", - "password": "${{ secrets.SONATYPE_PASSWORD }}" - }] + strategy: + matrix: + include: + - setup: linux-x86_64-java8 + docker-compose-build: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.18.yaml build" + docker-compose-run: "-f docker/docker-compose.yaml -f docker/docker-compose.centos-6.18.yaml run stage-snapshot" + - setup: linux-aarch64 + docker-compose-build: "-f docker/docker-compose.centos-7.yaml build" + docker-compose-run: "-f docker/docker-compose.centos-7.yaml run cross-compile-aarch64-stage-snapshot" + name: stage-snapshot-${{ matrix.setup }} + steps: - uses: actions/checkout@v2 # Cache .m2/repository - uses: actions/cache@v2 env: - cache-name: deploy-linux-x86_64-cache-m2-repository + cache-name: staging-${{ matrix.setup }}-cache-m2-repository + with: + path: ~/.m2/repository + key: ${{ runner.os }}-staging-${{ env.cache-name }}-${{ hashFiles('**/pom.xml') }} + restore-keys: | + ${{ runner.os }}-staging-${{ env.cache-name }}- + ${{ runner.os }}-staging- + + # Enable caching of Docker layers + - uses: satackey/action-docker-layer-caching@v0.0.8 + env: + docker-cache-name: staging-${{ matrix.setup }}-cache-docker + continue-on-error: true + with: + key: ${{ runner.os }}-staging-${{ env.docker-cache-name }}-{hash} + restore-keys: | + ${{ runner.os }}-staging-${{ env.docker-cache-name }}- + + - name: Create local staging directory + run: mkdir -p ~/local-staging + + - name: Build docker image + run: docker-compose ${{ matrix.docker-compose-build }} + + - name: Stage snapshots to local staging directory + run: docker-compose ${{ matrix.docker-compose-run }} + + - name: Upload local staging directory + uses: actions/upload-artifact@v2 + with: + name: ${{ matrix.setup }}-local-staging + path: ~/local-staging + if-no-files-found: error + + deploy-staged-snapshots: + runs-on: ubuntu-18.04 + # Wait until we have staged everything + needs: stage-snapshot + steps: + - uses: actions/checkout@v2 + + - name: Set up JDK 8 + uses: actions/setup-java@v1 + with: + java-version: 8 + + # Cache .m2/repository + - uses: actions/cache@v2 + env: + cache-name: deploy-staging-cache-m2-repository with: path: ~/.m2/repository key: ${{ runner.os }}-deploy-${{ env.cache-name }}-${{ hashFiles('**/pom.xml') }} @@ -36,63 +87,41 @@ jobs: ${{ runner.os }}-deploy-${{ env.cache-name }}- ${{ runner.os }}-deploy- - # Enable caching of Docker layers - - uses: satackey/action-docker-layer-caching@v0.0.8 - env: - docker-cache-name: deploy-linux-x86_64-cache-docker - continue-on-error: true + # Setup some env to re-use later. + - name: Prepare enviroment variables + run: | + echo "LOCAL_STAGING_DIR=$HOME/local-staging" >> $GITHUB_ENV + + # Hardcode the staging artifacts that need to be downloaded. + # These must match the matrix setups. There is currently no way to pull this out of the config. + - name: Download linux-aarch64 staging directory + uses: actions/download-artifact@v2 with: - key: ${{ runner.os }}-deploy-${{ env.docker-cache-name }}-{hash} - restore-keys: | - ${{ runner.os }}-deploy-${{ env.docker-cache-name }}- + name: linux-aarch64-local-staging + path: ~/linux-aarch64-local-staging - - name: Build docker image - run: docker-compose -f docker/docker-compose.yaml -f docker/docker-compose.centos-6.18.yaml build + - name: Download linux-x86_64-java8 staging directory + uses: actions/download-artifact@v2 + with: + name: linux-x86_64-java8-local-staging + path: ~/linux-x86_64-java8-local-staging - - name: Deploy snapshots - run: docker-compose -f docker/docker-compose.yaml -f docker/docker-compose.centos-6.18.yaml run deploy + - name: Merge staging repositories + run: | + mkdir -p ~/local-staging/deferred + cat ~/linux-aarch64-local-staging/deferred/.index >> ~/local-staging/deferred/.index + cp -r ~/linux-aarch64-local-staging/deferred/* ~/local-staging/deferred/ + cat ~/linux-x86_64-java8-local-staging/deferred/.index >> ~/local-staging/deferred/.index + cp -r ~/linux-x86_64-java8-local-staging/deferred/* ~/local-staging/deferred/ - deploy-linux-aarch64: - runs-on: ubuntu-latest - # We depend on the deploy of linux-x86_64 so we can download the dependencies - needs: deploy-linux-x86_64 - # Skip for now until we figured out how to deploy SNAPSHOTS with the the same timestamps - if: ${{ false }} - steps: - uses: s4u/maven-settings-action@v2.2.0 with: servers: | [{ - "id": "sonatype-nexus-snapshots", - "username": "${{ secrets.SONATYPE_USERNAME }}", - "password": "${{ secrets.SONATYPE_PASSWORD }}" + "id": "sonatype-nexus-snapshots", + "username": "${{ secrets.SONATYPE_USERNAME }}", + "password": "${{ secrets.SONATYPE_PASSWORD }}" }] - - uses: actions/checkout@v2 - - # Cache .m2/repository - - uses: actions/cache@v2 - env: - cache-name: deploy-linux-aarch64-cache-m2-repository - with: - path: ~/.m2/repository - key: ${{ runner.os }}-deploy-${{ env.cache-name }}-${{ hashFiles('**/pom.xml') }} - restore-keys: | - ${{ runner.os }}-deploy-${{ env.cache-name }}- - ${{ runner.os }}-deploy- - - # Enable caching of Docker layers - - uses: satackey/action-docker-layer-caching@v0.0.8 - env: - docker-cache-name: deploy-linux-aarch64-cache-docker - continue-on-error: true - with: - key: ${{ runner.os }}-deploy-${{ env.docker-cache-name }}-{hash} - restore-keys: | - ${{ runner.os }}-deploy-${{ env.docker-cache-name }}- - - - name: Build docker image - run: docker-compose -f docker/docker-compose.centos-7.yaml build - - - name: Deploy snapshots - run: docker-compose -f docker/docker-compose.centos-7.yaml run cross-compile-aarch64-deploy + - name: Deploy local staged artifacts + run: mvn -B --file pom.xml org.sonatype.plugins:nexus-staging-maven-plugin:deploy-staged -DaltStagingDirectory=$LOCAL_STAGING_DIR \ No newline at end of file diff --git a/docker/docker-compose.centos-6.18.yaml b/docker/docker-compose.centos-6.18.yaml index ff1aa5154c..e522f6348b 100644 --- a/docker/docker-compose.centos-6.18.yaml +++ b/docker/docker-compose.centos-6.18.yaml @@ -20,6 +20,9 @@ services: build-leak-boringssl-static: image: netty:centos-6-1.8 + stage-snapshot: + image: netty:centos-6-1.8 + deploy: image: netty:centos-6-1.8 diff --git a/docker/docker-compose.centos-7.yaml b/docker/docker-compose.centos-7.yaml index f4d9905493..5b2d324ea4 100644 --- a/docker/docker-compose.centos-7.yaml +++ b/docker/docker-compose.centos-7.yaml @@ -24,7 +24,17 @@ services: cross-compile-aarch64-deploy: <<: *cross-compile-aarch64-common - command: /bin/bash -cl "./mvnw -pl transport-native-unix-common,transport-native-epoll clean deploy -Plinux-aarch64 -DskipTests=true" + command: /bin/bash -cl "./mvnw -Plinux-aarch64 -pl transport-native-unix-common,transport-native-epoll clean deploy -DskipTests=true" + + cross-compile-aarch64-stage-snapshot: + <<: *cross-compile-aarch64-common + volumes: + - ~/.ssh:/root/.ssh + - ~/.gnupg:/root/.gnupg + - ~/.m2:/root/.m2 + - ~/local-staging:/root/local-staging + - ..:/code + command: /bin/bash -cl "./mvnw -Plinux-aarch64 -pl transport-native-unix-common,transport-native-epoll clean package org.sonatype.plugins:nexus-staging-maven-plugin:deploy -DaltStagingDirectory=/root/local-staging -DskipRemoteStaging=true -DskipTests=true" cross-compile-aarch64-shell: <<: *cross-compile-aarch64-common diff --git a/docker/docker-compose.yaml b/docker/docker-compose.yaml index e2dc92fc10..e516a26bc4 100644 --- a/docker/docker-compose.yaml +++ b/docker/docker-compose.yaml @@ -30,6 +30,16 @@ services: <<: *common command: /bin/bash -cl "./mvnw clean deploy -DskipTests=true" + stage-snapshot: + <<: *common + volumes: + - ~/.ssh:/root/.ssh + - ~/.gnupg:/root/.gnupg + - ~/.m2:/root/.m2 + - ~/local-staging:/root/local-staging + - ..:/code + command: /bin/bash -cl "./mvnw clean package org.sonatype.plugins:nexus-staging-maven-plugin:deploy -DaltStagingDirectory=/root/local-staging -DskipRemoteStaging=true -DskipTests=true" + build-boringssl-static: <<: *common command: /bin/bash -cl "./mvnw -P boringssl clean install -Dio.netty.testsuite.badHost=netty.io -Dxml.skip=true"