From b002801963b722bffb6caa80ebad898a50b20248 Mon Sep 17 00:00:00 2001 From: Thugutla sailakshmi Date: Wed, 4 Sep 2019 16:28:57 +0530 Subject: submittted build-docker.sh file for fgps-engine submittted build-docker.sh file for fgps-engine module Issue-ID: OPTFRA-578 Change-Id: I64e50083b9b0fe40fa0ba32723e30adb0dbce08e Signed-off-by: Thugutla sailakshmi --- engine/build-dockers.sh | 92 ++++++++++++++++++++++++++++++++++++++++++++ engine/docker/Dockerfile | 23 ----------- engine/src/docker/Dockerfile | 25 ++++++++++++ 3 files changed, 117 insertions(+), 23 deletions(-) create mode 100644 engine/build-dockers.sh delete mode 100644 engine/docker/Dockerfile create mode 100644 engine/src/docker/Dockerfile diff --git a/engine/build-dockers.sh b/engine/build-dockers.sh new file mode 100644 index 0000000..2db2f52 --- /dev/null +++ b/engine/build-dockers.sh @@ -0,0 +1,92 @@ +#!/bin/bash + +# The script starts in the root folder of the repo, which has the following outline +# We fetch the version information from version.properties, build docker files and +# do a docker push. Since the job will be run under Jenkins, it will have the Nexus +# credentials + +set -e + +BUILD_ARGS="--no-cache" +ORG="onap" +PROJECT="fgps-engine" +DOCKER_REPOSITORY="nexus3.onap.org:10003" +IMAGE_NAME="${DOCKER_REPOSITORY}/${ORG}/${PROJECT}" + +# Version properties +source version.properties +VERSION=$release_version +SNAPSHOT=$snapshot_version +STAGING=${release_version}-STAGING +TIMESTAMP=$(date +"%Y%m%dT%H%M%S")Z +REPO="" + +if [ $HTTP_PROXY ]; then + BUILD_ARGS+=" --build-arg HTTP_PROXY=${HTTP_PROXY}" +fi +if [ $HTTPS_PROXY ]; then + BUILD_ARGS+=" --build-arg HTTPS_PROXY=${HTTPS_PROXY}" +fi + +function log_ts() { # Log message with timestamp + echo [DEBUG LOG at $(date -u +%Y%m%d:%H%M%S)] "$@" +} + +function get_artifact_version() { + log_ts Get Maven Artifact version from pom.xml + MVN_ARTIFACT_VERSION=`echo -e "setns x=http://maven.apache.org/POM/4.0.0 \n xpath /x:project/x:version/text() "| xmllint --shell pom.xml | grep content | sed 's/.*content=//'` + log_ts Maven artifact version for HAS is $MVN_ARTIFACT_VERSION + if [[ "$MVN_ARTIFACT_VERSION" =~ SNAPSHOT ]]; then + log_ts "REPO is snapshots"; + REPO=snapshots + else + log_ts "REPO is releases"; + REPO=releases + fi + BUILD_ARGS+=" --build-arg REPO=${REPO}" + BUILD_ARGS+=" --build-arg MVN_ARTIFACT_VERSION=${MVN_ARTIFACT_VERSION}" +} + +function build_image() { + log_ts Building Image in folder: $PWD with build arguments ${BUILD_ARGS} + docker build ${BUILD_ARGS} -t ${IMAGE_NAME}:latest . + log_ts ... Built +} + +function push_image() { + if [[ "$REPO" == snapshots ]]; then + push_snapshot_image + else + push_staging_image + fi +} + +function push_snapshot_image(){ + log_ts Tagging images: ${IMAGE_NAME}:\{${SNAPSHOT}-${TIMESTAMP},${SNAPSHOT}-latest\} + docker tag ${IMAGE_NAME}:latest ${IMAGE_NAME}:${SNAPSHOT}-${TIMESTAMP} + docker tag ${IMAGE_NAME}:latest ${IMAGE_NAME}:${SNAPSHOT}-latest + log_ts ... Tagged images + + log_ts Pushing images: ${IMAGE_NAME}:\{${SNAPSHOT}-${TIMESTAMP},${SNAPSHOT}-latest\} + docker push ${IMAGE_NAME}:${SNAPSHOT}-${TIMESTAMP} + docker push ${IMAGE_NAME}:${SNAPSHOT}-latest + log_ts ... Pushed images +} + +function push_staging_image(){ + log_ts Tagging images: ${IMAGE_NAME}:\{${STAGING}-${TIMESTAMP},${STAGING}-latest\} + docker tag ${IMAGE_NAME}:latest ${IMAGE_NAME}:${STAGING}-${TIMESTAMP} + docker tag ${IMAGE_NAME}:latest ${IMAGE_NAME}:${STAGING}-latest + log_ts ... Tagged images + + log_ts Pushing images: ${IMAGE_NAME}:\{${STAGING}-${TIMESTAMP},${STAGING}-latest\} + docker push ${IMAGE_NAME}:${STAGING}-${TIMESTAMP} + docker push ${IMAGE_NAME}:${STAGING}-latest + log_ts ... Pushed images +} + +( + get_artifact_version + build_image + push_image +) diff --git a/engine/docker/Dockerfile b/engine/docker/Dockerfile deleted file mode 100644 index f8bf14e..0000000 --- a/engine/docker/Dockerfile +++ /dev/null @@ -1,23 +0,0 @@ -FROM python:2.7.15-alpine - -COPY src/ /opt/engine -WORKDIR /opt/engine - -ARG HTTP_PROXY -ARG HTTPS_PROXY - -ENV HTTP_PROXY ${HTTP_PROXY} -ENV HTTPS_PROXY ${HTTPS_PROXY} - -RUN apk --update add --virtual build-dep gcc musl-dev linux-headers libc-dev \ - && pip install -r requirements.txt \ - && apk del build-dep - -ENV HTTP_PROXY "" -ENV HTTPS_PROXY "" - -RUN addgroup -g 825 -S valetg && adduser -u 825 -S valetu -G valetg && chown -R valetu:valetg /opt/engine -USER valetu:valetg -RUN date > /home/valetu/imagedate.txt - -CMD ["python", "valet/valet_main.py", "/opt/config/solver.json"] diff --git a/engine/src/docker/Dockerfile b/engine/src/docker/Dockerfile new file mode 100644 index 0000000..a9b4728 --- /dev/null +++ b/engine/src/docker/Dockerfile @@ -0,0 +1,25 @@ +FROM python:2.7.15-alpine + +COPY /src/ /opt/engine +WORKDIR /opt/engine + +ARG HTTP_PROXY +ARG HTTPS_PROXY + +ENV HTTP_PROXY ${HTTP_PROXY} +ENV HTTPS_PROXY ${HTTPS_PROXY} + +RUN apk --update add --virtual build-dep gcc musl-dev linux-headers libc-dev \ + && pip install -r requirements.txt \ + && apk del build-dep + +ENV HTTP_PROXY "" +ENV HTTPS_PROXY "" + +RUN addgroup -g 825 -S valetg && adduser -u 825 -S valetu -G valetg && chown -R valetu:valetg /opt/engine +USER valetu:valetg +RUN date > /home/valetu/imagedate.txt + +CMD ["python", "valet/valet_main.py", "/opt/config/solver.json"] + + -- cgit 1.2.3-korg