docker v2
This commit is contained in:
parent
f195a33f79
commit
f0c4c6ac2f
64
Dockerfile
64
Dockerfile
@ -1,32 +1,46 @@
|
|||||||
# Stage 1: Сборка приложения
|
# # Stage 1: Сборка приложения
|
||||||
FROM node:18-alpine as builder
|
# 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
|
WORKDIR /app
|
||||||
|
|
||||||
# Копируем файлы package.json и package-lock.json
|
|
||||||
COPY package*.json ./
|
COPY package*.json ./
|
||||||
|
RUN npm install
|
||||||
|
|
||||||
# Устанавливаем зависимости
|
|
||||||
RUN npm ci
|
|
||||||
|
|
||||||
# Копируем исходный код
|
|
||||||
COPY . .
|
COPY . .
|
||||||
|
RUN npm run build
|
||||||
|
|
||||||
# Собираем приложение
|
EXPOSE 3000
|
||||||
# RUN npm run build
|
CMD ["npm", "start"]
|
||||||
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;"]
|
|
||||||
@ -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:
|
services:
|
||||||
web:
|
nextjs:
|
||||||
build:
|
build: .
|
||||||
context: .
|
container_name: nextjs
|
||||||
dockerfile: Dockerfile
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- "80:80"
|
|
||||||
- "3000:3000"
|
- "3000:3000"
|
||||||
restart: unless-stopped
|
|
||||||
# Добавьте volumes если нужно хранить данные постоянно
|
|
||||||
# volumes:
|
|
||||||
# - ./logs:/var/log/nginx
|
|
||||||
networks:
|
networks:
|
||||||
- app-network
|
- 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:
|
networks:
|
||||||
app-network:
|
app-network:
|
||||||
driver: bridge
|
driver: bridge
|
||||||
44
nginx.conf
44
nginx.conf
@ -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 {
|
server {
|
||||||
listen 80;
|
listen 80;
|
||||||
server_name localhost:3000;
|
server_name localhost:3000; # Замените на ваш домен
|
||||||
|
|
||||||
location / {
|
location / {
|
||||||
root /usr/share/nginx/html;
|
proxy_pass http://nextjs:3000;
|
||||||
index index.html;
|
proxy_http_version 1.1;
|
||||||
try_files $uri $uri/ /index.html;
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
}
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_set_header Host $host;
|
||||||
# Кэширование статических файлов
|
proxy_cache_bypass $http_upgrade;
|
||||||
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|webp)$ {
|
|
||||||
expires 30d;
|
|
||||||
add_header Cache-Control "public, no-transform";
|
|
||||||
}
|
|
||||||
|
|
||||||
# Запрещаем доступ к .git и другим служебным директориям
|
|
||||||
location ~ /\. {
|
|
||||||
deny all;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Loading…
Reference in New Issue
Block a user