# --- 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 # Instalamos libgdiplus + sus deps mínimas y creamos el symlink que .NET espera. RUN apt-get update \ && apt-get install -y --no-install-recommends \ libgdiplus \ libc6-dev \ libx11-dev \ libxrender1 \ libxtst6 \ libxi6 \ fontconfig \ && ln -s /usr/lib/libgdiplus.so /usr/lib/gdiplus.dll \ && rm -rf /var/lib/apt/lists/* 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"]