Commit
This commit is contained in:
@@ -13,15 +13,17 @@ COPY backend/package*.json ./
|
|||||||
RUN npm install
|
RUN npm install
|
||||||
COPY backend/ .
|
COPY backend/ .
|
||||||
|
|
||||||
# Production image using nginx:alpine
|
|
||||||
FROM nginx:alpine
|
FROM nginx:alpine
|
||||||
|
|
||||||
|
RUN apk add --no-cache nodejs npm
|
||||||
COPY docker/nginx.conf /etc/nginx/nginx.conf
|
COPY docker/nginx.conf /etc/nginx/nginx.conf
|
||||||
COPY --from=frontend-build /app/frontend/dist /usr/share/nginx/html
|
COPY --from=frontend-build /app/frontend/dist /usr/share/nginx/html
|
||||||
COPY --from=backend-build /backend /backend
|
COPY --from=backend-build /backend /backend
|
||||||
COPY --from=backend-build /backend/entrypoint.sh /backend/entrypoint.sh
|
COPY --from=backend-build /backend/entrypoint.sh /backend/entrypoint.sh
|
||||||
|
|
||||||
# Make entrypoint.sh executable
|
|
||||||
RUN chmod +x /backend/entrypoint.sh
|
RUN chmod +x /backend/entrypoint.sh
|
||||||
|
|
||||||
# Use entrypoint script to start backend and frontend servers
|
ENTRYPOINT ["/backend/entrypoint.sh"]
|
||||||
ENTRYPOINT ["/backend/entrypoint.sh"]
|
|
||||||
|
EXPOSE 80
|
||||||
|
EXPOSE 3001
|
||||||
@@ -1,31 +1,32 @@
|
|||||||
server {
|
http {
|
||||||
listen 80;
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name localhost;
|
||||||
|
|
||||||
server_name localhost;
|
# Serve the React app
|
||||||
|
|
||||||
# Serve the React app
|
|
||||||
root /usr/share/nginx/html;
|
|
||||||
index index.html;
|
|
||||||
|
|
||||||
# Frontend routes (SPA)
|
|
||||||
location / {
|
|
||||||
try_files $uri /index.html;
|
|
||||||
}
|
|
||||||
|
|
||||||
# API routes (proxy to backend)
|
|
||||||
location /api/ {
|
|
||||||
proxy_pass http://127.0.0.1:3001; # Forward API requests to backend
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_set_header Upgrade $http_upgrade;
|
|
||||||
proxy_set_header Connection "upgrade";
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_redirect off; # Disable automatic redirects by the backend (if any)
|
|
||||||
}
|
|
||||||
|
|
||||||
# Optional: Custom error handling
|
|
||||||
error_page 404 /404.html;
|
|
||||||
error_page 500 502 503 504 /50x.html;
|
|
||||||
location = /50x.html {
|
|
||||||
root /usr/share/nginx/html;
|
root /usr/share/nginx/html;
|
||||||
|
index index.html;
|
||||||
|
|
||||||
|
# Frontend routes (SPA)
|
||||||
|
location / {
|
||||||
|
try_files $uri /index.html;
|
||||||
|
}
|
||||||
|
|
||||||
|
# API routes (proxy to backend)
|
||||||
|
location /api/ {
|
||||||
|
proxy_pass http://127.0.0.1:3001; # Forward API requests to backend
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection "upgrade";
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_redirect off; # Disable automatic redirects by the backend (if any)
|
||||||
|
}
|
||||||
|
|
||||||
|
# Optional: Custom error handling
|
||||||
|
error_page 404 /404.html;
|
||||||
|
error_page 500 502 503 504 /50x.html;
|
||||||
|
location = /50x.html {
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user