Page History
...
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
FROM openjdk:8-jre-alpine LABEL maintainer="Software- und Organisations-Service GmbH" # BUILD SETTINGS # provide build arguments for release information ARG JS_RELEASE ARG JS_RELEASE_MAJOR # default user id has to match later run-time user ARG JS_USER_ID=${JS_USER_ID:-1001} ARG JS_HTTP_PORT=${JS_HTTP_PORT:-4446} ARG JS_HTTPS_PORT=${JS_HTTPS_PORT:-4443} ARG JS_JAVA_OPTIONS=${JS_JAVA_OPTIONS} # RUN-TIME SETTINGS # JS7 JobScheduler ports and Java options ENV RUN_JS_HTTP_PORT=${RUN_JS_HTTP_PORT:-$JS_HTTP_PORT} ENV RUN_JS_HTTPS_PORT=${RUN_JS_HTTPS_PORT:-$JS_HTTPS_PORT} ENV RUN_JS_JAVA_OPTIONS=${RUN_JS_JAVA_OPTIONS:-$JS_JAVA_OPTIONS} # PREPARATION # install process tools, net tools, bash RUN apk update && apk add --no-cache \ procps \ net-tools \ bash # add installer tarball # ADD https://download.sos-berlin.com/JobScheduler.${JS_RELEASE_MAJOR}/js7_joc_linux.${JS_RELEASE}.tar.gz /usr/local/src/ COPY js7_joc_linux.${JS_RELEASE}.tar.gz /usr/local/src/ # copy installer response file and start script COPY joc_install.xml /usr/local/src/ COPY start-joc.sh /usr/local/bin/ # add keystore and truststore for private keys and certificates COPY https-keystore.p12 /tmp/usr/local/src/ COPY https-truststore.p12 /tmpusr/local/src # add keystore and truststore locations to configuration files COPY start.ini.add /tmpusr/local/src/ COPY joc.properties.add /usr/local/tmpsrc/ # INSTALLATION # copyextract installer responsetarball # filefor andJDK start script COPY joc_install.xml /tmp COPY start-joc.sh /usr/local/bin/ # INSTALLATION # extract installer tarball # for JDK < 12, /dev< 12, /dev/random does not provide sufficient entropy, see https://kb.sos-berlin.com/x/lIM3 # substitute build arguments in installer response file # add jobscheduler user account and group # run setup # add keystore and truststore locations to configuration files # enable https module # add keystore and truststore for private keys and certificates # link start.ini from configuration directory RUN test -e /usr/local/src/js7_joc_linux.${JS_RELEASE}.tar.gz && \ tar zxvf /usr/local/src/js7_joc_linux.${JS_RELEASE}.tar.gz -C /usr/local/src/ && \ rm -f /usr/local/src/js7_joc_linux.${JS_RELEASE}.tar.gz && \ ln -s /usr/local/src/joc.${JS_RELEASE} /usr/local/src/joc && \ mv /usr/local/tmpsrc/joc_install.xml /usr/local/src/joc/ && \ sed -i 's/securerandom.source=file:\/dev\/random/securerandom.source=file:\/dev\/urandom/g' /usr/lib/jvm/java-1.8-openjdk/jre/lib/security/java.security && \ sed -i "s/\s*<entry\s*key\s*=\"jettyPort\".*\/>/<entry key=\"jettyPort\" value=\"$JS_HTTP_PORT\"\/>/g" /usr/local/src/joc/joc_install.xml && \ adduser -u ${JS_USER_ID:-1001} --disabled-password --home /home/jobscheduler --no-create-home --shell /bin/bash jobscheduler jobscheduler && \ cd /usr/local/src/joc && ./setup.sh -u joc_install.xml && \ cat /usr/local/tmpsrc/start.ini.add >> /var/sos-berlin.com/js7/joc/start.ini && \ sed -i "s/\s*jetty.ssl.port\s*=.*/jetty.ssl.port=$JS_HTTPS_PORT/g" /var/sos-berlin.com/js7/joc/start.ini && \ cat /usr/tmplocal/src/joc.properties.add >> /var/sos-berlin.com/js7/joc/resources/joc/joc.propertiesproperties && \ java -jar "/opt/sos-berlin.com/js7/joc/jetty/start.jar" -Djetty.home="/opt/sos-berlin.com/js7/joc/jetty" -Djetty.base="/var/sos-berlin.com/js7/joc" --add-to-start=https && \ mv /usr/local/src/https-keystore.p12 /var/sos-berlin.com/js7/joc/resources/joc/ && \ mv /usr/local/src/https-truststore.p12 /var/sos-berlin.com/js7/joc/resources/joc/ && \ javamv -jar "/optvar/sos-berlin.com/js7/joc/jetty/start.jar" -Djetty.home="/optini /var/sos-berlin.com/js7/joc/jetty" -Djetty.base="/var/sos-berlin.com/js7/joc" --add-to-start=httpsresources/joc/ && \ mvln /tmp/https-keystore.p12-s /var/sos-berlin.com/js7/joc/resources/joc/ && \ mv /tmp/https-truststore.p12start.ini /var/sos-berlin.com/js7/joc/resources/joc/start.ini && \ chmod +x /usr/local/bin/start-joc.sh && \ chown -R jobscheduler:jobscheduler /var/sos-berlin.com # CONFIGURATION # copy configuration # COPY --chown=jobscheduler:jobscheduler config/ /var/sos-berlin.com/js7/joc/resources/joc/ # CODA # run-time user, can be overwritten when running the container USER jobscheduler CMD ["sh","-c","/usr/local/bin/start-joc.sh --http-port=$RUN_JS_HTTP_PORT --https-port=$RUN_JS_HTTPS_PORT --java-options=\"$RUN_JS_JAVA_OPTIONS\""] |
...
Overview
Content Tools