Aggiungi il supporto per il build dell'applicazione e la configurazione di Nginx nel Dockerfile
All checks were successful
GKE Deploy / build-and-deploy (push) Successful in 35s
All checks were successful
GKE Deploy / build-and-deploy (push) Successful in 35s
This commit is contained in:
39
Dockerfile
39
Dockerfile
@@ -1,2 +1,37 @@
|
||||
FROM nginx:alpine
|
||||
RUN echo "<h1>Ciao da Gitea Actions su GKE! v1</h1>" > /usr/share/nginx/html/index.html
|
||||
# --- STAGE 1: Build dell'applicazione ---
|
||||
# Usiamo un'immagine con Node per installare le dipendenze e compilare
|
||||
FROM node:lts-alpine as build-stage
|
||||
|
||||
# Impostiamo la cartella di lavoro
|
||||
WORKDIR /app
|
||||
|
||||
# Copiamo prima i file di dipendenze (per sfruttare la cache di Docker)
|
||||
COPY package*.json ./
|
||||
|
||||
# Installiamo le dipendenze
|
||||
RUN npm install
|
||||
|
||||
# Copiamo tutto il resto del codice sorgente
|
||||
COPY . .
|
||||
|
||||
# Compiliamo il progetto per la produzione
|
||||
# (Questo crea la cartella 'dist' con i file ottimizzati)
|
||||
RUN npm run build
|
||||
|
||||
# --- STAGE 2: Serve con Nginx ---
|
||||
# Usiamo un'immagine Nginx leggera per servire i file
|
||||
FROM nginx:stable-alpine as production-stage
|
||||
|
||||
# Copiamo la configurazione personalizzata che abbiamo creato al punto 1
|
||||
COPY nginx.conf /etc/nginx/nginx.conf
|
||||
|
||||
# Copiamo i file compilati dallo Stage 1 dentro la cartella pubblica di Nginx
|
||||
# NOTA: Assicurati che il comando 'build' di Vue crei una cartella 'dist'.
|
||||
# Se il tuo progetto crea una cartella diversa (es. 'build'), modifica qui sotto.
|
||||
COPY --from=build-stage /app/dist /app
|
||||
|
||||
# Esponiamo la porta 80
|
||||
EXPOSE 80
|
||||
|
||||
# Avviamo Nginx
|
||||
CMD ["nginx", "-g", "daemon off;"]
|
||||
Reference in New Issue
Block a user