feat(deploy): Añade configuración Docker para despliegue de servicios

This commit is contained in:
2025-07-04 12:12:15 -03:00
parent 5e317ab304
commit 32c99515dd
7 changed files with 169 additions and 3 deletions

28
frontend/Dockerfile Normal file
View File

@@ -0,0 +1,28 @@
# --- Etapa 1: Build ---
# Usamos una imagen ligera de Node.js para instalar dependencias y compilar el frontend
FROM node:20-alpine AS build
WORKDIR /app
# Copiamos package.json y package-lock.json para cachear las dependencias
COPY package*.json ./
RUN npm install
# Copiamos el resto del código del frontend
COPY . .
# Ejecutamos el script de build de Vite
RUN npm run build
# --- Etapa 2: Producción ---
# Usamos la imagen oficial de Nginx, que es muy pequeña y eficiente
FROM nginx:1.25-alpine
# Copiamos los archivos estáticos generados en la etapa de build
# a la carpeta que Nginx sirve por defecto.
COPY --from=build /app/dist /usr/share/nginx/html
# Nginx ya está configurado para escuchar en el puerto 80 por defecto.
# Simplemente lo exponemos.
EXPOSE 80
# El comando por defecto de la imagen de Nginx ya inicia el servidor.
CMD ["nginx", "-g", "daemon off;"]

25
frontend/nginx.conf Normal file
View File

@@ -0,0 +1,25 @@
server {
listen 80;
server_name widgets.eldia.com;
# Ubicación raíz para servir los archivos estáticos del frontend
root /usr/share/nginx/html;
index index.html;
# Configuración para las rutas del frontend
location / {
try_files $uri $uri/ /index.html;
}
# --- Proxy Inverso para la API ---
# Todas las peticiones que empiecen con /api/ se redirigen al backend
location /api/ {
# El nombre 'backend-api' debe coincidir con el nombre del servicio en docker-compose.yml
# El puerto 8080 es el puerto que expone el contenedor de la API (no el host)
proxy_pass http://backend-api:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}

View File

@@ -62,8 +62,8 @@ export const RawBolsaUsaTable = () => {
<TableRow key={row.id}>
<TableCell>{row.ticker}</TableCell>
<TableCell>{row.nombreEmpresa}</TableCell>
<TableCell align="right">${formatCurrency(row.precioActual, 'USD')}</TableCell>
<TableCell align="right">${formatCurrency(row.cierreAnterior, 'USD')}</TableCell>
<TableCell align="right">{formatCurrency(row.precioActual, 'USD')}</TableCell>
<TableCell align="right">{formatCurrency(row.cierreAnterior, 'USD')}</TableCell>
<TableCell align="right">{row.porcentajeCambio.toFixed(2)}%</TableCell>
<TableCell>{formatFullDateTime(row.fechaRegistro)}</TableCell>
</TableRow>