Files
GestionIntegralWeb/Backend/GestionIntegral.Api/Dockerfile
dmolinari f4601b7520
All checks were successful
Build and Deploy / remote-build-and-deploy (push) Successful in 17m7s
Reversión.
Se añade GDIPlus para reportes.
2025-06-19 10:21:47 -03:00

47 lines
1.9 KiB
Docker

# --- Etapa 1: Build ---
# Usamos el SDK de .NET 9 (o el que corresponda) para compilar.
FROM mcr.microsoft.com/dotnet/sdk:9.0 AS build
WORKDIR /src
# Copiamos los archivos de proyecto (.sln y .csproj) y restauramos las dependencias.
# Esto es una optimización de caché de Docker.
COPY GestionIntegralWeb.sln .
COPY Backend/GestionIntegral.Api/GestionIntegral.Api.csproj Backend/GestionIntegral.Api/
# Restauramos los paquetes NuGet.
RUN dotnet restore "GestionIntegralWeb.sln"
# Copiamos todo el resto del código fuente.
COPY . .
# Nos movemos al directorio del proyecto y lo construimos en modo Release.
WORKDIR "/src/Backend/GestionIntegral.Api"
RUN dotnet build "GestionIntegral.Api.csproj" -c Release -o /app/build
# --- Etapa 2: Publish ---
# Publicamos la aplicación, lo que genera los artefactos listos para producción.
FROM build AS publish
RUN dotnet publish "GestionIntegral.Api.csproj" -c Release -o /app/publish /p:UseAppHost=false
# --- Etapa 3: Final ---
# Usamos la imagen de runtime de ASP.NET, que es mucho más ligera que el SDK.
FROM mcr.microsoft.com/dotnet/aspnet:9.0
WORKDIR /app
# La imagen mcr.microsoft.com/dotnet/aspnet:9.0 está basada en Debian.
# Necesitamos instalar libgdiplus para que System.Drawing y el motor de reportes funcionen.
# Cambiamos temporalmente a usuario root para instalar paquetes.
USER root
RUN apt-get update && apt-get install -y libgdiplus libc6-dev && rm -rf /var/lib/apt/lists/*
# Volvemos al usuario por defecto de la aplicación (usualmente 'app').
# Si tu imagen no define un usuario, esta línea puede ser opcional, pero es buena práctica.
USER app
COPY --from=publish /app/publish .
# El puerto en el que la API escuchará DENTRO del contenedor.
# Usaremos 8080 para evitar conflictos si en el futuro corres algo en el puerto 80.
EXPOSE 8080
# El comando para iniciar la API cuando el contenedor arranque.
ENTRYPOINT ["dotnet", "GestionIntegral.Api.dll"]