From 461cafda67a99f4cc27ea41539d1748b6c87a79c Mon Sep 17 00:00:00 2001 From: mmis Date: Wed, 5 Sep 2018 10:35:44 +0100 Subject: Generate docker image for policy distribution Added generation of tarball of policy distribution jars and generation of docker image using the tarball Issue-ID: POLICY-923 Change-Id: I9e38143fee864b765fbfd567c7e52bc7b0be2c9a Signed-off-by: mmis --- .../src/main/docker/Dockerfile | 45 ++++++++++++++++++++++ .../src/main/docker/policy-dist.sh | 25 ++++++++++++ 2 files changed, 70 insertions(+) create mode 100644 packages/policy-distribution-docker/src/main/docker/Dockerfile create mode 100644 packages/policy-distribution-docker/src/main/docker/policy-dist.sh (limited to 'packages/policy-distribution-docker/src/main') diff --git a/packages/policy-distribution-docker/src/main/docker/Dockerfile b/packages/policy-distribution-docker/src/main/docker/Dockerfile new file mode 100644 index 00000000..e1349775 --- /dev/null +++ b/packages/policy-distribution-docker/src/main/docker/Dockerfile @@ -0,0 +1,45 @@ +FROM ubuntu:14.04 + +ARG HTTP_PROXY=${HTTP_PROXY} +ARG HTTPS_PROXY=${HTTPS_PROXY} +ARG BUILD_VERSION=${BUILD_VERSION} +ARG POLICY_LOGS=/var/log/onap + +ENV http_proxy $HTTP_PROXY +ENV https_proxy $HTTPS_PROXY +ENV BUILD_VERSION ${BUILD_VERSION} +ENV POLICY_LOGS ${POLICY_LOGS} + +ENV POLICY_HOME=/opt/app/policy +ENV POLICY_DISTRIBUTION_HOME=${POLICY_HOME}/distribution + +RUN \ + apt-get clean && \ + apt-get update && \ + apt-get install -y zip unzip curl wget ssh telnet maven && \ + apt-get install -y software-properties-common && \ + apt-get install -y jq httpie && \ + apt-get install -y python-pip && \ + add-apt-repository ppa:openjdk-r/ppa && \ + apt-get clean && \ + apt-get update && \ + apt-get install -y openjdk-8-jdk + +RUN groupadd policy +RUN useradd --create-home --shell /bin/bash -g policy policy + +RUN mkdir -p ${POLICY_DISTRIBUTION_HOME} ${POLICY_LOGS} && \ + chown policy:policy ${POLICY_HOME} ${POLICY_DISTRIBUTION_HOME} ${POLICY_LOGS} + +RUN mkdir /packages +COPY /maven/* /packages +RUN tar xvfz /packages/policy-distribution.tar.gz --directory ${POLICY_DISTRIBUTION_HOME} +RUN rm /packages/policy-distribution.tar.gz + +WORKDIR ${POLICY_DISTRIBUTION_HOME} +COPY policy-dist.sh bin/. +RUN chown -R policy:policy * && chmod +x bin/*.sh + +USER policy +WORKDIR ${POLICY_DISTRIBUTION_HOME}/bin +ENTRYPOINT [ "bash", "./policy-dist.sh" ] diff --git a/packages/policy-distribution-docker/src/main/docker/policy-dist.sh b/packages/policy-distribution-docker/src/main/docker/policy-dist.sh new file mode 100644 index 00000000..854074fa --- /dev/null +++ b/packages/policy-distribution-docker/src/main/docker/policy-dist.sh @@ -0,0 +1,25 @@ +#!/bin/bash +# +# ============LICENSE_START======================================================= +# Copyright (C) 2018 Ericsson. All rights reserved. +# ================================================================================ +# Licensed 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. +# +# SPDX-License-Identifier: Apache-2.0 +# ============LICENSE_END========================================================= +# + +JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64/ +POLICY_DISTRIBUTION_HOME=/opt/app/policy/distribution + +$JAVA_HOME/bin/java -cp "$POLICY_DISTRIBUTION_HOME/etc:$POLICY_DISTRIBUTION_HOME/lib/*" org.onap.policy.distribution.main.startstop.Main -c $POLICY_DISTRIBUTION_HOME/etc/defaultConfig.json -- cgit 1.2.3-korg