Skip to content

Build and Publish docker images for Hive GA #47

Build and Publish docker images for Hive GA

Build and Publish docker images for Hive GA #47

# 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.DEVELOCITY_ACCESS_KEY }}
jobs:
buildAndPush:
if: github.event_name == 'workflow_dispatch' || 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 21'
uses: actions/setup-java@v1
with:
java-version: 21
- name: Prepare environment variables for Workflow Dispatch
if: github.event_name == 'workflow_dispatch'
run: |
echo "HIVE_VERSION=${{ github.event.inputs.hiveVersion }}" >> $GITHUB_ENV
echo "HADOOP_VERSION=${{ github.event.inputs.hadoopVersion }}" >> $GITHUB_ENV
echo "TEZ_VERSION=${{ github.event.inputs.tezVersion }}" >> $GITHUB_ENV
echo "BUILD_ENV=archive" >> $GITHUB_ENV
- name: Prepare environment variables for Release
if: github.event_name == 'create' && github.event.ref_type == 'tag' && startsWith(github.event.ref, 'rel/')
run: |
echo "HIVE_VERSION=$(mvn -f "pom.xml" -q help:evaluate -Dexpression=project.version -DforceStdout)" >> $GITHUB_ENV
echo "HADOOP_VERSION=$(mvn -f "pom.xml" -q help:evaluate -Dexpression=hadoop.version -DforceStdout)" >> $GITHUB_ENV
echo "TEZ_VERSION=$(mvn -f "pom.xml" -q help:evaluate -Dexpression=tez.version -DforceStdout)" >> $GITHUB_ENV
echo "BUILD_ENV=buildarchive" >> $GITHUB_ENV
- name: Prepare common environment variables
run: |
echo "namespace=${{ vars.DOCKER_NAMESPACE || 'apache' }}" >> $GITHUB_ENV
echo "tag=$HIVE_VERSION" | awk '{print tolower($0)}' >> $GITHUB_ENV
- name: Build Hive project
if: github.event_name == 'create' && github.event.ref_type == 'tag' && startsWith(github.event.ref, 'rel/')
run: |
mvn clean package -DskipTests -Pdist
ls ./packaging/target/
mv ./packaging/target/apache-hive-*-bin.tar.gz ./packaging/src/docker/
rm -rf ./packaging/target
ls ./packaging/src/docker/
ls ./standalone-metastore/packaging/target/
mv ./standalone-metastore/packaging/target/hive-standalone-metastore-*-bin.tar.gz ./standalone-metastore/packaging/src/docker/
rm -rf ./standalone-metastore/packaging/target
ls ./standalone-metastore/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: ${{ env.namespace }}/hive:${{ env.tag }}
build-args:
|
HIVE_VERSION=${{ env.HIVE_VERSION }}
HADOOP_VERSION=${{ env.HADOOP_VERSION }}
TEZ_VERSION=${{ env.TEZ_VERSION }}
BUILD_ENV=${{ env.BUILD_ENV }}
- name: Build and push Standalone Metastore Image to docker hub
uses: docker/build-push-action@v4
with:
context: ./standalone-metastore/packaging/src/docker/
file: ./standalone-metastore/packaging/src/docker/Dockerfile
platforms: linux/amd64,linux/arm64
push: true
tags: ${{ env.namespace }}/hive:standalone-metastore-${{ env.tag }}
build-args:
|
HIVE_VERSION=${{ env.HIVE_VERSION }}
HADOOP_VERSION=${{ env.HADOOP_VERSION }}
BUILD_ENV=${{ env.BUILD_ENV }}