-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
58 lines (39 loc) · 1.55 KB
/
Copy pathDockerfile
File metadata and controls
58 lines (39 loc) · 1.55 KB
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
# Etapa de construção (Builder Stage)
FROM node:20 as builder
WORKDIR /app
# Copie apenas os arquivos de configuração do pacote inicialmente
COPY package*.json ./
# Instale pnpm globalmente
RUN npm i -g pnpm
# Utilize o cache para node_modules
# A diretiva --mount=type=cache é específica do BuildKit
RUN --mount=type=cache,target=/root/.pnpm-store pnpm i
# Copie o restante do código da aplicação
COPY . .
# Construa a aplicação
RUN pnpm build
# Etapa de produção (Production Stage)
FROM nginx:alpine
# Defina o diretório de trabalho do Nginx
WORKDIR /usr/share/nginx/html
# Limpe o diretório HTML padrão do Nginx
RUN rm -rf ./*
# Copie os arquivos construídos da etapa anterior
COPY --from=builder /app/dist .
# Copie a configuração do Nginx
COPY nginx.conf /etc/nginx/conf.d/default.conf
# Crie o diretório de cache e defina as permissões
RUN mkdir -p /var/cache/nginx /var/run /var/log/nginx \
&& chown -R nginx:nginx /var/cache/nginx /var/run /var/log/nginx /usr/share/nginx/html
# Adicione o usuário não-root se ele não existir
RUN addgroup -S nginx || true && adduser -S nginx -G nginx || true
# Mude o proprietário dos arquivos para o usuário não-root
RUN chown -R nginx:nginx /usr/share/nginx/html /var/run/
# Defina o usuário não-root para executar a aplicação
USER nginx
# Adicione a instrução HEALTHCHECK
HEALTHCHECK --interval=30s --timeout=5s --retries=3 CMD curl -f http://localhost:8080/health || exit 1
# Defina o comando de entrada do Nginx
ENTRYPOINT ["nginx", "-g", "daemon off;"]
# Exponha a porta 8080
EXPOSE 8080