Merge pull request #107 from jabez007/docker_image_reduction

Reduce Docker image size
This commit is contained in:
TC² 2025-01-03 10:30:21 -05:00 committed by GitHub
commit 27279577dd
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 27 additions and 16 deletions

View File

@ -1,25 +1,36 @@
FROM alpine:latest
# From original Dockerfile at https://github.com/TheCommsChannel/TC2-BBS-mesh
FROM debian:stable-slim AS build
# Install required packages
RUN apk add --update --no-cache git python3 py3-pip
RUN apt-get update && \
apt-get install -y \
git \
&& apt-get clean && rm -rf /var/lib/apt/lists/*
# Clone the repository
RUN git clone https://github.com/TheCommsChannel/TC2-BBS-mesh.git
####
FROM --platform=$BUILDPLATFORM python:alpine
# Switch to non-root user
RUN adduser --disabled-password mesh
USER mesh
RUN mkdir -p /home/mesh/bbs
WORKDIR /home/mesh/bbs
# Install Python dependencies
RUN pip install --no-cache-dir --break-system-packages -r /TC2-BBS-mesh/requirements.txt
COPY --from=build /TC2-BBS-mesh/requirements.txt ./
RUN pip install --no-cache-dir --break-system-packages -r requirements.txt
# Copy configuration script
COPY configini.sh /
# Set permissions for configuration script
RUN chmod +x /configini.sh
# Copy over app code
COPY --from=build /TC2-BBS-mesh/*.py ./
# Define config volume
VOLUME /config
# Define working directory
WORKDIR /config
VOLUME /home/mesh/bbs/config
WORKDIR /home/mesh/bbs/config
COPY --from=build /TC2-BBS-mesh/example_config.ini ./config.ini
COPY --from=build /TC2-BBS-mesh/fortunes.txt ./
# Define the command to run
CMD ["sh", "-c", " /configini.sh && python3 /TC2-BBS-mesh/server.py"]
ENTRYPOINT [ "python3", "/home/mesh/bbs/server.py" ]

View File

@ -3,5 +3,5 @@ services:
build: .
restart: always
volumes:
- ./config:/config
- ./config:/home/mesh/bbs/config
container_name: tc2-bbs-mesh