-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.Dockerfile
53 lines (38 loc) · 1.39 KB
/
server.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
FROM golang:1.20-alpine as builder
# Set up apk dependencies
ENV PACKAGES make git libc-dev bash gcc linux-headers eudev-dev curl ca-certificates build-base
# Set working directory for the build
WORKDIR /opt/app
# Add source files
COPY . .
# Install minimum necessary dependencies, remove packages
RUN apk add --no-cache $PACKAGES
# For Private REPO
ARG GH_TOKEN=""
RUN go env -w GOPRIVATE="github.com/bnb-chain/*"
RUN git config --global url."https://${GH_TOKEN}@github.com".insteadOf "https://github.com"
RUN make build_server
# Pull binary into a second stage deploy alpine container
FROM alpine:3.17
ARG USER=app
ARG USER_UID=1000
ARG USER_GID=1000
ENV ARCHIVER_SYNCER_SERVER_HOME /opt/app
ENV CONFIG_FILE_PATH $ARCHIVER_SYNCER_SERVER_HOME/config/config.json
ENV DB_USERNAME ""
ENV DB_PASSWORD ""
ENV PACKAGES ca-certificates libstdc++
ENV WORKDIR=/app
RUN apk add --no-cache $PACKAGES \
&& rm -rf /var/cache/apk/* \
&& addgroup -g ${USER_GID} ${USER} \
&& adduser -u ${USER_UID} -G ${USER} --shell /sbin/nologin --no-create-home -D ${USER} \
&& addgroup ${USER} tty \
&& sed -i -e "s/bin\/sh/bin\/bash/" /etc/passwd
WORKDIR ${WORKDIR}
COPY --from=builder /opt/app/build/syncer ${WORKDIR}/
RUN chown -R ${USER_UID}:${USER_GID} ${WORKDIR}
USER ${USER_UID}:${USER_GID}
VOLUME [ $ARCHIVER_SYNCER_SERVER_HOME ]
# Run the app
CMD /app/server --host 0.0.0.0 --port 8080 --config-path "$CONFIG_FILE_PATH"