docker v2

This commit is contained in:
Zikil 2024-10-31 20:40:56 +07:00
parent f195a33f79
commit f0c4c6ac2f
3 changed files with 110 additions and 51 deletions

View File

@ -1,32 +1,46 @@
# Stage 1: Сборка приложения
FROM node:18-alpine as builder
# # Stage 1: Сборка приложения
# FROM node:18-alpine as builder
# WORKDIR /app
# # Копируем файлы package.json и package-lock.json
# COPY package*.json ./
# # Устанавливаем зависимости
# RUN npm ci
# # Копируем исходный код
# COPY . .
# # Собираем приложение
# # RUN npm run build
# CMD ["npm", "run", "start" ]
# # Stage 2: Настройка production-окружения
# # FROM nginx:alpine
# # Копируем собранные файлы из предыдущего этапа
# # COPY --from=builder /app/dist /usr/share/nginx/html
# # # Копируем конфигурацию nginx
# # COPY nginx.conf /etc/nginx/conf.d/default.conf
# # Открываем порт 80
# EXPOSE 80
# # Запускаем nginx
# # CMD ["nginx", "-g", "daemon off;"]
FROM node:18-alpine
WORKDIR /app
# Копируем файлы package.json и package-lock.json
COPY package*.json ./
RUN npm install
# Устанавливаем зависимости
RUN npm ci
# Копируем исходный код
COPY . .
RUN npm run build
# Собираем приложение
# RUN npm run build
CMD ["npm", "run", "start" ]
# Stage 2: Настройка production-окружения
# FROM nginx:alpine
# Копируем собранные файлы из предыдущего этапа
# COPY --from=builder /app/dist /usr/share/nginx/html
# # Копируем конфигурацию nginx
# COPY nginx.conf /etc/nginx/conf.d/default.conf
# Открываем порт 80
EXPOSE 80
# Запускаем nginx
# CMD ["nginx", "-g", "daemon off;"]
EXPOSE 3000
CMD ["npm", "start"]

View File

@ -1,20 +1,51 @@
version: '3.8'
# version: '3.8'
# services:
# web:
# build:
# context: .
# dockerfile: Dockerfile
# ports:
# - "80:80"
# - "3000:3000"
# restart: unless-stopped
# # Добавьте volumes если нужно хранить данные постоянно
# # volumes:
# # - ./logs:/var/log/nginx
# networks:
# - app-network
# networks:
# app-network:
# driver: bridge
version: '3'
services:
web:
build:
context: .
dockerfile: Dockerfile
nextjs:
build: .
container_name: nextjs
restart: always
ports:
- "80:80"
- "3000:3000"
restart: unless-stopped
# Добавьте volumes если нужно хранить данные постоянно
# volumes:
# - ./logs:/var/log/nginx
networks:
- app-network
nginx:
image: nginx:alpine
container_name: nginx
ports:
- "80:80"
- "443:443"
volumes:
- ./nginx/conf.d:/etc/nginx/conf.d
- ./nginx/ssl:/etc/nginx/ssl
depends_on:
- nextjs
networks:
- app-network
restart: always
networks:
app-network:
driver: bridge
driver: bridge

View File

@ -1,21 +1,35 @@
# server {
# listen 80;
# server_name localhost:3000;
# location / {
# root /usr/share/nginx/html;
# index index.html;
# try_files $uri $uri/ /index.html;
# }
# # Кэширование статических файлов
# location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|webp)$ {
# expires 30d;
# add_header Cache-Control "public, no-transform";
# }
# # Запрещаем доступ к .git и другим служебным директориям
# location ~ /\. {
# deny all;
# }
# }
server {
listen 80;
server_name localhost:3000;
server_name localhost:3000; # Замените на ваш домен
location / {
root /usr/share/nginx/html;
index index.html;
try_files $uri $uri/ /index.html;
}
# Кэширование статических файлов
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|webp)$ {
expires 30d;
add_header Cache-Control "public, no-transform";
}
# Запрещаем доступ к .git и другим служебным директориям
location ~ /\. {
deny all;
proxy_pass http://nextjs:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}