-
-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathubi9.Dockerfile
73 lines (49 loc) · 1.87 KB
/
ubi9.Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
FROM eclipse-temurin:11-jre-ubi9-minimal
ARG COMMANDBOX_VERSION
LABEL maintainer "Jon Clausen <jclausen@ortussolutions.com>"
LABEL repository "https://github.com/Ortus-Solutions/docker-commandbox"
# Default to UTF-8 file.encoding
ENV LANG C.UTF-8
# Since alpine runs as a single user, we need to create a "root" direcotry
ENV HOME /root
RUN microdnf install -y shadow-utils util-linux
# Add a working group which any dynamic users can be assigned
ENV WORKGROUP runwar
RUN groupadd $WORKGROUP && usermod -a -G $WORKGROUP root
### Directory Mappings ###
# BIN_DIR = Where the box binary goes
ENV BIN_DIR /usr/local/bin
# LIB_DIR = Where the build files go
ENV LIB_DIR /usr/local/lib
WORKDIR $BIN_DIR
# BUILD_DIR = WHERE runtime scripts go
ENV BUILD_DIR $LIB_DIR/build
WORKDIR $BUILD_DIR
# COMMANDBOX_HOME = Where CommmandBox Lives
ENV COMMANDBOX_HOME=$LIB_DIR/CommandBox
# APP_DIR = the directory where the application runs
ENV APP_DIR /app
WORKDIR $APP_DIR
# Copy file system
COPY ./test/ ${APP_DIR}/
COPY ./build/ ${BUILD_DIR}/
RUN chmod +x $BUILD_DIR/*.sh
# Ensure all runwar users have permission on the build scripts
RUN chown -R $(whoami):${WORKGROUP} $BUILD_DIR
# Basic Dependencies
RUN rm -rf $BUILD_DIR/util/alpine
RUN rm -rf $BUILD_DIR/util/debian
RUN ${BUILD_DIR}/util/ubi9/install-dependencies.sh
# Commandbox Installation
RUN $BUILD_DIR/util/install-commandbox.sh
# Add our custom classes added in the previous step to the java classpath
ENV CLASSPATH="$JAVA_HOME/classes"
# Default Port Environment Variables
ENV PORT 8080
ENV SSL_PORT 8443
# Healthcheck environment variables
ENV HEALTHCHECK_URI "http://127.0.0.1:${PORT}/"
# Our healthcheck interval doesn't allow dynamic intervals - Default is 20s intervals with 15 retries
HEALTHCHECK --interval=20s --timeout=30s --retries=15 CMD curl --fail ${HEALTHCHECK_URI} || exit 1
EXPOSE ${PORT} ${SSL_PORT}
CMD $BUILD_DIR/run.sh