Refactor Docker setup: consolidate Dockerfile stages, add entrypoint script, and update .gitignore and .dockerignore
This commit is contained in:
@@ -1,5 +1,4 @@
|
|||||||
target
|
target
|
||||||
dockerfile
|
|
||||||
.dockerignore
|
.dockerignore
|
||||||
.git
|
.git
|
||||||
.gitignore
|
.gitignore
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@@ -21,5 +21,6 @@ node_modules/
|
|||||||
*.db
|
*.db
|
||||||
|
|
||||||
uploads/
|
uploads/
|
||||||
|
database/
|
||||||
assets/static/css/main.css
|
assets/static/css/main.css
|
||||||
.env
|
.env
|
14
compose.yml
Normal file
14
compose.yml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
services:
|
||||||
|
website:
|
||||||
|
build: .
|
||||||
|
container_name: gabrielkaszewski-website
|
||||||
|
restart: unless-stopped
|
||||||
|
ports:
|
||||||
|
- "80:5150"
|
||||||
|
volumes:
|
||||||
|
- ./database:/app/db
|
||||||
|
- ./uploads:/app/uploads
|
||||||
|
environment:
|
||||||
|
- JWT_SECRET=your_super_secret_production_jwt_key_here
|
||||||
|
- HOST=https://your-domain.com
|
||||||
|
- BINDING=0.0.0.0
|
@@ -1,32 +0,0 @@
|
|||||||
services:
|
|
||||||
web:
|
|
||||||
build: .
|
|
||||||
volumes:
|
|
||||||
- uploads_volume:/usr/app/uploads
|
|
||||||
environment:
|
|
||||||
- HOST=${HOST}
|
|
||||||
- DATABASE_URL=${DATABASE_URL}
|
|
||||||
- JWT_SECRET=${JWT_SECRET}
|
|
||||||
- LOGGER_LEVEL=${LOGGER_LEVEL}
|
|
||||||
- BINDING=${BINDING}
|
|
||||||
depends_on:
|
|
||||||
db:
|
|
||||||
condition: service_healthy
|
|
||||||
expose:
|
|
||||||
- 5150
|
|
||||||
db:
|
|
||||||
image: postgres:latest
|
|
||||||
volumes:
|
|
||||||
- postgres_data:/var/lib/postgresql/data
|
|
||||||
environment:
|
|
||||||
- POSTGRES_USER=${POSTGRES_USER}
|
|
||||||
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
|
|
||||||
- POSTGRES_DB=${POSTGRES_DB}
|
|
||||||
healthcheck:
|
|
||||||
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER}"]
|
|
||||||
interval: 10s
|
|
||||||
timeout: 5s
|
|
||||||
retries: 5
|
|
||||||
volumes:
|
|
||||||
postgres_data:
|
|
||||||
uploads_volume:
|
|
52
dockerfile
52
dockerfile
@@ -1,17 +1,51 @@
|
|||||||
FROM rust:1.88-slim as builder
|
# =================================================================
|
||||||
|
# Stage 1: Build the Rust application
|
||||||
|
# =================================================================
|
||||||
|
FROM rust:1.89-slim-bookworm AS builder
|
||||||
|
|
||||||
WORKDIR /usr/src/
|
RUN apt-get update && apt-get install -y libsqlite3-dev pkg-config build-essential
|
||||||
|
|
||||||
COPY . .
|
WORKDIR /app
|
||||||
|
|
||||||
|
COPY Cargo.toml Cargo.lock ./
|
||||||
|
COPY .cargo ./.cargo/
|
||||||
|
COPY migration ./migration
|
||||||
|
|
||||||
|
RUN mkdir -p src/bin && \
|
||||||
|
echo "fn main() {}" > src/bin/main.rs && \
|
||||||
|
echo "fn main() {}" > src/bin/tool.rs
|
||||||
RUN cargo build --release
|
RUN cargo build --release
|
||||||
|
|
||||||
FROM debian:bookworm-slim
|
COPY src ./src
|
||||||
|
COPY assets ./assets
|
||||||
|
COPY config ./config
|
||||||
|
RUN cargo build --release
|
||||||
|
|
||||||
WORKDIR /usr/app
|
# =================================================================
|
||||||
|
# Stage 2: Create the final, lightweight runtime image
|
||||||
|
# =================================================================
|
||||||
|
FROM debian:bookworm-slim AS runtime
|
||||||
|
|
||||||
COPY --from=builder /usr/src/assets /usr/app/assets
|
RUN apt-get update && apt-get install -y libsqlite3-0 libssl3 gosu && rm -rf /var/lib/apt/lists/*
|
||||||
COPY --from=builder /usr/src/config /usr/app/config
|
|
||||||
COPY --from=builder /usr/src/target/release/gabrielkaszewski_rs-cli /usr/app/gabrielkaszewski_rs-cli
|
|
||||||
|
|
||||||
ENTRYPOINT ["/usr/app/gabrielkaszewski_rs-cli", "start"]
|
RUN addgroup --system nonroot && adduser --system --ingroup nonroot nonroot
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
COPY --from=builder /app/target/release/gabrielkaszewski_rs-cli ./server
|
||||||
|
|
||||||
|
COPY assets ./assets
|
||||||
|
COPY config ./config
|
||||||
|
|
||||||
|
RUN mkdir -p /app/db /app/uploads && chown -R nonroot:nonroot /app/db /app/uploads
|
||||||
|
|
||||||
|
COPY entrypoint.sh /usr/local/bin/entrypoint.sh
|
||||||
|
RUN chmod +x /usr/local/bin/entrypoint.sh
|
||||||
|
|
||||||
|
ENV LOCO_ENV=production
|
||||||
|
ENV DATABASE_URL=sqlite:///app/db/production.db?mode=rwc
|
||||||
|
|
||||||
|
EXPOSE 5150
|
||||||
|
|
||||||
|
ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]
|
||||||
|
CMD ["./server", "start"]
|
6
entrypoint.sh
Normal file
6
entrypoint.sh
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -e
|
||||||
|
|
||||||
|
chown -R nonroot:nonroot /app/db /app/uploads
|
||||||
|
|
||||||
|
exec gosu nonroot "$@"
|
Reference in New Issue
Block a user