-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
62 lines (39 loc) · 1.74 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
ARG ALPINE_VERSION=3.20
ARG CRYSTAL_VERSION=1.12
ARG NODE_VERSION=20.12
FROM crystallang/crystal:${CRYSTAL_VERSION}-alpine AS crystal
ARG COMPILE_FLAGS=
RUN ["apk", "add", "--no-cache", "curl", "git", "jq", "openssh-client"]
RUN mkdir -pm 0700 ~/.ssh && \
curl --silent https://api.github.com/meta | jq --raw-output \
'"github.com "+.ssh_keys[]' >> ~/.ssh/known_hosts && \
chmod 600 ~/.ssh/known_hosts
WORKDIR /tmp/lucky
COPY . .
COPY ./root-config /root/
RUN sed 's|/home/runner|/root|g' -i.bak /root/.ssh/config
RUN --mount=type=ssh,id=ssh-key shards build --static -Dpreview_mt \
--production --skip-postinstall --skip-executables ${COMPILE_FLAGS}
FROM node:${NODE_VERSION}-alpine AS node
RUN ["apk", "add", "curl", "git", "jq", "openssh-client"]
RUN mkdir -pm 0700 ~/.ssh && \
curl --silent https://api.github.com/meta | jq --raw-output \
'"github.com "+.ssh_keys[]' >> ~/.ssh/known_hosts && \
chmod 600 ~/.ssh/known_hosts
WORKDIR /tmp/lucky
COPY --chown=node:node . .
COPY ./root-config /root/
RUN sed 's|/home/runner|/root|g' -i.bak /root/.ssh/config
RUN --mount=type=ssh,id=ssh-key npm ci && npm run prod
FROM alpine:${ALPINE_VERSION}
RUN addgroup -S app-data && adduser -SH app-data -G app-data
WORKDIR /srv/app
COPY --from=crystal --chown=app-data:app-data /tmp/lucky/bin/ ./bin/
COPY --from=crystal --chown=app-data:app-data /tmp/lucky/lang/ ./lang/
COPY --from=node --chown=app-data:app-data /tmp/lucky/public/ ./public/
# COPY --from=node --chown=app-data:app-data /tmp/lucky/node_modules/ ./node_modules/
# COPY --from=node --chown=app-data:app-data /tmp/lucky/package*.json .
RUN chmod +x bin/*
RUN ["apk", "add", "--no-cache", "bind-tools", "tzdata"]
USER app-data:app-data
CMD bin/cli db.migrate && bin/app