feat: Add Dockerfile and Docker Compose configuration for containerized deployment and update README with instructions.
This commit is contained in:
46
Dockerfile
Normal file
46
Dockerfile
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
# Build Stage
|
||||||
|
FROM rust:1.85-bookworm AS builder
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
# Cache dependencies
|
||||||
|
# We create a dummy project to build only dependencies
|
||||||
|
RUN cargo new --bin blog_cms
|
||||||
|
COPY Cargo.toml Cargo.lock ./
|
||||||
|
RUN cargo build --release
|
||||||
|
RUN rm src/*.rs
|
||||||
|
|
||||||
|
# Copy real source
|
||||||
|
COPY src ./src
|
||||||
|
COPY templates ./templates
|
||||||
|
|
||||||
|
# The templates are needed during compilation by askama
|
||||||
|
# Rebuild the real source
|
||||||
|
RUN touch src/main.rs && cargo build --release
|
||||||
|
|
||||||
|
# Final Stage
|
||||||
|
FROM debian:bookworm-slim
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
# Install runtime dependencies (like SSL certificates and sqlite)
|
||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
|
ca-certificates \
|
||||||
|
libsqlite3-0 \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Copy the binary from the builder
|
||||||
|
COPY --from=builder /app/target/release/blog_cms .
|
||||||
|
|
||||||
|
# Create directory for attachments and database
|
||||||
|
RUN mkdir -p attachments
|
||||||
|
|
||||||
|
# Default environment variables
|
||||||
|
ENV PORT=3000
|
||||||
|
ENV DATABASE_URL=sqlite:///app/data.db
|
||||||
|
|
||||||
|
# Expose the application port
|
||||||
|
EXPOSE 3000
|
||||||
|
|
||||||
|
# Start the application
|
||||||
|
CMD ["./blog_cms"]
|
||||||
32
README.md
32
README.md
@@ -27,6 +27,7 @@ sqlx database create
|
|||||||
```
|
```
|
||||||
*(Optionally run migrations if any exist: `sqlx migrate run`)*
|
*(Optionally run migrations if any exist: `sqlx migrate run`)*
|
||||||
|
|
||||||
|
|
||||||
## Running the app
|
## Running the app
|
||||||
|
|
||||||
To start the server, simply run:
|
To start the server, simply run:
|
||||||
@@ -36,3 +37,34 @@ cargo run
|
|||||||
```
|
```
|
||||||
|
|
||||||
Then, open your web browser and navigate to `http://localhost:3000` (or whichever port you configured).
|
Then, open your web browser and navigate to `http://localhost:3000` (or whichever port you configured).
|
||||||
|
|
||||||
|
## Run with Docker
|
||||||
|
|
||||||
|
You can also run this project using Docker.
|
||||||
|
|
||||||
|
### Using Docker Compose (Recommended)
|
||||||
|
|
||||||
|
To start the application and its dependencies (like the database and attachment storage):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
docker-compose up -d --build
|
||||||
|
```
|
||||||
|
|
||||||
|
The application will be accessible at `http://localhost:3000`. Persistent data (the database and attachments) will be stored in the local directory.
|
||||||
|
|
||||||
|
### Using Docker Directly
|
||||||
|
|
||||||
|
1. Build the image:
|
||||||
|
```bash
|
||||||
|
docker build -t blog-cms .
|
||||||
|
```
|
||||||
|
|
||||||
|
2. Run the container:
|
||||||
|
```bash
|
||||||
|
docker run -d \
|
||||||
|
-p 3000:3000 \
|
||||||
|
-v $(pwd)/data.db:/app/data.db \
|
||||||
|
-v $(pwd)/attachments:/app/attachments \
|
||||||
|
--name blog-cms \
|
||||||
|
blog-cms
|
||||||
|
```
|
||||||
|
|||||||
13
docker-compose.yml
Normal file
13
docker-compose.yml
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
version: '3.8'
|
||||||
|
services:
|
||||||
|
blog:
|
||||||
|
build: .
|
||||||
|
ports:
|
||||||
|
- "3000:3000"
|
||||||
|
environment:
|
||||||
|
- PORT=3000
|
||||||
|
- DATABASE_URL=sqlite:///app/data.db
|
||||||
|
volumes:
|
||||||
|
- ./data.db:/app/data.db
|
||||||
|
- ./attachments:/app/attachments
|
||||||
|
restart: always
|
||||||
Reference in New Issue
Block a user