Преглед изворни кода

Merge pull request #6929 from Rory-Z/ci/push-multiarch-image-for-aws-ecr-5.0

ci(build_packages): push muilt arch image for aws ecr
Rory Z пре 4 година
родитељ
комит
70ce5cbab3
1 измењених фајлова са 29 додато и 22 уклоњено
  1. 29 22
      .github/workflows/build_packages.yaml

+ 29 - 22
.github/workflows/build_packages.yaml

@@ -494,6 +494,11 @@ jobs:
           source/deps/quicer/
           source/deps/quicer/
         key: ${{ matrix.os }}-${{ matrix.otp }}-${{ matrix.arch }}-${{ needs.prepare.outputs.DEP_QUICER_REF }}
         key: ${{ matrix.os }}-${{ matrix.otp }}-${{ matrix.arch }}-${{ needs.prepare.outputs.DEP_QUICER_REF }}
 
 
+    - uses: docker/login-action@v1
+      with:
+        username: ${{ secrets.DOCKER_HUB_USER }}
+        password: ${{ secrets.DOCKER_HUB_TOKEN }}
+
     - name: prepare for docker-action-parms
     - name: prepare for docker-action-parms
       id: pre-meta
       id: pre-meta
       run: |
       run: |
@@ -527,13 +532,6 @@ jobs:
           type=semver,pattern={{version}}
           type=semver,pattern={{version}}
         labels:
         labels:
           ${{ steps.pre-meta.outputs.img_labels }}
           ${{ steps.pre-meta.outputs.img_labels }}
-    - uses: docker/login-action@v1
-      if: >
-        ${{ (github.event_name == 'release' && !github.event.release.prerelease)
-        || (github.event.repository.owner != 'emqx' && startsWith(github.ref_name, 'ci/')) }}
-      with:
-        username: ${{ secrets.DOCKER_HUB_USER }}
-        password: ${{ secrets.DOCKER_HUB_TOKEN }}
 
 
     - uses: docker/build-push-action@v2
     - uses: docker/build-push-action@v2
       with:
       with:
@@ -551,28 +549,24 @@ jobs:
           EMQX_NAME=${{ steps.pre-meta.outputs.emqx_name }}
           EMQX_NAME=${{ steps.pre-meta.outputs.emqx_name }}
         file: source/deploy/docker/Dockerfile
         file: source/deploy/docker/Dockerfile
         context: source
         context: source
+
     - uses: aws-actions/configure-aws-credentials@v1
     - uses: aws-actions/configure-aws-credentials@v1
-      if: github.event_name == 'release' && !github.event.release.prerelease && matrix.profile == 'emqx'
+      if: matrix.profile == 'emqx'
       with:
       with:
         aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
         aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
         aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
         aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
         aws-region: ${{ secrets.AWS_DEFAULT_REGION }}
         aws-region: ${{ secrets.AWS_DEFAULT_REGION }}
-    - name: Push image to aws ecr
-      if: github.event_name == 'release' && !github.event.release.prerelease && matrix.profile == 'emqx' && matrix.build_elixir == 'no_elixir'
-      run: |
-        version=${GITHUB_REF##*/}
-        docker pull emqx/emqx:${version#v}
-        docker tag emqx/emqx:${version#v} public.ecr.aws/emqx/emqx:${version#v}
-        aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws
-        docker push public.ecr.aws/emqx/emqx:${version#v}
-    - name: Push image to aws ecr (elixir)
-      if: github.event_name == 'release' && !github.event.release.prerelease && matrix.profile == 'emqx' && matrix.build_elixir == 'with_elixir'
+    - name: Docker push to aws ecr
+      if: >
+        ${{ (github.event_name == 'release' && !github.event.release.prerelease && matrix.profile == 'emqx')
+        || (github.event.repository.owner != 'emqx' && startsWith(github.ref_name, 'ci/')) }}
       run: |
       run: |
-        version=${GITHUB_REF##*/}-elixir
-        docker pull emqx/emqx:${version#v}
-        docker tag emqx/emqx:${version#v} public.ecr.aws/emqx/emqx:${version#v}
         aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws
         aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws
-        docker push public.ecr.aws/emqx/emqx:${version#v}
+        for tag in $(echo ${{ steps.meta.outputs.json }} | jq  -c '.tags[]'); do
+          docker pull "$tag"
+          docker tag "$tag" "public.ecr.aws/$tag"
+          docker push "public.ecr.aws/$tag"
+        done
 
 
   docker-push-multi-arch-manifest:
   docker-push-multi-arch-manifest:
     # note, we only run on amd64
     # note, we only run on amd64
@@ -677,6 +671,19 @@ jobs:
           IsPushLatest=${{ github.event_name == 'release' && !github.event.release.prerelease }};
           IsPushLatest=${{ github.event_name == 'release' && !github.event.release.prerelease }};
           scripts/docker-create-push-manifests.sh "${{ steps.meta.outputs.tags }}" "$IsPushLatest"
           scripts/docker-create-push-manifests.sh "${{ steps.meta.outputs.tags }}" "$IsPushLatest"
 
 
+      - uses: aws-actions/configure-aws-credentials@v1
+        if: matrix.profile == 'emqx' && matrix.arch == 'amd64'
+        with:
+          aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
+          aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
+          aws-region: ${{ secrets.AWS_DEFAULT_REGION }}
+      - name: Docker push to aws ecr
+        if: matrix.profile == 'emqx' && matrix.arch == 'amd64'
+        run: |
+          aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aws
+          IsPushLatest=${{ github.event_name == 'release' && !github.event.release.prerelease }};
+          scripts/docker-create-push-manifests.sh "public.ecr.aws/${{ steps.meta.outputs.tags }}" "$IsPushLatest"
+
   delete-artifact:
   delete-artifact:
     runs-on: ubuntu-20.04
     runs-on: ubuntu-20.04
     needs: [prepare, mac, linux, docker]
     needs: [prepare, mac, linux, docker]