Skip to content

Build and Publish docker images for Hive GA #36

Build and Publish docker images for Hive GA

Build and Publish docker images for Hive GA #36

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'
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