Update Dockerfile and compose.yml for version upgrades and configuration changes

This commit is contained in:
Arndt Touby 2025-01-17 21:48:39 +01:00
parent 3bc810de42
commit 01bbf44c3b
2 changed files with 45 additions and 30 deletions

View file

@ -11,26 +11,30 @@
# - https://pkgs.org/ - resource for finding needed packages # - https://pkgs.org/ - resource for finding needed packages
# - Ex: hexpm/elixir:1.17.2-erlang-27.0.1-debian-bullseye-20240904-slim # - Ex: hexpm/elixir:1.17.2-erlang-27.0.1-debian-bullseye-20240904-slim
# #
ARG ELIXIR_VERSION=1.17.2 ARG ELIXIR_VERSION=1.18.1
ARG OTP_VERSION=27.0.1 ARG OTP_VERSION=27.2
ARG DEBIAN_VERSION=bullseye-20240904-slim ARG DEBIAN_VERSION=bookworm-20241223-slim
ARG BUILDER_IMAGE="hexpm/elixir:${ELIXIR_VERSION}-erlang-${OTP_VERSION}-debian-${DEBIAN_VERSION}" ARG BUILDER_IMAGE="hexpm/elixir:${ELIXIR_VERSION}-erlang-${OTP_VERSION}-debian-${DEBIAN_VERSION}"
ARG RUNNER_IMAGE="debian:${DEBIAN_VERSION}" ARG RUNNER_IMAGE="debian:${DEBIAN_VERSION}"
ARG NODE_VERSION=20
#################################################################################################### ####################################################################################################
FROM ${BUILDER_IMAGE} as package_installer FROM ${BUILDER_IMAGE} AS package_installer
# install build dependencies # install build dependencies
RUN curl -fsSL https://deb.nodesource.com/setup_${NODE_VERSION}.x
RUN apt-get update -y && apt-get install -y build-essential \ RUN apt-get update -y && apt-get install -y build-essential \
git \ git \
locales \ locales \
curl \
inotify-tools \ inotify-tools \
nodejs \
&& apt-get clean && rm -f /var/lib/apt/lists/*_* && apt-get clean && rm -f /var/lib/apt/lists/*_*
# prepare build dir # prepare build dir
WORKDIR /app WORKDIR /app
#################################################################################################### ####################################################################################################
FROM package_installer as development FROM package_installer AS development
RUN mix local.hex --force && \ RUN mix local.hex --force && \
mix archive.install hex phx_new --force && \ mix archive.install hex phx_new --force && \
mix local.rebar --force mix local.rebar --force
@ -39,7 +43,7 @@ COPY . .
CMD [ "bash" ] CMD [ "bash" ]
#################################################################################################### ####################################################################################################
FROM package_installer as builder FROM package_installer AS builder
# install hex + rebar # install hex + rebar
RUN mix local.hex --force && \ RUN mix local.hex --force && \
@ -77,7 +81,6 @@ COPY config/runtime.exs config/
COPY rel rel COPY rel rel
RUN mix release RUN mix release
#################################################################################################### ####################################################################################################
# start a new build stage so that the final image will only contain # start a new build stage so that the final image will only contain
# the compiled release and other runtime necessities # the compiled release and other runtime necessities
FROM ${RUNNER_IMAGE} FROM ${RUNNER_IMAGE}
@ -89,9 +92,9 @@ RUN apt-get update -y && \
# Set the locale # Set the locale
RUN sed -i '/en_US.UTF-8/s/^# //g' /etc/locale.gen && locale-gen RUN sed -i '/en_US.UTF-8/s/^# //g' /etc/locale.gen && locale-gen
ENV LANG en_US.UTF-8 ENV LANG=en_US.UTF-8
ENV LANGUAGE en_US:en ENV LANGUAGE=en_US:en
ENV LC_ALL en_US.UTF-8 ENV LC_ALL=en_US.UTF-8
WORKDIR "/app" WORKDIR "/app"
RUN chown nobody /app RUN chown nobody /app
@ -100,7 +103,19 @@ RUN chown nobody /app
ENV MIX_ENV="prod" ENV MIX_ENV="prod"
# Only copy the final release from the build stage # Only copy the final release from the build stage
COPY --from=builder --chown=nobody:root /app/_build/${MIX_ENV}/rel/phoenix_deploy_test ./ COPY --from=builder --chown=nobody:root /app/_build/${MIX_ENV}/rel/phx_db ./
# Copy the tailwind-cli binary used to compile stylesheets for pages
RUN mkdir -p ./bin/_build
COPY --from=builder --chown=nobody:root /app/_build/tailwind-* ./bin/_build/
# Copy heroicons svg files to used on the icon component
RUN mkdir -p ./vendor
COPY --from=builder --chown=nobody:root /app/deps/heroicons ./vendor/heroicons
# create cache dir for Req
RUN mkdir -p /nonexistent/.cache/req
RUN chown nobody:root /nonexistent/.cache/req
USER nobody USER nobody
@ -109,4 +124,4 @@ USER nobody
# above and adding an entrypoint. See https://github.com/krallin/tini for details # above and adding an entrypoint. See https://github.com/krallin/tini for details
# ENTRYPOINT ["/tini", "--"] # ENTRYPOINT ["/tini", "--"]
CMD ["/app/bin/server"] CMD ["sh", "-c", "/app/bin/migrate && /app/bin/server"]

View file

@ -1,16 +1,16 @@
services: services:
# db: db:
# image: postgres:16 image: postgres:17
# restart: always restart: always
# environment: environment:
# POSTGRES_USER: postgres POSTGRES_USER: postgres
# POSTGRES_PASSWORD: postgres POSTGRES_PASSWORD: postgres
# POSTGRES_DB: phoenix_deploy_test_dev POSTGRES_DB: bmt_checkout_dev
# volumes: volumes:
# - postgres:/var/lib/postgresql/data - postgres:/var/lib/postgresql/data
# - /etc/localtime:/etc/localtime:ro - /etc/localtime:/etc/localtime:ro
# ports: ports:
# - 5432:5432 - 5432:5432
app: app:
command: bash #-c "mix deps.get && mix phx.server" command: bash #-c "mix deps.get && mix phx.server"
@ -23,8 +23,8 @@ services:
environment: environment:
- HISTFILE=/usr/local/hist/.bash_history - HISTFILE=/usr/local/hist/.bash_history
# depends_on: depends_on:
# - db - db
volumes: volumes:
- .:/app - .:/app
- bash_history:/usr/local/hist - bash_history:/usr/local/hist
@ -34,4 +34,4 @@ services:
volumes: volumes:
bash_history: bash_history:
# postgres: postgres: