Compare commits
3 Commits
main
...
feat/docke
Author | SHA1 | Date | |
---|---|---|---|
|
1d3592a72d | ||
|
37c10f86ce | ||
|
7fd3e3c546 |
3
.dockerignore
Normal file
3
.dockerignore
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
frontend/node_modules
|
||||||
|
backend/server/.env
|
||||||
|
backend/server/node_modules
|
25
.github/workflows/docker-image.yml
vendored
Normal file
25
.github/workflows/docker-image.yml
vendored
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
name: Docker Image CI
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ "main" ]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
|
||||||
|
build:
|
||||||
|
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- name: Write .env file
|
||||||
|
run: echo "${{secrets.FRONTEND_DOT_ENV}}" > ./frontend/.env
|
||||||
|
- name: Login Dockerhub
|
||||||
|
env:
|
||||||
|
DOCKER_USERNAME: ${{secrets.DOCKER_USERNAME}}
|
||||||
|
DOCKER_PASSWORD: ${{secrets.DOCKER_PASSWORD}}
|
||||||
|
run: echo $DOCKER_PASSWORD | docker login -u $DOCKER_USERNAME --password-stdin
|
||||||
|
- name: Build the Docker image
|
||||||
|
run: docker build -t jamesmurdza/sandbox .
|
||||||
|
- name: Push to Dockerhub
|
||||||
|
run: docker push jamesmurdza/sandbox:latest
|
41
dockerfile
Normal file
41
dockerfile
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
# docker build -t myimage .
|
||||||
|
# docker run --env-file backend/server/.env -p 3000:3000 -p 4000:4000 myimage
|
||||||
|
|
||||||
|
FROM node:20
|
||||||
|
|
||||||
|
# Security: Drop all capabilities
|
||||||
|
USER root
|
||||||
|
RUN apt-get update && apt-get install -y libcap2-bin
|
||||||
|
RUN setcap cap_net_bind_service=+ep /usr/local/bin/node
|
||||||
|
|
||||||
|
# Build backend
|
||||||
|
WORKDIR /backend
|
||||||
|
COPY backend/server/package*.json ./
|
||||||
|
RUN npm install
|
||||||
|
COPY backend/server/ .
|
||||||
|
RUN npm run build
|
||||||
|
|
||||||
|
# Build frontend
|
||||||
|
WORKDIR /frontend
|
||||||
|
COPY frontend/package*.json ./
|
||||||
|
RUN npm install
|
||||||
|
COPY frontend .
|
||||||
|
RUN npm run build
|
||||||
|
|
||||||
|
# Set working directory to the root directory
|
||||||
|
WORKDIR /
|
||||||
|
|
||||||
|
# Security: Create non-root user and assign ownership
|
||||||
|
RUN useradd -m appuser
|
||||||
|
RUN mkdir -p /backend/projects && chown -R appuser:appuser /backend/projects
|
||||||
|
USER appuser
|
||||||
|
|
||||||
|
# Start both backend and frontend
|
||||||
|
ENV BACKEND_PORT=4000
|
||||||
|
ENV FRONTEND_PORT=3000
|
||||||
|
|
||||||
|
EXPOSE 5173
|
||||||
|
EXPOSE $BACKEND_PORT
|
||||||
|
EXPOSE $FRONTEND_PORT
|
||||||
|
|
||||||
|
CMD ["sh", "-c", "cd /backend && PORT=$BACKEND_PORT npm run start & cd /frontend && PORT=$FRONTEND_PORT npm run start"]
|
Loading…
x
Reference in New Issue
Block a user