Align configuration with nonograms: add healthcheck, nginx security, build from source
All checks were successful
Deploy to Production / deploy (push) Successful in 7s

This commit is contained in:
2026-02-15 20:36:02 +01:00
parent 835ea1feb3
commit 03d4adf6b1
3 changed files with 60 additions and 13 deletions

View File

@@ -1,20 +1,36 @@
# Build stage # Stage 1: Build the application
FROM node:18-alpine AS builder FROM node:18-alpine as build-stage
# Set working directory
WORKDIR /app WORKDIR /app
# Copy package files first to leverage Docker cache
COPY package*.json ./ COPY package*.json ./
# Install dependencies
RUN npm install RUN npm install
# Copy the rest of the application code
COPY . . COPY . .
# Build the application
RUN npm run build RUN npm run build
# Production stage # Stage 2: Serve the application with Nginx
FROM nginx:stable-alpine FROM nginx:stable-alpine as production-stage
COPY --from=builder /app/dist /usr/share/nginx/html # Copy the built artifacts from the build stage
COPY --from=build-stage /app/dist /usr/share/nginx/html
# Copy custom Nginx configuration
COPY nginx.conf /etc/nginx/conf.d/default.conf COPY nginx.conf /etc/nginx/conf.d/default.conf
# Expose port 80
EXPOSE 80 EXPOSE 80
# Healthcheck to ensure Nginx is running and serving
HEALTHCHECK --interval=30s --timeout=3s \
CMD wget --quiet --tries=1 --spider http://localhost/health || exit 1
# Start Nginx
CMD ["nginx", "-g", "daemon off;"] CMD ["nginx", "-g", "daemon off;"]

View File

@@ -2,11 +2,13 @@ version: '3.8'
services: services:
rubic-cube: rubic-cube:
image: gitea.7u.pl/gkucmierz/rubic-cube:latest
container_name: rubic-cube container_name: rubic-cube
restart: always build:
context: .
dockerfile: Dockerfile
ports: ports:
- "8083:80" - "8083:80"
restart: always
networks: networks:
- rubic-net - rubic-net

View File

@@ -1,15 +1,44 @@
server { server {
listen 80; listen 80;
server_name localhost; server_name localhost;
root /usr/share/nginx/html;
index index.html;
# Gzip compression
gzip on;
gzip_vary on;
gzip_min_length 10240;
gzip_proxied expired no-cache no-store private auth;
gzip_types text/plain text/css text/xml text/javascript application/x-javascript application/xml application/javascript;
gzip_disable "MSIE [1-6]\.";
# Security Headers
add_header X-Frame-Options "SAMEORIGIN";
add_header X-XSS-Protection "1; mode=block";
add_header X-Content-Type-Options "nosniff";
add_header Referrer-Policy "strict-origin-when-cross-origin";
# CSP: Adjust as needed. This is a strict starting point.
# Allowing unsafe-inline for styles is often necessary for Vue apps unless using nonces.
add_header Content-Security-Policy "default-src 'self'; script-src 'self' 'unsafe-inline' 'unsafe-eval'; style-src 'self' 'unsafe-inline'; img-src 'self' data:; font-src 'self' data:;";
location / { location / {
root /usr/share/nginx/html;
index index.html index.htm;
try_files $uri $uri/ /index.html; try_files $uri $uri/ /index.html;
} }
error_page 500 502 503 504 /50x.html; # Cache static assets
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {
expires 1y;
add_header Cache-Control "public, no-transform";
}
# Health check
location /health {
access_log off;
return 200 "healthy\n";
}
error_page 500 502 503 504 /50x.html;
location = /50x.html { location = /50x.html {
root /usr/share/nginx/html; root /usr/share/nginx/html;
} }
} }