| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you under the Apache License, Version 2.0 (the |
| # "License"); you may not use this file except in compliance |
| # with the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| name: Build and Publish docker images for Hive GA |
| |
| on: |
| create: |
| workflow_dispatch: |
| inputs: |
| hiveVersion: |
| description: 'Hive version' |
| required: true |
| default: '4.0.0-beta-1' |
| |
| |
| hadoopVersion: |
| description: 'hadoop version' |
| required: true |
| default: '3.3.1' |
| |
| tezVersion: |
| description: 'tez version' |
| required: true |
| default: '0.10.2' |
| |
| env: |
| DEVELOCITY_ACCESS_KEY: ${{ secrets.GE_ACCESS_TOKEN }} |
| |
| jobs: |
| buildFromArchive: |
| if: github.event_name == 'workflow_dispatch' |
| runs-on: ubuntu-latest |
| steps: |
| - |
| name: Checkout |
| uses: actions/checkout@v3 |
| |
| - |
| name: 'Set up JDK 8' |
| uses: actions/setup-java@v1 |
| with: |
| java-version: 8 |
| |
| - |
| name: Hive version |
| run: echo "HIVE_VERSION=${{ github.event.inputs.hiveVersion }}" >> $GITHUB_ENV |
| |
| |
| - name: Tag |
| run: echo "tag=${{ env.HIVE_VERSION }}" | awk '{print tolower($0)}' >> $GITHUB_ENV |
| |
| - |
| name: Hadoop version |
| run: echo "HADOOP_VERSION=${{ github.event.inputs.hadoopVersion }}" >> $GITHUB_ENV |
| - |
| name: Tez version |
| run: echo "TEZ_VERSION=${{ github.event.inputs.tezVersion }}" >> $GITHUB_ENV |
| |
| - name: Login to Docker Hub |
| uses: docker/login-action@v2 |
| with: |
| username: ${{ secrets.DOCKERHUB_USER }} |
| password: ${{ secrets.DOCKERHUB_TOKEN }} |
| |
| - |
| name: Set up Docker Buildx |
| uses: docker/setup-buildx-action@v2 |
| |
| - name: Build and push Hive Image to docker hub |
| uses: docker/build-push-action@v4 |
| with: |
| context: ./packaging/src/docker/ |
| file: ./packaging/src/docker/Dockerfile |
| platforms: linux/amd64,linux/arm64 |
| push: true |
| tags: apache/hive:${{ env.tag }} |
| build-args: |
| | |
| HIVE_VERSION=${{ env.HIVE_VERSION }} |
| HADOOP_VERSION=${{ env.HADOOP_VERSION }} |
| TEZ_VERSION=${{ env.TEZ_VERSION }} |
| BUILD_ENV=archive |
| |
| buildFromSource: |
| if: github.event_name == 'create' && github.event.ref_type == 'tag' && startsWith(github.event.ref, 'rel/') |
| runs-on: ubuntu-latest |
| steps: |
| - name: Checkout |
| uses: actions/checkout@v3 |
| |
| - name: 'Set up JDK 8' |
| uses: actions/setup-java@v1 |
| with: |
| java-version: 8 |
| |
| - name: Hive version |
| run: echo "HIVE_VERSION=$(mvn -f "pom.xml" -q help:evaluate -Dexpression=project.version -DforceStdout)" >> $GITHUB_ENV |
| |
| |
| - name: Tag |
| run: echo "tag=${{ env.HIVE_VERSION }}" | awk '{print tolower($0)}' >> $GITHUB_ENV |
| |
| - name: Hadoop version |
| run: echo "HADOOP_VERSION=$(mvn -f "pom.xml" -q help:evaluate -Dexpression=hadoop.version -DforceStdout)" >> $GITHUB_ENV |
| - name: Tez version |
| run: echo "TEZ_VERSION=$(mvn -f "pom.xml" -q help:evaluate -Dexpression=tez.version -DforceStdout)" >> $GITHUB_ENV |
| |
| - name: Build project |
| run: mvn clean package -DskipTests -Pitests,iceberg -Pdist |
| |
| - name: Check for hive tar.gz |
| run: ls ./packaging/target/ |
| |
| - name: Copy to docker directory |
| run: cp ./packaging/target/apache-hive-*-bin.tar.gz ./packaging/src/docker/ |
| |
| - name: Confirm the copy of hive tar.gz |
| run: ls ./packaging/src/docker/ |
| |
| - name: Login to Docker Hub |
| uses: docker/login-action@v2 |
| with: |
| username: ${{ secrets.DOCKERHUB_USER }} |
| password: ${{ secrets.DOCKERHUB_TOKEN }} |
| |
| - name: Set up Docker Buildx |
| uses: docker/setup-buildx-action@v2 |
| |
| - name: Build and push Hive Image to docker hub |
| uses: docker/build-push-action@v4 |
| with: |
| context: ./packaging/src/docker/ |
| file: ./packaging/src/docker/Dockerfile |
| platforms: linux/amd64,linux/arm64 |
| push: true |
| tags: apache/hive:${{ env.tag }} |
| build-args: |
| | |
| HIVE_VERSION=${{ env.HIVE_VERSION }} |
| HADOOP_VERSION=${{ env.HADOOP_VERSION }} |
| TEZ_VERSION=${{ env.TEZ_VERSION }} |
| BUILD_ENV=buildarchive |