feat/docker-setup #13
@@ -0,0 +1,87 @@
|
|||||||
|
# Docker Setup (Backend + Frontend + PostgreSQL)
|
||||||
|
|
||||||
|
This project provides a complete development environment using **Docker Compose** for:
|
||||||
|
|
||||||
|
- Backend (Node.js / Express / Prisma)
|
||||||
|
- Frontend (Vite / React)
|
||||||
|
- PostgreSQL Database
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Project Structure
|
||||||
|
|
||||||
|
```
|
||||||
|
.
|
||||||
|
├── backend/
|
||||||
|
├── frontend/
|
||||||
|
├── docker/
|
||||||
|
│ └── dev/
|
||||||
|
│ ├── Dockerfile.main
|
||||||
|
│ └── Dockerfile.frontend
|
||||||
|
├── docker-compose.dev.yml
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Prerequisites
|
||||||
|
|
||||||
|
Make sure you have installed:
|
||||||
|
|
||||||
|
- Docker
|
||||||
|
- Docker Compose
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Environment Variables
|
||||||
|
|
||||||
|
### Backend (`backend/.env`)
|
||||||
|
|
||||||
|
```env
|
||||||
|
DATABASE_URL=postgresql://user:password@db:5432/mydb
|
||||||
|
PORT=3000
|
||||||
|
JWT_SECRET=your_secret_here
|
||||||
|
|
||||||
|
CORS_ALLOWED_ORIGINS=http://localhost:5173
|
||||||
|
|
||||||
|
BYTESCALE_SECRET_API_KEY=your_key
|
||||||
|
POSTMARK_API_KEY=your_key
|
||||||
|
EMAIL_FROM=admin@example.com
|
||||||
|
```
|
||||||
|
|
||||||
|
### Frontend (`frontend/.env`)
|
||||||
|
|
||||||
|
```env
|
||||||
|
VITE_API_BASE_URL=http://localhost:5000
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Running the Project
|
||||||
|
|
||||||
|
### Start containers
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker compose -f docker-compose.dev.yml up --build
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### Stop containers
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker compose -f docker-compose.dev.yml down
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## Database (PostgreSQL)
|
||||||
|
|
||||||
|
- User: `user`
|
||||||
|
- Password: `password`
|
||||||
|
- DB: `mydb`
|
||||||
|
|
||||||
|
Data is persisted using Docker volume:
|
||||||
|
|
||||||
|
```
|
||||||
|
postgres_data
|
||||||
|
```
|
||||||
@@ -0,0 +1,44 @@
|
|||||||
|
version: "3.8"
|
||||||
|
|
||||||
|
services:
|
||||||
|
backend:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/dev/Dockerfile.main
|
||||||
|
ports:
|
||||||
|
- "5000:3000"
|
||||||
|
env_file:
|
||||||
|
- ./backend/.env
|
||||||
|
depends_on:
|
||||||
|
db:
|
||||||
|
condition: service_healthy
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
frontend:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/dev/Dockerfile.frontend
|
||||||
|
ports:
|
||||||
|
- "5173:5173"
|
||||||
|
env_file:
|
||||||
|
- ./frontend/.env
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
db:
|
||||||
|
image: postgres:15-alpine
|
||||||
|
container_name: postgres_db
|
||||||
|
environment:
|
||||||
|
POSTGRES_USER: user
|
||||||
|
POSTGRES_PASSWORD: password
|
||||||
|
POSTGRES_DB: mydb
|
||||||
|
volumes:
|
||||||
|
- postgres_data:/var/lib/postgresql/data
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD-SHELL", "pg_isready -U user -d mydb"]
|
||||||
|
interval: 5s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
postgres_data:
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
ARG NODE_VERSION=22.11.0
|
||||||
|
FROM node:${NODE_VERSION}-alpine
|
||||||
|
|
||||||
|
WORKDIR /usr/src/app
|
||||||
|
|
||||||
|
COPY ./frontend/package*.json ./
|
||||||
|
RUN npm ci
|
||||||
|
|
||||||
|
COPY ./frontend .
|
||||||
|
|
||||||
|
# Build the app
|
||||||
|
RUN npm run build
|
||||||
|
|
||||||
|
EXPOSE 5173
|
||||||
|
|
||||||
|
# Serve built app (no hot reload)
|
||||||
|
CMD ["npm", "run", "preview", "--", "--host", "0.0.0.0"]
|
||||||
@@ -0,0 +1,24 @@
|
|||||||
|
ARG NODE_VERSION=22.11.0
|
||||||
|
FROM node:${NODE_VERSION}-alpine
|
||||||
|
|
||||||
|
WORKDIR /usr/src/app
|
||||||
|
|
||||||
|
# Use cache mounts for faster installs
|
||||||
|
RUN --mount=type=bind,source=backend/package.json,target=package.json \
|
||||||
|
--mount=type=bind,source=backend/package-lock.json,target=package-lock.json \
|
||||||
|
--mount=type=cache,target=/root/.npm \
|
||||||
|
npm ci
|
||||||
|
|
||||||
|
# Copy the backend source
|
||||||
|
COPY ./backend .
|
||||||
|
|
||||||
|
# Copy and setup entrypoint
|
||||||
|
COPY ./docker/entrypoint.sh /usr/local/bin/entrypoint.sh
|
||||||
|
RUN chmod +x /usr/local/bin/entrypoint.sh
|
||||||
|
|
||||||
|
EXPOSE 5000
|
||||||
|
|
||||||
|
ENTRYPOINT [ "entrypoint.sh" ]
|
||||||
|
|
||||||
|
# This '$@' will be replaced by the CMD
|
||||||
|
CMD ["npm", "run", "dev"]
|
||||||
@@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -e # Exit immediately if a command exits with a non-zero status
|
||||||
|
|
||||||
|
echo "Generating Prisma Client..."
|
||||||
|
npx prisma generate
|
||||||
|
|
||||||
|
# echo "Running migrate..."
|
||||||
|
# npx prisma migrate deploy
|
||||||
|
echo "Running PUSH..."
|
||||||
|
npx prisma db push
|
||||||
|
|
||||||
|
echo "Executing command: $@"
|
||||||
|
exec "$@"
|
||||||
|
|
||||||
Generated
-7
@@ -8,7 +8,6 @@
|
|||||||
"name": "frontend",
|
"name": "frontend",
|
||||||
"version": "0.0.0",
|
"version": "0.0.0",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@bytescale/sdk": "^3.53.0",
|
|
||||||
"@editorjs/code": "^2.9.4",
|
"@editorjs/code": "^2.9.4",
|
||||||
"@editorjs/delimiter": "^1.4.2",
|
"@editorjs/delimiter": "^1.4.2",
|
||||||
"@editorjs/editorjs": "^2.31.5",
|
"@editorjs/editorjs": "^2.31.5",
|
||||||
@@ -525,12 +524,6 @@
|
|||||||
"node": ">=6.9.0"
|
"node": ">=6.9.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@bytescale/sdk": {
|
|
||||||
"version": "3.53.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/@bytescale/sdk/-/sdk-3.53.0.tgz",
|
|
||||||
"integrity": "sha512-qCeNup3pSjaklXuBrO9JeKbozZEs/PjQEvuqCiOAWLBRl6lDjd0V9gRVYqyttPimXYFoV+J/7dmPWtK6RfOABQ==",
|
|
||||||
"license": "MIT"
|
|
||||||
},
|
|
||||||
"node_modules/@codexteam/icons": {
|
"node_modules/@codexteam/icons": {
|
||||||
"version": "0.3.3",
|
"version": "0.3.3",
|
||||||
"resolved": "https://registry.npmjs.org/@codexteam/icons/-/icons-0.3.3.tgz",
|
"resolved": "https://registry.npmjs.org/@codexteam/icons/-/icons-0.3.3.tgz",
|
||||||
|
|||||||
@@ -10,7 +10,6 @@
|
|||||||
"preview": "vite preview"
|
"preview": "vite preview"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@bytescale/sdk": "^3.53.0",
|
|
||||||
"@editorjs/code": "^2.9.4",
|
"@editorjs/code": "^2.9.4",
|
||||||
"@editorjs/delimiter": "^1.4.2",
|
"@editorjs/delimiter": "^1.4.2",
|
||||||
"@editorjs/editorjs": "^2.31.5",
|
"@editorjs/editorjs": "^2.31.5",
|
||||||
|
|||||||
Reference in New Issue
Block a user