All checks were successful
		
		
	
	Build and Deploy / remote-build-and-deploy (push) Successful in 24m50s
				
			
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.7 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
 | |
| 
 | |
| # Instalar dependencias de Chromium en la imagen de ASP.NET (basada en Debian)
 | |
| RUN apt-get update && apt-get install -y \
 | |
|     libgconf-2-4 \
 | |
|     libgdk-pixbuf2.0-0 \
 | |
|     libgtk-3-0 \
 | |
|     libnss3 \
 | |
|     libxss1 \
 | |
|     libasound2 \
 | |
|     libxtst6 \
 | |
|     --no-install-recommends && \
 | |
|     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"] |