# Copyright (c) 2016-present Sonatype, Inc.
|
#
|
# 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.
|
|
FROM registry.access.redhat.com/rhel7:7.6
|
MAINTAINER Red Hat Training
|
|
|
# Atomic Labels
|
LABEL name="Nexus Repository Manager" \
|
vendor="Sonatype" \
|
version="3.6.0-02" \
|
release="3.6.0" \
|
url="https://sonatype.com" \
|
summary="The Nexus Repository Manager server \
|
with universal support for popular component formats." \
|
run="docker run -d --name NAME \
|
-p 8081:8081 \
|
IMAGE" \
|
stop="docker stop NAME"
|
|
# OpenShift Labels
|
LABEL io.k8s.description="The Nexus Repository Manager server \
|
with universal support for popular component formats." \
|
io.k8s.display-name="Nexus Repository Manager" \
|
io.openshift.expose-services="8081:8081" \
|
io.openshift.tags="Sonatype,Nexus,Repository Manager"
|
|
LABEL com.sonatype.license="Apache License, Version 2.0"
|
|
COPY help.1 uid_entrypoint /
|
|
COPY licenses /licenses
|
|
|
RUN rpm --rebuilddb && \
|
yum install -y \
|
curl tar createrepo java-1.8.0-openjdk-devel \
|
&& yum clean all
|
|
|
# Install Nexus
|
ENV SONATYPE_DIR=/opt/sonatype
|
ENV NEXUS_DATA=/nexus-data \
|
NEXUS_HOME=${SONATYPE_DIR}/nexus \
|
NEXUS_VERSION=3.6.0-02 \
|
SONATYPE_WORK=${SONATYPE_DIR}/sonatype-work \
|
NEXUS_CONTEXT='' \
|
USER_NAME=nexus \
|
USER_UID=200
|
|
# Install Nexus and Configure Nexus Runtime Environment
|
RUN mkdir -p ${NEXUS_HOME} && \
|
curl --fail --silent --location --retry 3 \
|
http://content.example.com/ocp3.6/x86_64/installers/nexus-${NEXUS_VERSION}-unix.tar.gz \
|
| gunzip \
|
| tar x -C ${NEXUS_HOME} --strip-components=1 nexus-${NEXUS_VERSION} && \
|
chown -R root:root ${NEXUS_HOME} && \
|
\
|
sed \
|
-e '/^nexus-context/ s:$:${NEXUS_CONTEXT}:' \
|
-i ${NEXUS_HOME}/etc/nexus-default.properties && \
|
\
|
useradd -l -u ${USER_UID} -r -g 0 -m -d ${NEXUS_DATA} -s /sbin/no-login \
|
-c "${USER_NAME} application user" ${USER_NAME} && \
|
mkdir -p ${NEXUS_DATA}/etc ${NEXUS_DATA}/log ${NEXUS_DATA}/tmp ${SONATYPE_WORK} && \
|
ln -s ${NEXUS_DATA} ${SONATYPE_WORK}/nexus3 && \
|
chown -R ${USER_NAME}:0 ${NEXUS_DATA} && \
|
chmod -R g+rw ${NEXUS_DATA} /etc/passwd && \
|
chmod ug+x /uid_entrypoint && \
|
find ${NEXUS_DATA} -type d -exec chmod g+x {} +
|
|
VOLUME ${NEXUS_DATA}
|
|
#Configure probes scripts
|
COPY probes/liveness.sh /usr/local/bin/liveness.sh
|
COPY probes/readiness.sh /usr/local/bin/readiness.sh
|
|
RUN chmod 775 /usr/local/bin/liveness.sh && \
|
chmod 775 /usr/local/bin/readiness.sh
|
|
# arbitrary uid recognition at runtime - for OpenShift deployments
|
RUN sed "s@${USER_NAME}:x:${USER_UID}:@${USER_NAME}:x:\${USER_ID}:@g" /etc/passwd > /etc/passwd.template
|
|
# Supply non variable to USER command ${USER_NAME}
|
USER 200
|
WORKDIR ${NEXUS_HOME}
|
|
ENV JAVA_MAX_MEM=1200m \
|
JAVA_MIN_MEM=1200m
|
|
EXPOSE 8081
|
|
ENTRYPOINT [ "/uid_entrypoint" ]
|
CMD ["bin/nexus", "run"]
|