-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDockerfile
69 lines (54 loc) · 1.92 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
63
64
65
66
67
68
69
# see all official Bun versions at https://hub.docker.com/r/oven/bun/tags
FROM oven/bun AS base
# Set up application
WORKDIR /usr/src/app
# Set to true to tell Elysia we are in a Docker system
ENV DOCKER_ENV=true
# install netcat to detect when services are ready (for entrypoint.sh)
RUN apt-get update && apt-get install -y --no-install-recommends netcat-traditional
# install dependencies into temp directory (cache and speed for future builds)
FROM base AS install
RUN mkdir -p /temp/dev
COPY package.json bun.lockb /temp/dev/
COPY prisma /temp/dev/prisma
COPY tsconfig.json /temp/dev/
ENV NODE_ENV=development
RUN cd /temp/dev && bun install --frozen-lockfile
RUN cd /temp/dev && bunx prisma generate
# install with --production (exclude devDependencies)
# RUN mkdir -p /temp/prod
# COPY package.json bun.lockb /temp/prod/
# RUN cd /temp/prod && bun install --frozen-lockfile --production
# copy node_modules from temp directory
# then copy all (non-ignored) project files into the image
FROM base AS prerelease
COPY --from=install /temp/dev/node_modules node_modules
COPY --from=install /temp/dev/package.json .
COPY --from=install /temp/dev/prisma prisma
COPY --from=install /temp/dev/tsconfig.json .
COPY public public
COPY src src
COPY logs logs
COPY entrypoint.sh .
# [optional] tests & build
# ENV NODE_ENV=production
# RUN bun test
# RUN bun run build
# copy production dependencies and source code into final image
# FROM base AS release
# COPY --from=install /temp/prod/node_modules node_modules
# COPY --from=install /temp/dev/node_modules node_modules
# COPY --from=prerelease /usr/src/app/ .
# COPY --from=prerelease /usr/src/app/package.json .
# Ensure logs directory exists
RUN mkdir -p /logs
RUN chmod +x entrypoint.sh
# Switch to non-root user for added security
USER bun
EXPOSE 3000/tcp
# run the app
# CMD [ "bun", "dev" ]
# execute start script
ENTRYPOINT [ "./entrypoint.sh" ]
# execute the binary!
# CMD ["/usr/src/app/app"]