-
Notifications
You must be signed in to change notification settings - Fork 129
/
Copy pathDockerfile
62 lines (43 loc) · 1.35 KB
/
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
#
# Build stage
#
FROM node:16 AS front-build
WORKDIR /app
COPY web .
RUN yarn config set network-timeout 300000 && yarn && yarn build
FROM maven:3-amazoncorretto-17 AS build
WORKDIR /app
COPY src src
COPY pom.xml pom.xml
COPY LICENSE LICENSE
COPY --from=front-build /app/dist src/main/resources/static
RUN mvn -f pom.xml clean package -Dmaven.test.skip=true
# base image to build a JRE
FROM amazoncorretto:17.0.8-alpine as corretto-jdk
# required for strip-debug to work
RUN apk add --no-cache binutils
# Build small JRE image
RUN $JAVA_HOME/bin/jlink \
--verbose \
--add-modules ALL-MODULE-PATH \
--strip-debug \
--no-man-pages \
--no-header-files \
--compress=2 \
--output /customjre
#
# Package stage
#
FROM alpine:latest
ENV JAVA_HOME=/jre
ENV PATH="${JAVA_HOME}/bin:${PATH}"
# copy JRE from the base image
COPY --from=corretto-jdk /customjre $JAVA_HOME
ENV SERVER_PORT 8080
ENV DEFAULT_USERNAME admin
ENV DEFAULT_PASSWORD admin
WORKDIR /usr/local/kafka-map
COPY --from=build /app/target/*.jar kafka-map.jar
COPY --from=build /app/LICENSE LICENSE
EXPOSE $SERVER_PORT
ENTRYPOINT ["/jre/bin/java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/usr/local/kafka-map/kafka-map.jar", "--server.port=${SERVER_PORT}", "--default.username=${DEFAULT_USERNAME}", "--default.password=${DEFAULT_PASSWORD}"]