Skip to content

Build and Publish docker images #2

Build and Publish docker images

Build and Publish docker images #2

Workflow file for this run

# 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:
schedule:
- cron: '17 3 * * *'
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 == 'schedule' || (github.event_name == 'create' && github.event.ref_type == 'tag' && startsWith(github.event.ref, 'rel/'))
runs-on: ubuntu-latest
steps:
- name: Free disk space
run: |
echo '===== Before ====='
df -h
sudo rm -rf /opt/hostedtoolcache/go
sudo rm -rf /opt/hostedtoolcache/CodeQL
sudo rm -rf /usr/lib/google-cloud-sdk
sudo rm -rf /usr/local/julia*
sudo rm -rf /usr/local/.ghcup
sudo rm -rf /usr/share/swift
sudo rm -rf /usr/share/dotnet
sudo apt-get clean
echo '===== After ====='
df -h
- name: Checkout
uses: actions/checkout@v3
- name: 'Set up JDK 21'
uses: actions/setup-java@v5
with:
java-version: '21'
distribution: temurin
cache: maven
- 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=release" >> $GITHUB_ENV
- name: Prepare environment variables from repository
if: github.event_name != 'workflow_dispatch'
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=hybrid" >> $GITHUB_ENV
- name: Prepare common environment variables
run: |
echo "namespace=${{ vars.DOCKER_NAMESPACE || 'apache' }}" >> $GITHUB_ENV
- name: Prepare an image tag for release
if: github.event_name != 'schedule'
run: |
echo "tag=$HIVE_VERSION" >> $GITHUB_ENV
- name: Prepare an image tag for nightly
if: github.event_name == 'schedule'
run: |
echo "tag=nightly" >> $GITHUB_ENV
- name: Build Hive project
if: github.event_name != 'workflow_dispatch'
run: |
mvn --batch-mode 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 Hive Image locally
uses: docker/build-push-action@v4
with:
context: ./packaging/src/docker/
file: ./packaging/src/docker/Dockerfile
push: false
load: true
tags: hive:test
build-args:
|
HIVE_VERSION=${{ env.HIVE_VERSION }}
HADOOP_VERSION=${{ env.HADOOP_VERSION }}
TEZ_VERSION=${{ env.TEZ_VERSION }}
BUILD_ENV=${{ env.BUILD_ENV }}
- name: Build Standalone Metastore Image locally
uses: docker/build-push-action@v4
with:
context: ./standalone-metastore/packaging/src/docker/
file: ./standalone-metastore/packaging/src/docker/Dockerfile
push: false
load: true
tags: hive:standalone-metastore-test
build-args:
|
HIVE_VERSION=${{ env.HIVE_VERSION }}
HADOOP_VERSION=${{ env.HADOOP_VERSION }}
BUILD_ENV=${{ env.BUILD_ENV }}
- name: Create k8s cluster
uses: helm/kind-action@v1
- name: Set up Helm
uses: azure/setup-helm@v4
- name: Load images
run: kind load docker-image hive:test hive:standalone-metastore-test --name chart-testing
- name: Deploy Hive
run: |
./itests/test-docker/scripts/setup.sh
- name: Run JUnit
# On workflow_dispatch, the checked-out source code and libraries could be inconsistent with the specified Hive release
if: github.event_name != 'workflow_dispatch'
run: |
mvn --batch-mode test -Pitests -Pdocker -pl itests/test-docker
- name: Test HiveServer2
run: |
./itests/test-docker/scripts/test_hive_server2.sh
- name: Clean up k8s
run: |
./itests/test-docker/scripts/teardown.sh
kind delete cluster --name chart-testing
- 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 }}
- name: Dump resource space at the end
run: |
df -h
free -h
- name: Dump resource usage on failure
if: failure() || cancelled()
run: |
df -h
du -xh / --max-depth=3 2>/dev/null | sort -h | tail -50
free -h
ps aux --sort -rss | head -n 30
kubectl get pods